#include<iostream>
#include<math.h>
#define pi 3.1415926535897939
using namespace std;
float psat(float Tsat)
{
    float psat;
    psat=exp(21.51297-2200.9809/(Tsat+246.61));
    return (psat);
}
float Tsat(float psat)
{
    float Tsat;
    Tsat=-2200.9809/(log(psat)-21.51297)-246.61;
    return (Tsat);
}
float v(float tsh,float Tsat)
{
    float v,vs;
    vs=exp(-12.4539+2669.0/(Tsat+273.15))*(1.01357+10.6736*pow(10,-4)*Tsat-9.2532*pow(10,-6)*pow(Tsat,2)-3.2192*pow(10,-7)*pow(Tsat,3));
    v=(1+4.7881*pow(10,-3)*tsh-3.965*pow(10,-6)*pow(tsh,2)+2.5817*pow(10,-5)*tsh*Tsat-1.8506*pow(10,-7)*pow(tsh,2)*Tsat
        +8.5739*pow(10,-7)*tsh*pow(Tsat,2)-5.401*pow(10,-9)*pow(tsh,2)*pow(Tsat,2))*vs;
   return(v);
}
float ug(float Tg)
{
    float ug;
    ug=pow(10,-7)*(-5.083+0.50162*(Tg+273.15)-1.18e-4*pow(Tg+273.15,2));
    return(ug);
}
float uf(float Tf)
{
    float uf;
    uf=pow(10,-3)*pow(10,-14.4406+1256.3/(Tf+273.15)+0.052393*(Tf+273.15)-6.9771*pow(10,-5)*pow((Tf+273.15),2));
    return(uf);
}
float utp(float uf,float ug,float x)
{
    float utp;
    utp=uf*ug/(x*uf+(1-x)*ug);
    return(utp);
}
float g(float t)
{
    float g,T,j;
    T=t+273.15;
    j=-pow(1-T/380,0.31372);
    g=0.49834*pow(0.24141,j)*1000;
    return(g);
}
float vs(float Tsat)
{
    float vs(Tsat);
    vs=exp(-12.4539+2669.0/(Tsat+273.15))*(1.01357+10.6736*pow(10,-4)*Tsat-9.2532*pow(10,-6)*pow(Tsat,2)-3.2192*pow(10,-7)*pow(Tsat,3));
    return(vs);
}
float hf(float T1)
{
    float hf;
    hf=200000+1335.29*T1+1.70650*pow(T1,2)+7.6741*pow(10,-3)*pow(T1,3);
    return(hf);
}
float T(float h)
{
    float t,h1,t1,t2;
    for(t1=60,t2=-60,t=(t1+t2)/2,h1=200000+1335.29*t+1.70650*pow(t,2)+7.6741*pow(10,-3)*pow(t,3);
    fabs(h-h1)>0.01;
    t=(t1+t2)/2,h1=200000+1335.29*t+1.70650*pow(t,2)+7.6741*pow(10,-3)*pow(t,3))
    {  if(h1>h)
          t1=t;
        else
            t2=t;}
    return(t);
}
float hv(float Tsat)
{
    float hv,hi1;
    hi1=249455+606.163*Tsat-1.05644*pow(Tsat,2)-18.2426*pow(10,-3)*pow(Tsat,3);
    hv=hi1+149048;
    return(hv);
}
float hs(float Tsat,float tsh)
{
    float hs,hi1,hi2;
    hi1=249455+606.163*Tsat-1.05644*pow(Tsat,2)-18.2426*pow(10,-3)*pow(Tsat,3);
    hi2=(1+3.48186*pow(10,-3)*tsh+16.886*pow(10,-7)*pow(tsh,2)+9.2642*pow(10,-6)*tsh*Tsat-7.698*pow(10,-8)*pow(tsh,2)*Tsat
        +17.07*pow(10,-8)*tsh*pow(Tsat,2)-12.13*pow(10,-10)*pow(tsh,2)*pow(Tsat,2))*hi1;
    hs=hi2+149048;
    return(hs);
}
float Tsh(float h,float Tsat)
{
    float t,h1,t1,t2;
    for(t1=0,t2=40,t=(t1+t2)/2,h1=hs(t,Tsat);
    fabs(h-h1)>0.01;
    t=(t1+t2)/2,h1=hs(t,Tsat))
    {
      if(h1>h)
          t2=t;
      else
          t1=t;
    }
    return(t);
}
float cpf(float Tf)
{
    float cpf;
    cpf=pow(10,3)*(-14.015+1.4306*(Tf+273.15)-0.006022*pow((Tf+273.15),2)+9.9834*pow(10,-6)*pow((Tf+273.15),3))/86.5;//为什么要除以86.5
    return(cpf);
}
float cpg(float Tg)
{
    float cpg;
    cpg=pow(10,3)*(8.429+0.34966*(Tg+273.15)-3.3281*pow(10,-4)*pow((Tg+273.15),2)+1.5603*pow(10,-7)*pow((Tg+273.15),3)-2.8939*pow(10,-11)*pow((Tg+273.15),4))/86.5;
    return(cpg);
}
float rg(float Tg)
{
    float rg;
    rg=-0.00668+4.8544*pow(10,-5)*(Tg+273.15)+1.2108*pow(10,-8)*pow(Tg+273.15,2);
    return(rg);
}
float rf(float Tf)
{
    float rf;
    rf=pow(10,(-1.7425+0.9769*pow(1-(Tf+273.15)/380,2.0/7.0)));
    return (rf);
}
float d(float Tg,float Tw)
{
    float d,a,b,c,tg,tw;
    tg=Tg+273.15;
    tw=Tw+273.15;
    a=166.31*pow(647.3-tw,0.38);
    b=1e5*exp(3816.44/(tw-46.13)-23.1964)-1;
    c=267.38*pow(647.3-tw,0.38)+1.88*(tg-tw);
    d=(a*1.0/b-1.01*(tg-tw))/c;
    return(d);
}
float cpma(float Tg,float Tw)
{
    float cpma,cpda,cpv,da;
        cpda=1.00687*pow(10,3)-8.722*pow(10,-2)*Tg+1.236*pow(10,-4)*pow(Tg,2);
        cpv=1.85314*pow(10,3)+0.6133*Tg+1.014*pow(10,-3)*pow(Tg,2);
        da=d(Tg,Tw);
        cpma=(cpda/(1+da))*(1+da*cpv/cpda);
        return(cpma);
}
float Re(float G,float d,float u)
{
    float Re;
    Re=G*d/u;
    return (Re);
}
float ha(float Tg,float Tw)
{
    float ha,da,w;
    w=pow(10,5)*exp(3816.44/(Tw+273.15-46.13)-23.1964)-1;
    da=d(Tg,Tw);
    ha=(1.01*Tg+0.001*(da*1000)*(2501+1.85*Tg))*1000;
    return(ha);
}
float ra(float Tg,float Tw)
{
    float ra,uda,uv,rda,rv,w,d;
    w=pow(10,5)*exp(3816.44/(Tw+273.15-46.13)-23.1964)-1;
    d=(166.31*pow((647.3-Tw-273.15),0.38)*1.0/w-1.01*(Tg-Tw))*1.0/(267.38*pow((647.3-Tw-273.15),0.38)+1.88*(Tg-Tw));
    uda=(17.4945+4.779e-2*Tg-3.526e-5*pow(Tg,2))*pow(10,-6);
    uv=(8.1804+4.011e-2*Tg-1.7858e-5*pow(Tg,2))*pow(10,-6);
    rda=(2.4587+7.5855e-3*Tg-1.69e-6*pow(Tg,2))*pow(10,-2);
    rv=(1.6+6.179e-3*Tg+2.7535e-5*pow(Tg,2))*pow(10,-2);
    ra=(rda*4.56724/pow((1+0.881*pow((uda/uv),0.5)),2))*(1/(1+1.60746*d)+(rv/rda)/(1+(uv/uda)*(1/d)));
    return(ra);
}
float ua(float Tg,float Tw)
{
    float ua,uda,uv,d,w;
    uda=(17.4945+4.779e-2*Tg-3.526e-5*pow(Tg,2))*pow(10,-6);
    uv=(8.1804+4.011e-2*Tg-1.7858e-5*pow(Tg,2))*pow(10,-6);
    w=pow(10,5)*exp(3816.44/(Tw+273.15-46.13)-23.1964)-1;
    d=(166.31*pow((647.3-Tw-273.15),0.38)*1.0/w-1.01*(Tg-Tw))*1.0/(267.38*pow((647.3-Tw-273.15),0.38)+1.88*(Tg-Tw));
    ua=uda*(1+1.268*(uv/uda)*d)/(1+1.268*d);
    return(ua);
}
float a(float Tg,float Tw,float Ga,float gjv,float jv,float ch,float de,float Hp,float D,float W)
         
{
    float a,Rea,pr,r,cpa,u;    
        u=ua(Tg,Tw);
        Rea=Re(Ga,de,u);
        r=ra(Tg,Tw);
        cpa=cpma(Tg,Tw);
        pr=cpa*u/r; 
        a=0.1758*(r/de)*pow(Rea,0.505)*pow(pr,0.3333)*pow((W/de),0.485)*pow((D/de),1.9908)*pow((Hp/de),-0.5268);
        return(a);
}
float Tg(float d1,float tw)
{
    float t1,t2,t,da;
    for (t1=-15,t2=70,t=(t1+t2)/2,da=d(t,tw);
    fabs(da-d1)>0.0001;
    t=(t1+t2)/2,da=d(t,tw))
    {
        if(da>d1)
            t1=t;
        else
            t2=t;
    }
    return(t);
}
float ga(float tg,float tw)
{
    float a,ga,da,ps;
    ps=exp(6.42+0.072*tg-2.71e-3*pow(tg,2)+7.23e-7*pow(tg,3));
    da=d(tg,tw);
    a=101325/(0.622/da+1)/ps;
    ga=101325*(1-0.378*a*ps/101325)/(287.06*(tg+273.15));
    return(ga);
}
float t_w(float h)
{
    float t,t1,t2,ha,da;
    for(t1=-20,t2=70,t=(t1+t2)/2,da=d(t,t),
        ha=(1.01*t+0.001*(da*1000)*(2501+1.85*t))*1000;
        fabs(ha-h)>1;
        t=(t1+t2)/2,da=d(t,t),ha=(1.01*t+0.001*(da*1000)*(2501+1.85*t))*1000)
    
    {
         if (ha>h)
            t2=t;
            else
            t1=t;
    }
    return(t);
}
float x(float htp,float t)
{
    float x;
    x=(htp-hf(t))/(hv(t)-hf(t));
    return(x);
}
float ash(float Gr,float t,float de)
{
    float ash,re,pr,nu,r,cp,u;
    u=uf(t);
    cp=cpf(t);
    r=rf(t);
    re=Gr*de/u;
    pr=cp*u/r;
    nu=0.023*pow(re,0.8)*pow(pr,0.4);
    ash=nu*r/de;
    return(ash);
}
 float asc(float Gr,float de,float t)
{
    float asc,re,pr,nu,r,cp,u;
    u=ug(t);
    cp=cpg(t);
    r=rg(t);
    re=Gr*de/u;
    pr=cp*u/r;
    nu=0.023*pow(re,0.8)*pow(pr,0.4);
    asc=nu*r/de;
    return(asc);
}
 
 float atp(float x,float Gr,float t,float de)
 {
     float atp,cp,r,u,pr,g1,vs1,nu;
     cp=cpf(t);
     u=uf(t);
     r=x*rg(t)+(1-x)*rf(t);
     pr=cp*u/r;
     g1=g(t);
     vs1=vs(t);
     nu=0.0265*pow(Gr,0.8)*pow(((1-x+x*pow(g1*vs1,0.5))/u),0.8)*pow(pr,1/3);
     atp=nu*r/de;
     return(atp);
 }
void Lsh(float L,float ta,float tw,float v,float Tc,float mr,float gjv,float jv,float ch,float de,float ck,
         float e,float Hp,float D,float W,float hjs,float *ta2,float *tw2,float *Lsh,float *tout,float *Qr)
{
    float L_sh;
    float tsh,h2,t1,t2,h1,trm,a_sh;
    float ta1,tw1,da,ha1,Qr1,ha2,tam,twm,ao,Aa;
    float ma,g_a,As,Gr,Ga,Qa;
    float n,i;
    float Ai,Ao;
    As=pi*pow(de/2-e,2);
    Gr=mr/As;
    g_a=ga(ta,tw);
    ma=g_a*v/3600;
    Aa=pi*(gjv/2)*(gjv/2+de);
    Ga=ma/Aa;
    Ai=pi*(de-2*e)*L;
    Ao=pi*de*L;
    
    *tout=T(hjs);
    n=50;
    tsh=(Tc-*tout)/n;
    t2=*tout;
    h2=hf(t2);
    ta1=ta;
    tw1=tw;
    ha1=ha(ta1,tw1);
    da=d(ta,tw);
    *Lsh=0;
    *Qr=0;
    for(i=1;i<=n;i++)
    {
        t1=t2+tsh;
        h1=hf(t1);
        Qr1=mr*(h1-h2);
        Qa=Qr1;
        ha2=Qa/ma+ha1;
        *tw2=t_w(ha2);
        *ta2=Tg(da,*tw2);
        trm=(t1+t2)/2;
        tam=(ta1+*ta2)/2;
        twm=(tw1+*tw2)/2;
        a_sh=ash(Gr,trm,de-2*e);
        ao=a(tam,twm,Ga,gjv,jv,ch,de,Hp,D,W);
        L_sh=(1/a_sh+Ai/(Ao*ao))*mr*(h1-h2)/((trm-tam)*pi*(de-2*e));
        *Lsh=*Lsh+L_sh;
        *Qr=*Qr+Qr1;
        t2=t1;
        h2=h1;
        
    }
}
void Ltp(float L,float ta,float tw,float v,float Tc,float mr,float gjv,float jv,float ch,float de,float ck,float e,
                 float Hp,float D,float W,float hout,float *Ltp,float *ta2,float *tw2,float *Qr,float *xout)
{
    float h2,h1,hin,htp,x1,x2,a_tp,xm;
    float ta1,tw1,da,ha1,Q_r,ha2,tam,twm,ao,Qa,Aa;
    float L_tp;
    float n,i;
    float ma,g_a,As,Gr,Ga;
    float Ai,Ao;
    As=pi*pow(de/2-e,2);
    Gr=mr/As;
    g_a=ga(ta,tw);
    ma=g_a*v/3600;
    Aa=pi*(gjv/2)*(gjv/2+de);
    Ga=ma/Aa;
    Ai=pi*(de-2*e)*L;
    Ao=pi*de*L;
    hin=hv(Tc);
    n=100;
    htp=(hin-hout)/n;
    ta1=ta;
    tw1=tw;
    ha1=ha(ta1,tw1);
    da=d(ta,tw);
    *xout=x(hout,Tc);
    h2=hout;
    x2=*xout;
    *Ltp=0;
    *Qr=0;
    for(i=1;i<=n;i++)
    {
        h1=h2+htp;
        x1=x(h1,Tc);
        xm=(x1+x2)/2;
        Q_r=mr*(h1-h2);
        Qa=Q_r;
        ha2=Qa/ma+ha1;
        *tw2=t_w(ha2);
        *ta2=Tg(da,*tw2);
        *tw2=t_w(ha2);
        *ta2=Tg(da,*tw2);
        tam=(ta1+*ta2)/2;
        twm=(tw1+*tw2)/2;
        ao=a(tam,twm,Ga,gjv,jv,ch,de,Hp,D,W);
        a_tp=atp(xm,Gr,Tc,de-2*e);
        L_tp=(1/a_tp+Ai/(Ao*ao))*mr*htp/((Tc-tam)*pi*(de-2*e));
        *Ltp=*Ltp+L_tp;
        *Qr=*Qr+Q_r;
        h2=h1;
        x2=x1;
        
    }
}
void Lsc(float L,float ta,float tw,float tin,float v,float Tc,float mr,float gjv,float jv,float ch,float de,float ck,float e,
                 float Hp,float D,float W,float *ta2,float *tw2,float *Lsc,float *Qr)
{
    float tout,t2,h2,t1,h1,trm,a_sc,tsc;
    float ta1,tw1,da,ha1,Q_r,ha2,tam,twm,ao,Qa,Aa;
    float n,i;
    float L_sc;
    float ma,g_a,As,Gr,Ga;
    float Ai,Ao;
    
    As=pi*pow(de/2-e,2);
    Gr=mr/As;
    g_a=ga(ta,tw);
    ma=g_a*v/3600;
    Aa=pi*(gjv/2.0)*(gjv/2.0+de);
    Ga=ma/Aa;
    Ai=pi*(de-2*e)*L;
    Ao=pi*de*L;
    tout=Tc;
    n=50;
    tsc=(tin-tout)/n;
    t2=tout;
    h2=hv(t2);
    ta1=ta;
    tw1=tw;
    ha1=ha(ta1,tw1);
    da=d(ta,tw);
    *Lsc=0;
    *Qr=0;
    for(i=1;i<=n;i++)
    {
        t1=t2+tsc;
        h1=hs(t1-Tc,Tc);
        Q_r=mr*(h1-h2);
        Qa=Q_r;
        ha2=Qa/ma+ha1;
        *tw2=t_w(ha2);
        *ta2=Tg(da,*tw2);
        trm=(t1+t2)/2;
        tam=(ta1+*ta2)/2;
        twm=(tw1+*tw2)/2;
        a_sc=asc(Gr,trm,de-2*e);
        ao=a(tam,twm,Ga,gjv,jv,ch,de,Hp,D,W);
        L_sc=(1/a_sc+Ai/(Ao*ao))*mr*(h1-h2)/((trm-tam)*pi*(de-2*e));
        *Lsc=*Lsc+L_sc;
        *Qr=*Qr+Q_r;
        t2=t1;
        h2=h1;
        //ta1=*ta2;
        //tw1=*tw2;
        //ha1=ha2;
    }
}
void condenser(float gjv,float jv,float ch,float de,float ck,float e,float Hp,float D,float W,float L,float mr,float tin,float Tc, float ta,float tw,
               float v,float*tout,float*L_sh_con,float*L_tp_con,float*L_sc_con,float*Qr_sh_con,float*Qr_tp_con,float*Qr_sc_con,
               float*Qz,float*Lz,float*hjs,float*hyt,float*xout)
{
    float pc,hsx,hxx;
    float ta2_sh,tw2_sh;
    float hout,ta2_tp,tw2_tp;
    float ta2_sc,tw2_sc;
    float L_sh,L_tp,L_sc;
    float Qr_sh,Qr_tp,Qr_sc;
    pc=psat(Tc);
    hsx=hv(Tc);
    hxx=hf(ta);
    *hjs=hsx+hxx/2.0;
    *hyt=hf(Tc);
    for(*hjs=(hsx+hxx)/2.0;;*hjs=(hsx+hxx)/2.0)
    {
        if (*hjs<*hyt)
        {  
            Lsh(L,ta,tw,v,Tc,mr,gjv,jv,ch,de,ck,e,Hp,D,W,*hjs,&ta2_sh,&tw2_sh,&L_sh,*&tout,&Qr_sh);
            *L_sh_con=L_sh;
            *Qr_sh_con=Qr_sh;
            hout=hf(Tc);
            Ltp(L,ta,tw,v,Tc,mr,gjv,jv,ch,de,ck,e,Hp,D,W,hout,&L_tp,&ta2_tp,&tw2_tp,&Qr_tp,*&xout);
            *L_tp_con=L_tp;
            *Qr_tp_con=Qr_tp;
            Lsc(L,ta,tw,tin,v,Tc,mr,gjv,jv,ch,de,ck,e,Hp,D,W,&ta2_sc,&tw2_sc,&L_sc,&Qr_sc);
            *L_sc_con=L_sc;
            *Qr_sc_con=Qr_sc;
            *Lz=*L_sh_con+*L_tp_con+*L_sc_con;
            *Qz=*Qr_sh_con+*Qr_tp_con+*Qr_sc_con;
        }
        else if (*hjs>*hyt)
        {
            L_sh=0;
            Qr_sh=0;
            *L_sh_con=L_sh;
            *Qr_sh_con=Qr_sh;
            Ltp(L,ta,tw,v,Tc,mr,gjv,jv,ch,de,ck,e,Hp,D,W,*hjs,&L_tp,&ta2_tp,&tw2_tp,&Qr_tp,*&xout);
            *L_tp_con=L_tp;
            *Qr_tp_con=Qr_tp;
            Lsc(L,ta,tw,tin,v,Tc,mr,gjv,jv,ch,de,ck,e,Hp,D,W,&ta2_sc,&tw2_sc,&L_sc,&Qr_sc);
            *L_sc_con=L_sc;
            *Qr_sc_con=Qr_sc;
            *Lz=*L_sh_con+*L_tp_con+*L_sc_con;
            *Qz=*Qr_sh_con+*Qr_tp_con+*Qr_sc_con;
        }
       if((*Lz-L)>0.1)
            hxx=*hjs;
        else if((*Lz-L)<0.1)
            hsx=*hjs;
        else
            break;
    }
  }
void main()
{
    float gjv,jv,ch,de,ck,e,L,Hp,D,W;
    float mr,tin,Tc;
    float ta,tw,v;
    float Qr_sh,Qr_sc,Qr_tp,Qz;
    float Lz,L_sh,L_tp,L_sc;
    float hjs,hyt,tout,xout;
    gjv=10e-3;
    jv=2.5e-3;
    ch=0.1e-3;
    de=3.74e-3;
    ck=0.016;
    e=0.0005;
    Tc=45;
    tin=75;
    mr=0.005;
    v=360/2.0;
    ta=20;
    tw=12;
    L=0.62;
    Hp=0.008;
    D=0.0015;
    W=0.001;
   condenser(gjv,jv,ch,de,ck,e,Hp,D,W,L,mr,tin,Tc,ta,tw,v,&tout,&L_sh,&L_tp,&L_sc,&Qr_sh,&Qr_tp,&Qr_sc,&Qz,&Lz,&hjs,&hyt,&xout);
    if (hjs<hyt)
    {
        cout<<"冷凝器过冷"<<endl;
        cout<<"制冷剂出口温度tout="<<tout<<endl;
        cout<<"过冷区长度L_sh="<<L_sh<<endl;
        cout<<"过冷区换热量Qr_sh="<<Qr_sh<<endl;
        cout<<"两相区长度L_tp="<<L_tp<<endl;
        cout<<"两相区换热量Qr_tp="<<Qr_tp<<endl;
        cout<<"过热区长度L_sc="<<L_sc<<endl;
        cout<<"过热区换热量Qr_sc="<<Qr_sc<<endl;
        cout<<"总换热量Qz="<<Qz<<endl;
        cout<<"总长Lz="<<Lz<<endl;
    }
    else
    {
        
        cout<<"两相区长度L_tp="<<L_tp<<endl;
        cout<<"两相区换热量Qr_tp="<<Qr_tp<<endl;
        cout<<"两相区出口干度xcout="<<xout<<endl;
        cout<<"过热区长度L_sc="<<L_sc<<endl;
        cout<<"过热区换热量Qr_sc="<<Qr_sc<<endl;
        cout<<"总换热量Qz="<<Qz<<endl;
        cout<<"总长Lz="<<Lz<<endl;
    }    
}