Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #include "doubleSigmoid.H"
00027 #include <OpenFOAM/addToRunTimeSelectionTable.H>
00028
00029
00030
00031 namespace Foam
00032 {
00033 namespace energyScalingFunctions
00034 {
00035
00036
00037
00038 defineTypeNameAndDebug(doubleSigmoid, 0);
00039
00040 addToRunTimeSelectionTable
00041 (
00042 energyScalingFunction,
00043 doubleSigmoid,
00044 dictionary
00045 );
00046
00047
00048
00049 scalar doubleSigmoid::sigmoidScale
00050 (
00051 const scalar r,
00052 const scalar shift,
00053 const scalar scale
00054 ) const
00055 {
00056 return 1.0 / (1.0 + exp( scale * (r - shift)));
00057 }
00058
00059
00060
00061
00062 doubleSigmoid::doubleSigmoid
00063 (
00064 const word& name,
00065 const dictionary& energyScalingFunctionProperties,
00066 const pairPotential& pairPot
00067 )
00068 :
00069 energyScalingFunction(name, energyScalingFunctionProperties, pairPot),
00070 doubleSigmoidCoeffs_
00071 (
00072 energyScalingFunctionProperties.subDict(typeName + "Coeffs")
00073 ),
00074 shift1_(readScalar(doubleSigmoidCoeffs_.lookup("shift1"))),
00075 scale1_(readScalar(doubleSigmoidCoeffs_.lookup("scale1"))),
00076 shift2_(readScalar(doubleSigmoidCoeffs_.lookup("shift2"))),
00077 scale2_(readScalar(doubleSigmoidCoeffs_.lookup("scale2")))
00078 {}
00079
00080
00081
00082
00083 void doubleSigmoid::scaleEnergy(scalar& e, const scalar r) const
00084 {
00085 e *= sigmoidScale(r, shift1_, scale1_) * sigmoidScale(r, shift2_, scale2_);
00086 }
00087
00088
00089 bool doubleSigmoid::read(const dictionary& energyScalingFunctionProperties)
00090 {
00091 energyScalingFunction::read(energyScalingFunctionProperties);
00092
00093 doubleSigmoidCoeffs_ =
00094 energyScalingFunctionProperties.subDict(typeName + "Coeffs");
00095
00096 doubleSigmoidCoeffs_.lookup("shift1") >> shift1_;
00097 doubleSigmoidCoeffs_.lookup("scale1") >> scale1_;
00098 doubleSigmoidCoeffs_.lookup("shift2") >> shift2_;
00099 doubleSigmoidCoeffs_.lookup("scale2") >> scale2_;
00100
00101 return true;
00102 }
00103
00104
00105
00106
00107 }
00108 }
00109
00110