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 "hPolynomialThermo.H"
00027 #include <OpenFOAM/IOstreams.H>
00028
00029
00030
00031 template<class EquationOfState, int PolySize>
00032 Foam::hPolynomialThermo<EquationOfState, PolySize>::hPolynomialThermo
00033 (
00034 Istream& is
00035 )
00036 :
00037 EquationOfState(is),
00038 Hf_(readScalar(is)),
00039 Sf_(readScalar(is)),
00040 CpPolynomial_("CpPolynomial", is),
00041 hPolynomial_(),
00042 sPolynomial_()
00043 {
00044 Hf_ *= this->W();
00045 Sf_ *= this->W();
00046 CpPolynomial_ *= this->W();
00047
00048 hPolynomial_ = CpPolynomial_.integrate();
00049 sPolynomial_ = CpPolynomial_.integrateMinus1();
00050
00051
00052 hPolynomial_[0] += Hf_ - hPolynomial_.evaluate(specie::Tstd);
00053
00054
00055 sPolynomial_[0] += Sf_ - sPolynomial_.evaluate(specie::Tstd);
00056 }
00057
00058
00059
00060
00061 template<class EquationOfState, int PolySize>
00062 Foam::Ostream& Foam::operator<<
00063 (
00064 Ostream& os,
00065 const hPolynomialThermo<EquationOfState, PolySize>& pt
00066 )
00067 {
00068 os << static_cast<const EquationOfState&>(pt) << tab
00069 << pt.Hf_/pt.W() << tab
00070 << pt.Sf_ << tab
00071 << "CpPolynomial" << tab << pt.CpPolynomial_/pt.W();
00072
00073 os.check
00074 (
00075 "operator<<"
00076 "("
00077 "Ostream&, "
00078 "const hPolynomialThermo<EquationOfState, PolySize>&"
00079 ")"
00080 );
00081
00082 return os;
00083 }
00084
00085
00086