#ifndef __powerpc__ #include #include #include static std::complex t1 ( 0.368017112855051e-1, 0.510878114959572e-1); static std::complex r1 ( 0.447050716285388e2, 0.656876847463481e2); static std::complex t2 ( 0.337315741065416, 0.335449415919309); static std::complex r20 (-0.725974574329220e2, -0.781008427112870e2); static std::complex r21 (-0.557107698030123e-4, 0.464578634580806e-4); static std::complex r22 ( 0.234801409215913e-10,-0.285651142904972e-10); #endif #include "Ice.h" static double T_t = 273.16, ///< Triple point temperature in K p_t = 611.657, ///< Triple point pressure in Pa p_0 = 101325; ///< Ambient pressure in Pa // Complex Constants for EOS static double g00=-0.632020233449497e6; static double g01= 0.655022213658955; static double g02=-0.189369929326131e-7; static double g03= 0.339746123271053e-14; static double g04=-0.556464869058991e-21; static double s0= -0.332733756492168e4; double IsothermCompress_Ice(double T, double p) { #ifndef __powerpc__ // Inputs in K, Pa, Output in 1/Pa return -dg2_dp2_Ice(T,p)/dg_dp_Ice(T,p); #else return 1e99; #endif } double psub_Ice(double T) { #ifndef __powerpc__ double a[]={0,-0.212144006e2,0.273203819e2,-0.610598130e1}; double b[]={0,0.333333333e-2,0.120666667e1,0.170333333e1}; double summer=0,theta; theta=T/T_t; for (int i=1;i<=3;i++) { summer+=a[i]*pow(theta,b[i]); } return p_t*exp(1/theta*summer); #else return 1e99; #endif } double g_Ice(double T,double p) { #ifndef __powerpc__ std::complex r2,term1,term2; double g0,theta,pi,pi_0; theta= T/T_t; pi=p/p_t; pi_0=p_0/p_t; g0=g00*pow(pi-pi_0,0.0)+g01*pow(pi-pi_0,1.0)+g02*pow(pi-pi_0,2.0)+g03*pow(pi-pi_0,3.0)+g04*pow(pi-pi_0,4.0); r2=r20*pow(pi-pi_0,0.0)+r21*pow(pi-pi_0,1.0)+r22*pow(pi-pi_0,2.0); // The two terms of the summation term1=r1*((t1-theta)*log(t1-theta)+(t1+theta)*log(t1+theta)-2.0*t1*log(t1)-theta*theta/t1); term2=r2*((t2-theta)*log(t2-theta)+(t2+theta)*log(t2+theta)-2.0*t2*log(t2)-theta*theta/t2); return g0-s0*T_t*theta+T_t*real(term1+term2); #else return 1e99; #endif } double dg_dp_Ice(double T, double p) { #ifndef __powerpc__ std::complex r2_p; double g0_p,theta,pi,pi_0; theta= T/T_t; pi=p/p_t; pi_0=p_0/p_t; g0_p=g01*1.0/p_t*pow(pi-pi_0,1-1.0)+g02*2.0/p_t*pow(pi-pi_0,2-1.0)+g03*3.0/p_t*pow(pi-pi_0,3-1.0)+g04*4.0/p_t*pow(pi-pi_0,4-1.0); r2_p=r21*1.0/p_t*pow(pi-pi_0,1-1.0)+r22*2.0/p_t*pow(pi-pi_0,2-1.0); return g0_p+T_t*real(r2_p*((t2-theta)*log(t2-theta)+(t2+theta)*log(t2+theta)-2.0*t2*log(t2)-theta*theta/t2)); #else return 1e99; #endif } double dg2_dp2_Ice(double T, double p) { #ifndef __powerpc__ std::complex r2_pp; double g0_pp,theta,pi,pi_0; theta= T/T_t; pi=p/p_t; pi_0=p_0/p_t; g0_pp=g02*2.0*(2.0-1.0)/p_t/p_t*pow(pi-pi_0,2.0-2.0)+g03*3.0*(3.0-1.0)/p_t/p_t*pow(pi-pi_0,3.0-2.0)+g04*4.0*(4.0-1.0)/p_t/p_t*pow(pi-pi_0,4-2.0); r2_pp=r22*2.0/p_t/p_t; return g0_pp+T_t*real(r2_pp*((t2-theta)*log(t2-theta)+(t2+theta)*log(t2+theta)-2.0*t2*log(t2)-theta*theta/t2)); #else return 1e99; #endif } double dg_dT_Ice(double T, double p) { #ifndef __powerpc__ std::complex r2,term1,term2; double theta,pi,pi_0; theta= T/T_t; pi=p/p_t; pi_0=p_0/p_t; r2=r20*pow(pi-pi_0,0.0)+r21*pow(pi-pi_0,1.0)+r22*pow(pi-pi_0,2.0); // The two terms of the summation term1=r1*(-log(t1-theta)+log(t1+theta)-2.0*theta/t1); term2=r2*(-log(t2-theta)+log(t2+theta)-2.0*theta/t2); return -s0+real(term1+term2); #else return 1e99; #endif } double h_Ice(double T, double p) { #ifndef __powerpc__ // Returned value is in units of J/kg return g_Ice(T,p)-T*dg_dT_Ice(T,p); #else return 1e99; #endif } double rho_Ice(double T, double p) { #ifndef __powerpc__ // Returned value is in units of kg/m3 return 1/g_Ice(T,p); #else return 1e99; #endif } double s_Ice(double T, double p) { #ifndef __powerpc__ // Returned value is in units of J/kg/K return -dg_dT_Ice(T,p); #else return 1e99; #endif }