6 double RedlichKwong::up()
8 return -Pp()/Rho + hresid() + m_energy_offset;
11 double RedlichKwong::hresid()
13 double hh = m_b * (Rho/m_mw);
14 double hresid_mol_RT = z() - 1.0
15 - (1.5*m_a/(m_b*8314.3*T*sqrt(T)))*log(1.0 + hh);
16 return 8314.3*T*hresid_mol_RT/m_mw;
19 double RedlichKwong::sresid()
21 double hh = m_b * (Rho/m_mw);
22 double sresid_mol_R = log(z()*(1.0 - hh))
23 - (0.5*m_a/(m_b*8314.3*T*sqrt(T)))*log(1.0 + hh);
24 return 8314.3*sresid_mol_R/m_mw;
27 double RedlichKwong::sp()
29 const double Pref = 101325.0;
30 double rgas = 8314.3/m_mw;
34 return rgas*(log(Pref/p)) + sr + m_entropy_offset;
37 double RedlichKwong::z()
39 return Pp()*m_mw/(Rho*8314.3*T);
42 double RedlichKwong::Pp()
46 return R*T/(V - m_b) - m_a/(sqrt(T)*V*(V+m_b));
49 double RedlichKwong::Psat()
51 double tt = m_tcrit/T;
52 double lpr = -0.8734*tt*tt - 3.4522*tt + 4.2918;
53 return m_pcrit*exp(lpr);
56 double RedlichKwong::ldens()
64 for (i = 0; i < 50; i++) {
65 c = m_b*m_b + m_b*GasConstant*T/pp - m_a/(pp*sqt);
66 vnew = (1.0/c)*(v*v*v - GasConstant*T*v*v/pp - m_a*m_b/(pp*sqt));