Continuous adjoint to the Spalart-Allmaras one-eqn mixing-length model for incompressible flows. More...
Public Member Functions | |
TypeName ("adjointSpalartAllmaras") | |
adjointSpalartAllmaras (incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName=adjointTurbulenceModel::typeName, const word &modelName=typeName) | |
virtual | ~adjointSpalartAllmaras ()=default |
virtual tmp< volSymmTensorField > | devReff () const |
virtual tmp< volSymmTensorField > | devReff (const volVectorField &U) const |
virtual tmp< fvVectorMatrix > | divDevReff (volVectorField &U) const |
virtual tmp< volVectorField > | adjointMeanFlowSource () |
virtual tmp< volScalarField > | nutJacobianTMVar1 () const |
virtual tmp< scalarField > | diffusionCoeffVar1 (label patchI) const |
virtual const boundaryVectorField & | adjointMomentumBCSource () const |
virtual const boundaryVectorField & | wallShapeSensitivities () |
virtual const boundaryVectorField & | wallFloCoSensitivities () |
virtual tmp< volScalarField > | distanceSensitivities () |
virtual tmp< volTensorField > | FISensitivityTerm () |
virtual void | nullify () |
virtual void | correct () |
virtual bool | read () |
![]() | |
TypeName ("adjointRASModel") | |
declareRunTimeSelectionTable (autoPtr, adjointRASModel, dictionary,(incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName),(primalVars, adjointVars, objManager, adjointTurbulenceModelName)) | |
adjointRASModel (const word &type, incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName=adjointTurbulenceModel::typeName) | |
virtual | ~adjointRASModel ()=default |
const nearWallDist & | y () const |
const dictionary & | coeffDict () const |
const word & | primalSolverName () const |
const word & | adjointSolverName () const |
volScalarField & | getAdjointTMVariable1Inst () |
volScalarField & | getAdjointTMVariable2Inst () |
volScalarField & | getAdjointTMVariable1 () |
volScalarField & | getAdjointTMVariable2 () |
autoPtr< volScalarField > & | getAdjointTMVariable1InstPtr () |
autoPtr< volScalarField > & | getAdjointTMVariable2InstPtr () |
virtual tmp< volScalarField > | nutJacobianTMVar2 () const |
virtual tmp< scalarField > | diffusionCoeffVar2 (label patchI) const |
void | setChangedPrimalSolution () |
void | resetMeanFields () |
void | computeMeanFields () |
bool | includeDistance () const |
![]() | |
TypeName ("adjointTurbulenceModel") | |
declareRunTimeNewSelectionTable (autoPtr, adjointTurbulenceModel, adjointTurbulenceModel,(incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName),(primalVars, adjointVars, objManager, adjointTurbulenceModelName)) | |
adjointTurbulenceModel (incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName=typeName) | |
virtual | ~adjointTurbulenceModel ()=default |
tmp< volScalarField > | nu () const |
virtual tmp< volScalarField > | nuEff () const |
virtual bool | writeData (Ostream &) const |
![]() | |
TypeName ("regIOobject") | |
regIOobject (const IOobject &io, const bool isTimeObject=false) | |
regIOobject (const regIOobject &rio) | |
regIOobject (const regIOobject &rio, bool registerCopy) | |
regIOobject (const word &newName, const regIOobject &, bool registerCopy) | |
regIOobject (const IOobject &io, const regIOobject &rio) | |
virtual | ~regIOobject () |
bool | checkIn () |
bool | checkOut () |
virtual void | addWatch () |
bool | ownedByRegistry () const |
bool | store () |
void | release (const bool unregister=false) |
label | eventNo () const |
label & | eventNo () |
bool | upToDate (const regIOobject &) const |
bool | upToDate (const regIOobject &, const regIOobject &) const |
bool | upToDate (const regIOobject &, const regIOobject &, const regIOobject &) const |
bool | upToDate (const regIOobject &, const regIOobject &, const regIOobject &, const regIOobject &) const |
void | setUpToDate () |
virtual void | rename (const word &newName) |
const dictionary * | findMetaData () const noexcept |
dictionary & | getMetaData () noexcept |
void | removeMetaData () |
virtual void | updateMetaData () |
bool | headerOk () |
Istream & | readStream (const word &, const bool valid=true) |
void | close () |
virtual label | addWatch (const fileName &) |
const labelList & | watchIndices () const |
labelList & | watchIndices () |
virtual bool | modified () const |
virtual bool | readIfModified () |
virtual bool | writeObject (IOstreamOption streamOpt, const bool valid) const |
virtual bool | write (const bool valid=true) const |
void | operator= (const IOobject &io) |
virtual bool | writeObject (IOstreamOption::streamFormat fmt, IOstreamOption::versionNumber ver, IOstreamOption::compressionType comp, const bool valid) const |
![]() | |
TypeName ("IOobject") | |
IOobject (const IOobject &)=default | |
virtual | ~IOobject ()=default |
IOobject (const word &name, const fileName &instance, const objectRegistry ®istry, readOption r=NO_READ, writeOption w=NO_WRITE, bool registerObject=true, bool globalObject=false) | |
IOobject (const word &name, const fileName &instance, const fileName &local, const objectRegistry ®istry, readOption r=NO_READ, writeOption w=NO_WRITE, bool registerObject=true, bool globalObject=false) | |
IOobject (const fileName &path, const objectRegistry ®istry, readOption r=NO_READ, writeOption w=NO_WRITE, bool registerObject=true, bool globalObject=false) | |
IOobject (const IOobject &io, const objectRegistry ®istry) | |
IOobject (const IOobject &io, const word &name) | |
IOobject (const IOobject &io, readOption, writeOption) | |
autoPtr< IOobject > | clone () const |
autoPtr< IOobject > | clone (const objectRegistry ®istry) const |
const objectRegistry & | db () const noexcept |
const Time & | time () const |
const word & | name () const noexcept |
const word & | headerClassName () const noexcept |
word & | headerClassName () noexcept |
const string & | note () const noexcept |
string & | note () noexcept |
bool | registerObject () const noexcept |
bool | registerObject (bool on) noexcept |
bool | globalObject () const noexcept |
bool | globalObject (bool on) noexcept |
unsigned | labelByteSize () const noexcept |
unsigned | scalarByteSize () const noexcept |
bool | isHeaderClassName (const word &clsName) const |
template<class Type > | |
bool | isHeaderClassName () const |
readOption | readOpt () const noexcept |
readOption | readOpt (readOption opt) noexcept |
writeOption | writeOpt () const noexcept |
writeOption | writeOpt (writeOption opt) noexcept |
word | group () const |
word | member () const |
const fileName & | rootPath () const |
const fileName & | caseName () const |
const fileName & | instance () const noexcept |
fileName & | instance () noexcept |
const fileName & | local () const noexcept |
fileName | path () const |
fileName | path (const word &instance, const fileName &local=fileName::null) const |
fileName | objectPath () const |
fileName | objectRelPath () const |
fileName | localFilePath (const word &typeName, const bool search=true) const |
fileName | globalFilePath (const word &typeName, const bool search=true) const |
IOstreamOption | parseHeader (const dictionary &headerDict) |
bool | readHeader (Istream &is) |
bool | readHeader (dictionary &headerDict, Istream &is) |
template<class Type > | |
bool | typeHeaderOk (const bool checkType=true, const bool search=true, const bool verbose=true) |
template<class Type > | |
void | warnNoRereading () const |
bool | writeHeader (Ostream &os) const |
bool | writeHeader (Ostream &os, const word &objectType) const |
void | writeHeader (dictionary &dict, IOstreamOption streamOpt) const |
void | writeHeader (dictionary &dict, const word &objectType, IOstreamOption streamOpt) const |
bool | good () const noexcept |
bool | bad () const noexcept |
InfoProxy< IOobject > | info () const |
void | operator= (const IOobject &io) |
readOption & | readOpt () noexcept |
writeOption & | writeOpt () noexcept |
bool & | registerObject () noexcept |
bool & | globalObject () noexcept |
template<> | |
bool | isHeaderClassName () const |
template<class StringType > | |
Foam::word | groupName (StringType base, const word &group) |
![]() | |
IOdictionary (const IOobject &io, const dictionary *fallback=nullptr) | |
IOdictionary (const IOobject &io, const dictionary &dict) | |
IOdictionary (const IOobject &io, const word &wantedType, const dictionary *fallback=nullptr) | |
IOdictionary (const IOobject &io, Istream &is) | |
virtual | ~IOdictionary ()=default |
virtual bool | global () const |
virtual fileName | filePath () const |
![]() | |
TypeName ("dictionary") | |
baseIOdictionary (const baseIOdictionary &)=default | |
baseIOdictionary (baseIOdictionary &&)=default | |
virtual | ~baseIOdictionary ()=default |
baseIOdictionary (const IOobject &io, const dictionary *fallback=nullptr) | |
baseIOdictionary (const IOobject &io, const dictionary &dict) | |
baseIOdictionary (const IOobject &io, Istream &is) | |
const word & | name () const |
virtual bool | readData (Istream &) |
virtual bool | writeData (Ostream &) const |
void | operator= (const baseIOdictionary &rhs) |
void | operator= (const dictionary &rhs) |
![]() | |
ClassName ("dictionary") | |
dictionary () | |
dictionary (const fileName &name) | |
dictionary (const fileName &name, const dictionary &parentDict, Istream &is, bool keepHeader=false) | |
dictionary (Istream &is) | |
dictionary (Istream &is, bool keepHeader) | |
dictionary (const dictionary &parentDict, const dictionary &dict) | |
dictionary (const dictionary &dict) | |
dictionary (const dictionary *dict) | |
dictionary (const dictionary &parentDict, dictionary &&dict) | |
dictionary (dictionary &&dict) | |
autoPtr< dictionary > | clone () const |
virtual | ~dictionary () |
const fileName & | name () const noexcept |
fileName & | name () noexcept |
word | dictName () const |
fileName | relativeName (const bool caseTag=false) const |
bool | isNullDict () const noexcept |
const dictionary & | parent () const noexcept |
const dictionary & | topDict () const |
label | startLineNumber () const |
label | endLineNumber () const |
SHA1Digest | digest () const |
tokenList | tokens () const |
bool | found (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
entry * | findEntry (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) |
const entry * | findEntry (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
const entry * | findScoped (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
dictionary * | findDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) |
const dictionary * | findDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
const entry & | lookupEntry (const word &keyword, enum keyType::option matchOpt) const |
ITstream & | lookup (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T > | |
T | get (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T > | |
T | getOrDefault (const word &keyword, const T &deflt, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T > | |
T | getOrAdd (const word &keyword, const T &deflt, enum keyType::option matchOpt=keyType::REGEX) |
template<class T > | |
bool | readEntry (const word &keyword, T &val, enum keyType::option matchOpt=keyType::REGEX, bool mandatory=true) const |
template<class T > | |
bool | readIfPresent (const word &keyword, T &val, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T , class Predicate > | |
T | getCheck (const word &keyword, const Predicate &pred, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T , class Predicate > | |
T | getCheckOrDefault (const word &keyword, const T &deflt, const Predicate &pred, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T , class Predicate > | |
T | getCheckOrAdd (const word &keyword, const T &deflt, const Predicate &pred, enum keyType::option matchOpt=keyType::REGEX) |
template<class T , class Predicate > | |
bool | readCheck (const word &keyword, T &val, const Predicate &pred, enum keyType::option matchOpt=keyType::REGEX, bool mandatory=true) const |
template<class T , class Predicate > | |
bool | readCheckIfPresent (const word &keyword, T &val, const Predicate &pred, enum keyType::option matchOpt=keyType::REGEX) const |
bool | isDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
const dictionary & | subDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
dictionary & | subDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) |
dictionary & | subDictOrAdd (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) |
dictionary | subOrEmptyDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX, const bool mandatory=false) const |
const dictionary & | optionalSubDict (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
wordList | toc () const |
wordList | sortedToc () const |
template<class Compare > | |
wordList | sortedToc (const Compare &comp) const |
List< keyType > | keys (bool patterns=false) const |
bool | substituteKeyword (const word &keyword, bool mergeEntry=false) |
bool | substituteScopedKeyword (const word &keyword, bool mergeEntry=false) |
entry * | add (entry *entryPtr, bool mergeEntry=false) |
entry * | add (const entry &e, bool mergeEntry=false) |
entry * | add (const keyType &k, const word &v, bool overwrite=false) |
entry * | add (const keyType &k, const string &v, bool overwrite=false) |
entry * | add (const keyType &k, const label v, bool overwrite=false) |
entry * | add (const keyType &k, const scalar v, bool overwrite=false) |
entry * | add (const keyType &k, const dictionary &d, bool mergeEntry=false) |
template<class T > | |
entry * | add (const keyType &k, const T &v, bool overwrite=false) |
entry * | set (entry *entryPtr) |
entry * | set (const entry &e) |
entry * | set (const keyType &k, const dictionary &v) |
template<class T > | |
entry * | set (const keyType &k, const T &v) |
bool | remove (const word &keyword) |
bool | changeKeyword (const keyType &oldKeyword, const keyType &newKeyword, bool overwrite=false) |
bool | merge (const dictionary &dict) |
void | clear () |
void | transfer (dictionary &dict) |
void | checkITstream (const ITstream &is, const word &keyword) const |
bool | read (Istream &is) |
bool | read (Istream &is, bool keepHeader) |
void | writeEntry (Ostream &os) const |
void | writeEntry (const keyType &keyword, Ostream &os) const |
void | writeEntries (Ostream &os, const bool extraNewLine=false) const |
void | write (Ostream &os, const bool subDict=true) const |
const_searcher | csearch (const word &keyword, enum keyType::option=keyType::REGEX) const |
const_searcher | search (const word &keyword, enum keyType::option=keyType::REGEX) const |
searcher | search (const word &keyword, enum keyType::option=keyType::REGEX) |
const_searcher | csearchScoped (const word &keyword, enum keyType::option) const |
const_searcher | searchScoped (const word &keyword, enum keyType::option) const |
searcher | searchScoped (const word &keyword, enum keyType::option) |
const dictionary * | cfindScopedDict (const fileName &dictPath) const |
const dictionary * | findScopedDict (const fileName &dictPath) const |
dictionary * | findScopedDict (const fileName &dictPath) |
dictionary * | makeScopedDict (const fileName &dictPath) |
const_searcher | csearchCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option=keyType::REGEX) const |
bool | foundCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option=keyType::REGEX) const |
const entry * | findCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option) const |
const entry & | lookupEntryCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option) const |
ITstream & | lookupCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option=keyType::REGEX) const |
template<class T > | |
T | getCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, enum keyType::option=keyType::REGEX) const |
template<class T > | |
T | getOrDefaultCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, const T &deflt, enum keyType::option=keyType::REGEX) const |
template<class T > | |
bool | readCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, T &val, enum keyType::option=keyType::REGEX, bool mandatory=true) const |
template<class T > | |
bool | readIfPresentCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, T &val, enum keyType::option=keyType::REGEX) const |
void | operator= (const dictionary &rhs) |
void | operator+= (const dictionary &rhs) |
void | operator|= (const dictionary &rhs) |
void | operator<<= (const dictionary &rhs) |
template<class T > | |
T | lookupOrDefault (const word &keyword, const T &deflt, enum keyType::option matchOpt=keyType::REGEX) const |
template<class T > | |
T | lookupOrAddDefault (const word &keyword, const T &deflt, enum keyType::option matchOpt=keyType::REGEX) |
template<class T > | |
T | lookupOrDefaultCompat (const word &keyword, std::initializer_list< std::pair< const char *, int >> compat, const T &deflt, enum keyType::option matchOpt=keyType::REGEX) const |
ITstream & | operator[] (const word &keyword) const |
bool | found (const word &keyword, bool recursive, bool patternMatch=true) const |
entry * | lookupEntryPtr (const word &keyword, bool recursive, bool patternMatch) |
const entry * | lookupEntryPtr (const word &keyword, bool recursive, bool patternMatch) const |
const entry * | lookupScopedEntryPtr (const word &keyword, bool recursive, bool patternMatch) const |
const dictionary * | subDictPtr (const word &keyword) const |
dictionary * | subDictPtr (const word &keyword) |
const entry & | lookupEntry (const word &keyword, bool recursive, bool patternMatch) const |
ITstream & | lookup (const word &keyword, bool recursive, bool patternMatch=true) const |
template<class T > | |
T | lookupOrDefault (const word &keyword, const T &deflt, bool recursive, bool patternMatch=true) const |
template<class T > | |
T | lookupOrAddDefault (const word &keyword, const T &deflt, bool recursive, bool patternMatch=true) |
template<class T > | |
bool | readIfPresent (const word &keyword, T &val, bool recursive, bool patternMatch=true) const |
template<class T > | |
T | lookupType (const word &keyword, bool recursive=false, bool patternMatch=true) const |
bool | getBool (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< bool >(const word&, keyType::option) More... | |
label | getLabel (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< label >(const word&, keyType::option) More... | |
scalar | getScalar (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< scalar >(const word&, keyType::option) More... | |
string | getString (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< string >(const word&, keyType::option) More... | |
word | getWord (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< word >(const word&, keyType::option) More... | |
fileName | getFileName (const word &keyword, enum keyType::option matchOpt=keyType::REGEX) const |
Same as get< fileName >(const word&, keyType::option) More... | |
template<class Compare > | |
Foam::wordList | sortedToc (const Compare &comp) const |
template<class T > | |
Foam::entry * | add (const keyType &k, const T &v, bool overwrite) |
template<class T > | |
Foam::entry * | set (const keyType &k, const T &v) |
![]() | |
ILList ()=default | |
ILList (T *item) | |
ILList (Istream &is) | |
ILList (const ILList< LListBase, T > &lst) | |
ILList (ILList< LListBase, T > &&lst) | |
template<class CloneArg > | |
ILList (const ILList< LListBase, T > &lst, const CloneArg &cloneArg) | |
template<class INew > | |
ILList (Istream &is, const INew &inew) | |
~ILList () | |
bool | eraseHead () |
bool | erase (T *item) |
void | clear () |
void | transfer (ILList< LListBase, T > &lst) |
void | operator= (const ILList< LListBase, T > &lst) |
void | operator= (ILList< LListBase, T > &&lst) |
Additional Inherited Members | |
![]() | |
enum | objectState : char { GOOD, BAD } |
enum | readOption : char { MUST_READ, MUST_READ_IF_MODIFIED, READ_IF_PRESENT, NO_READ } |
enum | writeOption : char { AUTO_WRITE = 0, NO_WRITE = 1 } |
enum | fileCheckTypes : char { timeStamp, timeStampMaster, inotify, inotifyMaster } |
![]() | |
typedef Searcher< true > | const_searcher |
typedef Searcher< false > | searcher |
![]() | |
static autoPtr< adjointRASModel > | New (incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName=adjointTurbulenceModel::typeName) |
![]() | |
static autoPtr< adjointTurbulenceModel > | New (incompressibleVars &primalVars, incompressibleAdjointMeanFlowVars &adjointVars, objectiveManager &objManager, const word &adjointTurbulenceModelName=typeName) |
![]() | |
template<class Type > | |
static Type & | store (Type *p) |
template<class Type > | |
static Type & | store (autoPtr< Type > &ptr) |
template<class Type > | |
static Type & | store (autoPtr< Type > &&ptr) |
template<class Type > | |
static Type & | store (refPtr< Type > &ptr) |
template<class Type > | |
static Type & | store (refPtr< Type > &&ptr) |
template<class Type > | |
static Type & | store (tmp< Type > &ptr) |
template<class Type > | |
static Type & | store (tmp< Type > &&ptr) |
![]() | |
static bool | bannerEnabled () noexcept |
static bool | bannerEnabled (bool on) noexcept |
static bool | fileNameComponents (const fileName &path, fileName &instance, fileName &local, word &name) |
template<class StringType > | |
static word | groupName (StringType base, const word &group) |
static word | group (const word &name) |
static word | member (const word &name) |
static word | scopedName (const std::string &scope, const word &name) |
static IOobject | selectIO (const IOobject &io, const fileName &altFile, const word &ioName="") |
static Ostream & | writeBanner (Ostream &os, const bool noSyntaxHint=false) |
static Ostream & | writeDivider (Ostream &os) |
static Ostream & | writeEndDivider (Ostream &os) |
![]() | |
static int | reportOptional () noexcept |
static int | reportOptional (const int level) noexcept |
static autoPtr< dictionary > | New (Istream &is) |
![]() | |
friend | const_searcher |
friend | searcher |
![]() | |
static const Enum< fileCheckTypes > | fileCheckTypesNames |
static char | scopeSeparator |
static fileCheckTypes | fileModificationChecking |
static float | fileModificationSkew |
static int | maxFileModificationPolls |
![]() | |
static int | writeOptionalEntries |
static const dictionary | null |
static refPtr< OSstream > | reportingOutput |
![]() | |
static void | writeHeaderContent (Ostream &os, const IOobject &io, const word &objectType, const dictionary *metaDataDict=nullptr) |
static void | writeHeaderContent (dictionary &dict, const IOobject &io, const word &objectType, IOstreamOption streamOpt, const dictionary *metaDataDict=nullptr) |
![]() | |
static bool | masterOnlyReading = false |
Continuous adjoint to the Spalart-Allmaras one-eqn mixing-length model for incompressible flows.
For the adjoint to the Spalart-Allmaras PDE Zymaris, A., Papadimitriou, D., Giannakoglou, K., & Othmer, C. (2009). Continuous adjoint approach to the Spalart-Allmaras turbulence model for incompressible flows. Computers & Fluids, 38(8), 1528-538. http://doi.org/10.1016/j.compfluid.2008.12.006 For the FI sensitivity terms Papoutsis-Kiachagias, E. M., Asouti, V. G., Giannakoglou, K. C., Gkagkas, K., Shimokawa, S., & Itakura, E. (2018). Multi-point aerodynamic shape optimization of cars based on continuous adjoint. Structural and Multidisciplinary Optimization, 59(2), 675-694. http://doi.org/10.1007/s00158-018-2091-3
Both of the above-mentioned papers develop the adjoint to the Spalart-Allmaras PDE that includes the fv3 term. The current implementation corresponds to the Spalart-Allmaras PDE as programmed within OpenFOAM and is, thus, slightly different than the one developed in the cited papers
Definition at line 83 of file adjointSpalartAllmaras.H.
adjointSpalartAllmaras | ( | incompressibleVars & | primalVars, |
incompressibleAdjointMeanFlowVars & | adjointVars, | ||
objectiveManager & | objManager, | ||
const word & | adjointTurbulenceModelName = adjointTurbulenceModel::typeName , |
||
const word & | modelName = typeName |
||
) |
Definition at line 468 of file adjointSpalartAllmaras.C.
References variablesSet::setField(), variablesSet::solverName(), and variablesSet::useSolverNameForFields().
|
virtualdefault |
|
protected |
Definition at line 56 of file adjointSpalartAllmaras.C.
References adjointTurbulenceModel::nu(), and adjointSpalartAllmaras::nuTilda().
Referenced by adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), adjointSpalartAllmaras::fv1(), adjointSpalartAllmaras::nutJacobianTMVar1(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 62 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::Cv1_, and Foam::pow3().
Referenced by adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), adjointSpalartAllmaras::nutJacobianTMVar1(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 70 of file adjointSpalartAllmaras.C.
Referenced by adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 80 of file adjointSpalartAllmaras.C.
References Foam::mag(), Foam::max(), Foam::skew(), Foam::sqr(), and Foam::sqrt().
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 100 of file adjointSpalartAllmaras.C.
References Foam::max(), Foam::min(), Foam::sqr(), Foam::tr(), and Foam::Zero.
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 122 of file adjointSpalartAllmaras.C.
References g, Foam::pow(), and Foam::pow6().
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 132 of file adjointSpalartAllmaras.C.
References adjointTurbulenceModel::nu(), adjointSpalartAllmaras::nuTilda(), and adjointSpalartAllmaras::sigmaNut_.
Referenced by adjointSpalartAllmaras::correct(), and adjointSpalartAllmaras::FISensitivityTerm().
|
protected |
Definition at line 141 of file adjointSpalartAllmaras.C.
References adjointTurbulenceModel::primalVars_, and incompressibleVars::RASModelVariables().
Referenced by adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::diffusionCoeffVar1(), adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::DnuTildaEff(), adjointSpalartAllmaras::FISensitivityTerm(), adjointSpalartAllmaras::updatePrimalRelatedFields(), adjointSpalartAllmaras::wallFloCoSensitivities(), and adjointSpalartAllmaras::wallShapeSensitivities().
|
protectedvirtual |
Reimplemented from adjointTurbulenceModel.
Definition at line 147 of file adjointSpalartAllmaras.C.
References adjointTurbulenceModel::primalVars_, and incompressibleVars::RASModelVariables().
Referenced by adjointSpalartAllmaras::distanceSensitivities().
|
protected |
Definition at line 156 of file adjointSpalartAllmaras.C.
References Foam::pow3(), and Foam::sqr().
Referenced by adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::nutJacobianTMVar1(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 167 of file adjointSpalartAllmaras.C.
References Foam::sqr().
Referenced by adjointSpalartAllmaras::distanceSensitivities(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 178 of file adjointSpalartAllmaras.C.
References Foam::neg(), Foam::pos(), and Foam::sqr().
Referenced by adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 193 of file adjointSpalartAllmaras.C.
References nu, Foam::pos(), and Foam::sqr().
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 207 of file adjointSpalartAllmaras.C.
References Foam::pos(), and Foam::sqr().
Referenced by adjointSpalartAllmaras::distanceSensitivities().
|
protected |
Definition at line 220 of file adjointSpalartAllmaras.C.
References Foam::max(), tmp::ref(), Foam::sqr(), and Foam::Zero.
|
protected |
Definition at line 236 of file adjointSpalartAllmaras.C.
References Foam::max(), tmp::ref(), Foam::sqr(), and Foam::Zero.
|
protected |
Definition at line 252 of file adjointSpalartAllmaras.C.
References Foam::max(), tmp::ref(), Foam::sqr(), and Foam::Zero.
|
protected |
Definition at line 268 of file adjointSpalartAllmaras.C.
References g, Foam::pow(), Foam::pow5(), and Foam::pow6().
Referenced by adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 284 of file adjointSpalartAllmaras.C.
References Foam::sqr().
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 298 of file adjointSpalartAllmaras.C.
Referenced by adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 309 of file adjointSpalartAllmaras.C.
Referenced by adjointSpalartAllmaras::distanceSensitivities().
|
protected |
Definition at line 320 of file adjointSpalartAllmaras.C.
References Foam::sqr().
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 330 of file adjointSpalartAllmaras.C.
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 339 of file adjointSpalartAllmaras.C.
References nu.
Referenced by adjointSpalartAllmaras::nutJacobianTMVar1(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 348 of file adjointSpalartAllmaras.C.
References adjointRASModel::adjMomentumBCSourcePtr_, fvMesh::boundary(), GeometricField::boundaryField(), Foam::fvc::div(), forAll, adjointTurbulenceModel::mesh_, adjointSpalartAllmaras::momentumSourceMult_, adjointSpalartAllmaras::nuaTilda(), and Foam::foamVersion::patch.
Referenced by adjointSpalartAllmaras::adjointMeanFlowSource().
|
inlineprotected |
Definition at line 275 of file adjointSpalartAllmaras.H.
References adjointRASModel::adjointTMVariable1Ptr_.
Referenced by adjointSpalartAllmaras::adjointMeanFlowSource(), adjointSpalartAllmaras::conservativeMomentumSource(), adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), adjointSpalartAllmaras::nullify(), adjointSpalartAllmaras::wallFloCoSensitivities(), and adjointSpalartAllmaras::wallShapeSensitivities().
|
protected |
Definition at line 368 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::Cb1_, adjointSpalartAllmaras::Cdnut_, adjointRASModel::changedPrimalSolution_, adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::Cw1_, adjointSpalartAllmaras::dD_dNuTilda(), adjointSpalartAllmaras::dFv1_dChi(), adjointSpalartAllmaras::dFv2_dChi(), adjointSpalartAllmaras::dfw_dNuTilda(), adjointSpalartAllmaras::dfw_dOmega(), adjointSpalartAllmaras::dfw_dr(), adjointSpalartAllmaras::dnut_dNuTilda(), adjointSpalartAllmaras::dP_dNuTilda(), adjointSpalartAllmaras::dStilda_dNuTilda(), adjointSpalartAllmaras::dStilda_dOmega(), Foam::endl(), adjointSpalartAllmaras::fv1(), adjointSpalartAllmaras::fv2(), adjointSpalartAllmaras::fw(), adjointSpalartAllmaras::fw_, Foam::fvc::grad(), adjointSpalartAllmaras::gradNuTilda_, adjointSpalartAllmaras::gradU_, Foam::Info, Foam::mag(), adjointSpalartAllmaras::mask_, adjointSpalartAllmaras::momentumSourceMult_, adjointSpalartAllmaras::nuTilda(), adjointTurbulenceModel::primalVars_, adjointSpalartAllmaras::productionDestructionSource_, adjointSpalartAllmaras::r(), adjointSpalartAllmaras::r_, Foam::skew(), Foam::sqr(), Foam::sqrt(), adjointSpalartAllmaras::Stilda(), adjointSpalartAllmaras::Stilda_, Foam::symm(), adjointSpalartAllmaras::symmAdjointProductionU_, U, incompressibleVars::U(), and adjointSpalartAllmaras::y_.
Referenced by adjointSpalartAllmaras::correct().
|
protected |
Definition at line 434 of file adjointSpalartAllmaras.C.
References adjointRASModel::coeffDict_, ATCModel::createLimiter(), Foam::dimless, adjointSpalartAllmaras::limitAdjointProduction_, adjointTurbulenceModel::mesh_, IOobject::NO_READ, IOobject::NO_WRITE, fvMesh::time(), and Time::timeName().
TypeName | ( | "adjointSpalartAllmaras" | ) |
|
virtual |
Implements adjointRASModel.
Definition at line 696 of file adjointSpalartAllmaras.C.
References adjointTurbulenceModel::adjointVars_, and incompressibleAdjointMeanFlowVars::UaInst().
|
virtual |
Implements adjointRASModel.
Definition at line 704 of file adjointSpalartAllmaras.C.
References Foam::dev(), Foam::fvc::grad(), tmp::New(), IOobject::NO_READ, IOobject::NO_WRITE, Foam::twoSymm(), and U.
|
virtual |
Implements adjointRASModel.
Definition at line 724 of file adjointSpalartAllmaras.C.
References Foam::dev(), Foam::fvc::div(), Foam::fvc::grad(), Foam::fvm::laplacian(), adjointTurbulenceModel::nuEff(), and Foam::T().
|
virtual |
Implements adjointRASModel.
Definition at line 737 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::conservativeMomentumSource(), adjointSpalartAllmaras::gradNuTilda_, and adjointSpalartAllmaras::nuaTilda().
|
virtual |
Reimplemented from adjointRASModel.
Definition at line 747 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::dFv1_dChi(), adjointSpalartAllmaras::dnut_dNuTilda(), and adjointSpalartAllmaras::fv1().
|
virtual |
Reimplemented from adjointRASModel.
Definition at line 757 of file adjointSpalartAllmaras.C.
References fvMesh::boundary(), GeometricField::boundaryField(), adjointTurbulenceModel::mesh_, adjointTurbulenceModel::nu(), adjointSpalartAllmaras::nuTilda(), tmp::ref(), adjointSpalartAllmaras::sigmaNut_, dimensioned::value(), and Foam::Zero.
Referenced by adjointSpalartAllmaras::wallShapeSensitivities().
|
virtual |
Implements adjointRASModel.
Definition at line 775 of file adjointSpalartAllmaras.C.
References adjointRASModel::adjMomentumBCSourcePtr_.
|
virtual |
Implements adjointRASModel.
Definition at line 782 of file adjointSpalartAllmaras.C.
References fvMesh::boundary(), GeometricField::boundaryField(), adjointSpalartAllmaras::diffusionCoeffVar1(), forAll, adjointTurbulenceModel::mesh_, adjointSpalartAllmaras::nuaTilda(), adjointSpalartAllmaras::nuTilda(), Foam::foamVersion::patch, and adjointRASModel::wallShapeSensitivitiesPtr_.
|
virtual |
Implements adjointRASModel.
Definition at line 805 of file adjointSpalartAllmaras.C.
References fvMesh::boundary(), GeometricField::boundaryField(), forAll, adjointTurbulenceModel::mesh_, adjointSpalartAllmaras::nuaTilda(), adjointSpalartAllmaras::nuTilda(), and adjointRASModel::wallFloCoSensitivitiesPtr_.
|
virtual |
Implements adjointRASModel.
Definition at line 823 of file adjointSpalartAllmaras.C.
References objectiveManager::adjointSolverName(), adjointTurbulenceModel::adjointVars_, fvMesh::boundary(), GeometricField::boundaryField(), adjointSpalartAllmaras::Cb1_, adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::Cw1_, adjointSpalartAllmaras::dFv1_dChi(), adjointSpalartAllmaras::dFv2_dChi(), adjointSpalartAllmaras::dfw_dDelta(), adjointSpalartAllmaras::dfw_dr(), adjointSpalartAllmaras::dStilda_dDelta(), Foam::exp(), forAll, adjointSpalartAllmaras::fv1(), adjointSpalartAllmaras::fv2(), adjointSpalartAllmaras::fw_, adjointSpalartAllmaras::gradU_, adjointSpalartAllmaras::kappa_, Foam::mag(), adjointTurbulenceModel::mesh_, Foam::min(), boundaryAdjointContribution::New(), adjointTurbulenceModel::nu(), adjointSpalartAllmaras::nuaTilda(), adjointTurbulenceModel::nuEff(), adjointSpalartAllmaras::nut(), adjointSpalartAllmaras::nuTilda(), adjointRASModel::objectiveManager_, Foam::foamVersion::patch, fvPatchField::patchInternalField(), adjointTurbulenceModel::primalVars_, tmp::ref(), fvPatchField::snGrad(), Foam::sqr(), Foam::sqrt(), adjointSpalartAllmaras::Stilda_, Foam::type(), U, incompressibleVars::U(), incompressibleAdjointMeanFlowVars::Ua(), uPlus, fvMesh::V(), adjointRASModel::y(), adjointSpalartAllmaras::y_, and yPlus.
|
virtual |
Implements adjointRASModel.
Definition at line 942 of file adjointSpalartAllmaras.C.
References fvMesh::boundary(), GeometricField::boundaryField(), GeometricField::boundaryFieldRef(), adjointSpalartAllmaras::Cb1_, adjointSpalartAllmaras::Cb2_, adjointSpalartAllmaras::chi(), adjointSpalartAllmaras::Cw1_, adjointSpalartAllmaras::dfw_dOmega(), adjointSpalartAllmaras::dfw_dr(), adjointSpalartAllmaras::DnuTildaEff(), adjointSpalartAllmaras::dStilda_dOmega(), forAll, adjointSpalartAllmaras::fv1(), adjointSpalartAllmaras::fv2(), Foam::fvc::grad(), Foam::mag(), adjointTurbulenceModel::mesh_, adjointSpalartAllmaras::nuaTilda(), adjointSpalartAllmaras::nuTilda(), Foam::foamVersion::patch, adjointTurbulenceModel::primalVars_, adjointSpalartAllmaras::sigmaNut_, Foam::skew(), Foam::sqr(), Foam::sqrt(), adjointSpalartAllmaras::Stilda_, Foam::T(), U, incompressibleVars::U(), and adjointSpalartAllmaras::y_.
|
virtual |
Implements adjointRASModel.
Definition at line 1017 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::nuaTilda(), and variablesSet::nullifyField().
|
virtual |
Reimplemented from adjointRASModel.
Definition at line 1023 of file adjointSpalartAllmaras.C.
References objectiveManager::addTMEqn1Source(), adjointRASModel::adjointTurbulence_, adjointTurbulenceModel::adjointVars_, adjointSpalartAllmaras::Cb1_, adjointSpalartAllmaras::Cb2_, adjointSpalartAllmaras::Cdnut_, adjointTurbulenceModel::correct(), GeometricField::correctBoundaryConditions(), adjointSpalartAllmaras::Cw1_, Foam::fvm::ddt(), Foam::fvm::div(), adjointSpalartAllmaras::DnuTildaEff(), Foam::endl(), adjointSpalartAllmaras::fw_, incompressibleAdjointMeanFlowVars::getSolverControl(), Foam::gMax(), Foam::fvc::grad(), adjointSpalartAllmaras::gradNuTilda_, Foam::Info, Foam::fvc::laplacian(), Foam::fvm::laplacian(), Foam::mag(), Foam::max(), adjointSpalartAllmaras::nuaTilda(), adjointSpalartAllmaras::nuTilda(), adjointRASModel::objectiveManager_, phi, incompressibleVars::phi(), adjointTurbulenceModel::primalVars_, solverControl::printMaxMags(), adjointSpalartAllmaras::productionDestructionSource_, tmp::ref(), GeometricField::relax(), adjointSpalartAllmaras::sigmaNut_, Foam::solve(), Foam::fvm::Sp(), Foam::sqr(), adjointSpalartAllmaras::Stilda_, GeometricField::storePrevIter(), Foam::fvm::SuSp(), adjointSpalartAllmaras::symmAdjointProductionU_, incompressibleAdjointMeanFlowVars::UaInst(), adjointSpalartAllmaras::updatePrimalRelatedFields(), dimensioned::value(), and adjointSpalartAllmaras::y_.
|
virtual |
Reimplemented from adjointRASModel.
Definition at line 1083 of file adjointSpalartAllmaras.C.
References adjointSpalartAllmaras::Cb1_, adjointSpalartAllmaras::Cb2_, adjointRASModel::coeffDict(), adjointSpalartAllmaras::Cs_, adjointSpalartAllmaras::Cv1_, adjointSpalartAllmaras::Cw1_, adjointSpalartAllmaras::Cw2_, adjointSpalartAllmaras::Cw3_, adjointSpalartAllmaras::kappa_, adjointRASModel::read(), dimensioned::readIfPresent(), adjointSpalartAllmaras::sigmaNut_, and Foam::sqr().
|
protected |
Definition at line 102 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::diffusionCoeffVar1(), adjointSpalartAllmaras::DnuTildaEff(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::read().
|
protected |
Definition at line 103 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::distanceSensitivities(), and adjointSpalartAllmaras::read().
|
protected |
|
protected |
Definition at line 106 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::read().
|
protected |
|
protected |
Definition at line 108 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::read().
|
protected |
Definition at line 109 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::read().
|
protected |
Definition at line 110 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::fv1(), and adjointSpalartAllmaras::read().
|
protected |
Definition at line 111 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::read().
|
protected |
Definition at line 115 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::allocateMask().
|
protected |
Definition at line 122 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 125 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 130 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 131 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 132 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::distanceSensitivities(), adjointSpalartAllmaras::FISensitivityTerm(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 133 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 134 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), adjointSpalartAllmaras::distanceSensitivities(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 135 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::correct(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 136 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::conservativeMomentumSource(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 137 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::distanceSensitivities(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 138 of file adjointSpalartAllmaras.H.
Referenced by adjointSpalartAllmaras::adjointMeanFlowSource(), adjointSpalartAllmaras::correct(), and adjointSpalartAllmaras::updatePrimalRelatedFields().
|
protected |
Definition at line 141 of file adjointSpalartAllmaras.H.
Copyright © 2011-2018 OpenFOAM | OPENFOAM® is a registered trademark of OpenCFD Ltd.