termo.eos.alpha.YuAndLu Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of materia Show documentation
Show all versions of materia Show documentation
Thermodynamics properties and
equilibria calculations for
chemical engineering.
package termo.eos.alpha;
import termo.component.Compound;
/**
*
* @author Hugo
*/
public class YuAndLu extends Alpha{
public YuAndLu(){
setEquation("\\alpha(T) = 10^{\\left(A+BT_r + CT_r^2\\right)\\left(1-T_r \\right)}");
}
@Override
public double alpha(double temperature, Compound component) {
double A = component.getA_YuAndLu();
double B = component.getB_YuAndLu();
double C = component.getC_YuAndLu();
double tr = temperature /component.getCriticalTemperature();
double log10 = (A + B * tr + C * Math.pow(tr,2))*(1-tr);
return Math.pow(10, log10);
}
@Override
public double TempOverAlphaTimesDerivativeAlphaRespectTemperature(double temperature, Compound component) {
double A = component.getA_YuAndLu();
double B = component.getB_YuAndLu();
double C = component.getC_YuAndLu();
double tr = temperature /component.getCriticalTemperature();
return Math.log(10)*((B*tr+2*C*tr)*(1-tr)
-tr*(A+B*tr+C*Math.pow(tr, 2)));
}
@Override
public int numberOfParameters() {
return 3;
}
@Override
public void setParameter(double value, Compound component, int index) {
switch(index){
case 0: component.setA_YuAndLu(value);
break;
case 1: component.setB_YuAndLu(value);
break;
case 2: component.setC_YuAndLu(value);
break;
}
}
@Override
public double getParameter(Compound component, int index) {
switch(index){
case 0:
return component.getA_YuAndLu();
case 1:
return component.getB_YuAndLu();
case 2:
return component.getC_YuAndLu();
default:
return 0;
}
}
@Override
public String getParameterName(int index) {
switch(index){
case 0 : return "A";
case 1: return "B";
case 2: return "C";
default: return null;
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy