#ifndef __powerpc__
#include <math.h>
#include <complex>
#include <iostream>
static std::complex <double> t1 ( 0.368017112855051e-1, 0.510878114959572e-1);
static std::complex <double> r1 ( 0.447050716285388e2, 0.656876847463481e2);
static std::complex <double> t2 ( 0.337315741065416, 0.335449415919309);
static std::complex <double> r20 (-0.725974574329220e2, -0.781008427112870e2);
static std::complex <double> r21 (-0.557107698030123e-4, 0.464578634580806e-4);
static std::complex <double> 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<double> 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<double> 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<double> 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<double> 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
}