Implements Brinkman penalisation terms for topology optimisation. Looks up the indicator field (beta) from the registry, through topOVariablesBase. More...


Public Member Functions | |
| TypeName ("topOSource") | |
| Runtime type information. More... | |
| topOSource (const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh) | |
| Construct from components. More... | |
| virtual | ~topOSource ()=default |
| Destructor. More... | |
| virtual void | addSup (fvMatrix< vector > &eqn, const label fieldi) |
| Add implicit contribution to momentum equation. More... | |
| virtual void | addSup (fvMatrix< scalar > &eqn, const label fieldi) |
| Add implicit contribution to scalar equations (e.g. turbulence model) More... | |
| virtual void | addSup (const volScalarField &rho, fvMatrix< vector > &eqn, const label fieldi) |
| Add implicit contribution to compressible momentum equation. More... | |
| virtual void | addSup (const volScalarField &rho, fvMatrix< scalar > &eqn, const label fieldi) |
| Add implicit contribution to compressible scalar equation. More... | |
| virtual void | postProcessSens (scalarField &sensField, const word &fieldName=word::null, const word &designValue=word::null) |
| Multiply sensitivities with the derivative of the interpolation function. More... | |
| virtual bool | read (const dictionary &dict) |
| Read source dictionary. More... | |
Public Member Functions inherited from option | |
| TypeName ("option") | |
| Runtime type information. More... | |
| declareRunTimeSelectionTable (autoPtr, option, dictionary,(const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh),(name, modelType, dict, mesh)) | |
| option (const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh) | |
| Construct from components. More... | |
| autoPtr< option > | clone () const |
| Return clone. More... | |
| virtual | ~option ()=default |
| Destructor. More... | |
| const word & | name () const noexcept |
| Return const access to the source name. More... | |
| const fvMesh & | mesh () const noexcept |
| Return const access to the mesh database. More... | |
| const dictionary & | coeffs () const noexcept |
| Return dictionary. More... | |
| bool | active () const noexcept |
| True if source is active. More... | |
| void | setApplied (const label fieldi) |
| Set the applied flag to true for field index fieldi. More... | |
| bool | active (const bool on) noexcept |
| Change source active flag, return previous value. More... | |
| virtual bool | isActive () |
| Is the source active? More... | |
| virtual label | applyToField (const word &fieldName) const |
| Return index of field name if found in fieldNames list. More... | |
| virtual void | checkApplied () const |
| Check that the source has been applied. More... | |
| virtual void | addSup (fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< vector > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< vector > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | correct (volScalarField &field) |
| virtual void | correct (volVectorField &field) |
| virtual void | correct (volSphericalTensorField &field) |
| virtual void | correct (volSymmTensorField &field) |
| virtual void | correct (volTensorField &field) |
| virtual void | correct (surfaceScalarField &field) |
| virtual void | correct (surfaceVectorField &field) |
| virtual void | correct (surfaceTensorField &field) |
| virtual void | postProcessSens (vectorField &sensField, const word &fieldName=word::null, const word &designVariablesName=word::null) |
| virtual void | postProcessSens (tensorField &sensField, const word &fieldName=word::null, const word &designVariablesName=word::null) |
| virtual void | postProcessAuxSens (const volScalarField &primalField, const volScalarField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | postProcessAuxSens (const volVectorField &primalField, const volVectorField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | postProcessAuxSens (const volTensorField &primalField, const volTensorField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | writeHeader (Ostream &) const |
| Write the source header information. More... | |
| virtual void | writeFooter (Ostream &) const |
| Write the source footer information. More... | |
| virtual void | writeData (Ostream &) const |
| Write the source properties. More... | |
Protected Member Functions | |
| virtual tmp< DimensionedField< scalar, volMesh > > | getSource () |
| Compute the source term based on the indicator field. More... | |
Protected Member Functions inherited from option | |
| void | resetApplied () |
| Resize/reset applied flag list for all fieldNames_ entries. More... | |
Protected Attributes | |
| autoPtr< topOInterpolationFunction > | interpolation_ |
| Interpolation function. More... | |
| word | interpolationFieldName_ |
| Interpolation field name. More... | |
| scalar | betaMax_ |
| Optional betaMax. More... | |
| bool | darcyFlow_ |
| Does this option apply to a Darcy flow model. More... | |
| autoPtr< scalar > | Da_ |
| Dimensionless Darcy number. More... | |
Protected Attributes inherited from option | |
| const word | name_ |
| Source name. More... | |
| const word | modelType_ |
| Model type. More... | |
| const fvMesh & | mesh_ |
| Reference to the mesh database. More... | |
| dictionary | dict_ |
| Top level source dictionary. More... | |
| dictionary | coeffs_ |
| Dictionary containing source coefficients. More... | |
| wordList | fieldNames_ |
| Field names to apply source to - populated by derived models. More... | |
| List< bool > | applied_ |
| Applied flag list - corresponds to each fieldNames_ entry. More... | |
| bool | active_ |
| Source active flag. More... | |
Additional Inherited Members | |
Static Public Member Functions inherited from option | |
| static autoPtr< option > | New (const word &name, const dictionary &dict, const fvMesh &mesh) |
| Return a reference to the selected fvOption model. More... | |
Public Attributes inherited from option | |
| bool | log |
| Switch write log to Info. More... | |
Implements Brinkman penalisation terms for topology optimisation. Looks up the indicator field (beta) from the registry, through topOVariablesBase.
Definition at line 57 of file topOSource.H.
| topOSource | ( | const word & | name, |
| const word & | modelType, | ||
| const dictionary & | dict, | ||
| const fvMesh & | mesh | ||
| ) |
Construct from components.
Definition at line 89 of file topOSource.C.
References dict, and Foam::read().

|
virtualdefault |
Destructor.
|
protectedvirtual |
Compute the source term based on the indicator field.
Definition at line 48 of file topOSource.C.
References topOSource::betaMax_, topOSource::Da_, topOSource::darcyFlow_, Foam::dimless, Foam::dimTime, objectRegistry::foundObject(), topOSource::interpolation_, topOSource::interpolationFieldName_, objectRegistry::lookupObject(), option::mesh_, primitiveMesh::nCells(), option::New(), IOobjectOption::NO_READ, IOobjectOption::NO_WRITE, topOVariablesBase::sourceTerm(), fvMesh::time(), Time::timeName(), and Foam::Zero.

| TypeName | ( | "topOSource" | ) |
Runtime type information.
Add implicit contribution to momentum equation.
Reimplemented from option.
Definition at line 110 of file topOSource.C.
References DebugInfo, Foam::endl(), IOobject::name(), fvMatrix< Type >::psi(), and Foam::fvm::Sp().

|
virtual |
Add implicit contribution to scalar equations (e.g. turbulence model)
Reimplemented from option.
Definition at line 123 of file topOSource.C.
References DebugInfo, Foam::endl(), IOobject::name(), fvMatrix< Type >::psi(), and Foam::fvm::Sp().

|
virtual |
Add implicit contribution to compressible momentum equation.
Reimplemented from option.
Definition at line 136 of file topOSource.C.
References DebugInfo, Foam::endl(), IOobject::name(), fvMatrix< Type >::psi(), rho, and Foam::fvm::Sp().

|
virtual |
Add implicit contribution to compressible scalar equation.
Reimplemented from option.
Definition at line 150 of file topOSource.C.
References DebugInfo, Foam::endl(), IOobject::name(), fvMatrix< Type >::psi(), rho, and Foam::fvm::Sp().

|
virtual |
Multiply sensitivities with the derivative of the interpolation function.
Reimplemented from option.
Definition at line 164 of file topOSource.C.
References DebugInfo, Foam::endl(), and topOVariablesBase::sourceTermSensitivities().

|
virtual |
Read source dictionary.
Reimplemented from option.
Definition at line 194 of file topOSource.C.
References dict, UList< T >::get(), topOVariablesBase::getBetaMax(), dictionary::getOrDefault(), and option::read().

|
protected |
Interpolation function.
Definition at line 69 of file topOSource.H.
Referenced by topOSource::getSource().
|
protected |
Interpolation field name.
Definition at line 74 of file topOSource.H.
Referenced by topOSource::getSource().
|
protected |
Optional betaMax.
If not found, the one known by topOVariablesBase will be used.
Definition at line 81 of file topOSource.H.
Referenced by topOSource::getSource().
|
protected |
Does this option apply to a Darcy flow model.
Definition at line 86 of file topOSource.H.
Referenced by topOSource::getSource().
|
protected |
Dimensionless Darcy number.
Definition at line 91 of file topOSource.H.
Referenced by topOSource::getSource().