From 4632e45859511b236d2f0632aee0ae7112094e35 Mon Sep 17 00:00:00 2001 From: Even Solbraa <41290109+EvenSol@users.noreply.github.com> Date: Thu, 7 Jul 2022 13:12:39 +0200 Subject: [PATCH] Add eos (#409) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Delete .classpath * Delete .factorypath * update git ignore * Added new atractive term AtractiveTermMatCopPRUMRNew added * added new alpha term for UMR * disabled test * changed to use NeqSim MSAccessDB * rm invalid doc * pipe friction update * update * Update AtractiveTermMatCopPRUMRNew.java * Update ComponentEos.java * Update NeqSimDataBase.java * updates * update * updated UMR Matchias Copeman terms * update * update * further updates * small change in test * updated attr.term * updated vol.translation * just added simle PR for testing a calculation * attractive term for nitrogen * just added simper models to test some calculations * set volume correction to fals * updated devcontainer file (#410) (#411) * updated devcontainer file (#410) (#412) * added molar volume of two phases * arbitrary value for translation and tests * modified componentPRvolcor to make zero the outer get volume correction * several changes needed to be discussed * completion of the derivatives of small g and small f with regards to model B,C,V parameters * loc_C,getc,getC definitions..needing to be connected to translation definition 9with calcCi or omething) * numerous * Completion of the dF derivatives-needing changes in the way that all translation elements should be expressed e.g.Ci,cij etc * changes in volcor and some tests * Ci change * some more changes * more changes..(needing assitance to some printouts for all the F functions in order to compare with mine) * more * updates * chenges in tests * test to be checked by professor * I think I fixed the systemtest(see microsoft teams for details) * fetching also the rest of the derivative tests with the fixed setup * some changes * Added UMRCPA * modified component UMRCPA to not use the fixed a,b,c values of the CPA scheme! * use of attractive term via the PR EoS * some modifications that I did to test the volcor functions in mixtures * setting up the CPA version of my code into Neqsim through overriding the createComponent class+super.method+changing the Tc,Pc,w,ε,β parameters * ... * printouts for fugacities * print outs of fugacity * ... * added in CPA an enthalpy printout * added Hres+Cv * TESTING... * ... * fixed the bug * further sychronisation of my CPA with Neqsim CPA * crossscheck of new mc5 attractive term with my code * fixed radial g in PhaseSRKCPA * fixed componentSRKCPA original and simplified * several changes... * now all fug derivative tests are run for all phases * crosscheck of arbitrary PR_MC5_CPA EoS with my code-->on the road of fitting * small correction in dn derivative test * fugacities test fix * further correction * further fix Co-authored-by: Åsmund Våge Fannemel Co-authored-by: Åsmund Våge Fannemel <34712686+asmfstatoil@users.noreply.github.com> Co-authored-by: GeorgeT <47523587+akisTas@users.noreply.github.com> --- .gitignore | 4 +- .../neqsim/thermo/ThermodynamicModelTest.java | 729 +-- .../neqsim/thermo/component/Component.java | 4503 ++++++++--------- .../neqsim/thermo/component/ComponentEos.java | 16 +- .../thermo/component/ComponentInterface.java | 1 + .../thermo/component/ComponentPRvolcor.java | 191 + .../thermo/component/ComponentSrkCPA.java | 1284 ++--- .../thermo/component/ComponentSrkCPAs.java | 146 +- .../thermo/component/ComponentUMRCPA.java | 672 +++ .../AtractiveTermMatCopPRUMRNew.java | 187 + .../neqsim/thermo/phase/PhasePrEosvolcor.java | 407 ++ .../java/neqsim/thermo/phase/PhaseSrkCPA.java | 6 +- .../java/neqsim/thermo/phase/PhaseUMRCPA.java | 2120 ++++++++ .../neqsim/thermo/system/SystemUMRCPAEoS.java | 48 + .../thermo/system/SystemUMRPRUMCEosNew.java | 83 +- .../pipeFlowSystem/PipeFlowSystemTest.java | 1 + .../neqsim/thermo/system/ModelBaseTest.java | 240 +- .../thermo/system/SystemUMRCPAEoStest.java | 233 + .../system/SystemUMRPRUMCEosNewTest.java | 340 +- .../neqsim/thermo/util/example/ModelTest.java | 28 +- 20 files changed, 7575 insertions(+), 3664 deletions(-) create mode 100644 src/main/java/neqsim/thermo/component/ComponentPRvolcor.java create mode 100644 src/main/java/neqsim/thermo/component/ComponentUMRCPA.java create mode 100644 src/main/java/neqsim/thermo/component/attractiveEosTerm/AtractiveTermMatCopPRUMRNew.java create mode 100644 src/main/java/neqsim/thermo/phase/PhasePrEosvolcor.java create mode 100644 src/main/java/neqsim/thermo/phase/PhaseUMRCPA.java create mode 100644 src/main/java/neqsim/thermo/system/SystemUMRCPAEoS.java create mode 100644 src/test/java/neqsim/thermo/system/SystemUMRCPAEoStest.java diff --git a/.gitignore b/.gitignore index 0c672bd3a3..16cda0aece 100644 --- a/.gitignore +++ b/.gitignore @@ -71,13 +71,13 @@ nbdist/ src/main/java/neqsim/util/database/NeqSimDataBase2.java neqsim.iml +.classpath .DS_Store - # Test output - Serialized files test_*.ser .dccache #Intellij IDEA -.idea \ No newline at end of file +.idea diff --git a/src/main/java/neqsim/thermo/ThermodynamicModelTest.java b/src/main/java/neqsim/thermo/ThermodynamicModelTest.java index 37856bb0b9..ff7dba0307 100644 --- a/src/main/java/neqsim/thermo/ThermodynamicModelTest.java +++ b/src/main/java/neqsim/thermo/ThermodynamicModelTest.java @@ -18,402 +18,407 @@ * @version $Id: $Id */ public class ThermodynamicModelTest implements ThermodynamicConstantsInterface { - private static final long serialVersionUID = 1000; - SystemInterface system; - static Logger logger = LogManager.getLogger(ThermodynamicModelTest.class); - - /** - *

- * Constructor for ThermodynamicModelTest. - *

- */ - public ThermodynamicModelTest() {} - - /** - *

- * Constructor for ThermodynamicModelTest. - *

- * - * @param system a {@link neqsim.thermo.system.SystemInterface} object - */ - public ThermodynamicModelTest(SystemInterface system) { - this.system = system; + private static final long serialVersionUID = 1000; + SystemInterface system; + static Logger logger = LogManager.getLogger(ThermodynamicModelTest.class); + + /** + *

+ * Constructor for ThermodynamicModelTest. + *

+ */ + public ThermodynamicModelTest() {} + + /** + *

+ * Constructor for ThermodynamicModelTest. + *

+ * + * @param system a {@link neqsim.thermo.system.SystemInterface} object + */ + public ThermodynamicModelTest(SystemInterface system) { + this.system = system; + } + + /** + *

+ * runTest. + *

+ */ + public void runTest() { + // system.init(0); + system.init(3); + logger.info("testing fugacitycoefs..." + checkFugacityCoefficients()); + logger.info("testing fugacity der composition..." + checkFugacityCoefficientsDn()); + logger.info("testing fugacity der composition2..." + checkFugacityCoefficientsDn2()); + logger.info("testing fugacity der pressure..." + checkFugacityCoefficientsDP()); + logger.info("testing fugacity der temperature..." + checkFugacityCoefficientsDT()); + logger.info("comparing to numerical derivatives..." + checkNumerically()); + // System.out.println("testing fugacitycoefs..." + checkFugacityCoefficients()); + // System.out.println("testing fugacity der composition..." + + // checkFugacityCoefficientsDn()); + // System.out.println("testing fugacity der composition2..." + + // checkFugacityCoefficientsDn2()); + // System.out.println("testing fugacity der pressure..." + + // checkFugacityCoefficientsDP()); + // System.out.println("testing fugacity der temperature..." + + // checkFugacityCoefficientsDT()); + // System.out.println("comparing to numerical derivatives..." + + // checkNumerically()); + } + + /** + *

+ * checkFugacityCoefficients. + *

+ * + * @return a boolean + */ + public boolean checkFugacityCoefficients() { + double temp1 = 0 ; + for (int j = 0; j < system.getNumberOfPhases(); j++) { + for (int i = 0; i < system.getPhase(j).getNumberOfComponents(); i++) { + temp1 += system.getPhase(j).getComponents()[i].getNumberOfMolesInPhase() + * Math.log(system.getPhase(j).getComponents()[i].getFugacityCoefficient()); + // temp2 += system.getPhase(j).getComponents()[i].getNumberOfMolesInPhase() + // * Math.log(system.getPhase(j).getComponents()[i].getFugacityCoefficient()); + } + temp1 -= system.getPhase(j).getGresTP() / (R * system.getTemperature()); } - - /** - *

- * runTest. - *

- */ - public void runTest() { - // system.init(0); - system.init(3); - logger.info("testing fugacitycoefs..." + checkFugacityCoefficients()); - logger.info("testing fugacity der composition..." + checkFugacityCoefficientsDn()); - logger.info("testing fugacity der composition2..." + checkFugacityCoefficientsDn2()); - logger.info("testing fugacity der pressure..." + checkFugacityCoefficientsDP()); - logger.info("testing fugacity der temperature..." + checkFugacityCoefficientsDT()); - logger.info("comparing to numerical derivatives..." + checkNumerically()); - // System.out.println("testing fugacitycoefs..." + checkFugacityCoefficients()); - // System.out.println("testing fugacity der composition..." + - // checkFugacityCoefficientsDn()); - // System.out.println("testing fugacity der composition2..." + - // checkFugacityCoefficientsDn2()); - // System.out.println("testing fugacity der pressure..." + - // checkFugacityCoefficientsDP()); - // System.out.println("testing fugacity der temperature..." + - // checkFugacityCoefficientsDT()); - // System.out.println("comparing to numerical derivatives..." + - // checkNumerically()); + logger.info("Testing fugacity coefficients..................."); + //logger.info("Total fug gas : " + temp1); + //logger.info("Total fug liq : " + temp2); + // System.out.println("Testing fugacity coefficients..................."); + // System.out.println("Total fug gas : " + temp1); + // System.out.println("Total fug liq : " + temp2); + //System.out.println("MOLAR VOLUME 1 " + system.getPhase("gas").getMolarVolume()); + // System.out.println("MOLAR VOLUME 2 " + system.getPhase("aqueous").getMolarVolume()); + //System.out.println("number of phases " + system.getNumberOfPhases()); + //System.out.println("number of components " + system.getNumberOfComponents()); + // temp1 -= system.getPhase(j).getGresTP() / (R * system.getTemperature()); + // temp2 -= system.getPhases()[1].getGresTP() / (R * system.getTemperature()); + double sum = Math.abs(temp1); + //logger.info("Diffference fug gas : " + temp1); + //logger.info("Difference fug liq : " + temp2); + // System.out.println("Diffference fug gas : " + temp1); + // System.out.println("Difference fug liq : " + temp2); + return Math.abs(sum) < 1e-10; + } + + /** + *

+ * checkFugacityCoefficientsDn. + *

+ * + * @return a boolean + */ + // public boolean checkFugacityCoefficientsDn() { + + public boolean checkFugacityCoefficientsDn() { + double temp1 = 0; + double sum = 0; + for (int k = 0; k < system.getNumberOfPhases(); k++) { + for (int j = 0; j < system.getPhase(k).getNumberOfComponents(); j++) { + temp1 = 0; + //temp2 = 0; + // temp1 += + // Math.log(system.getPhases()[0].getComponents()[j].getFugacityCoefficient()); + // temp2 += + // Math.log(system.getPhases()[1].getComponents()[j].getFugacityCoefficient()); + for (int i = 0; i < system.getPhase(k).getNumberOfComponents(); i++) { + temp1 += system.getPhase(k).getComponents()[i].getNumberOfMolesInPhase() + * system.getPhase(k).getComponents()[i].getdfugdn(j); + //temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() + //* system.getPhases()[1].getComponents()[i].getdfugdn(j); + // System.out.println("fug " + + // system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase()*system.getPhases()[1].getComponents()[i].getdfugdn(j)); + } + + + // System.out.println("test fugdn gas : " + j + " " + temp1 + " name " + + // system.getPhases()[0].getComponents()[j].getComponentName()); + // System.out.println("test fugdn liq : " + j + " " + temp2); } - - /** - *

- * checkFugacityCoefficients. - *

- * - * @return a boolean - */ - public boolean checkFugacityCoefficients() { - double temp1 = 0, temp2 = 0; - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - temp1 += system.getPhases()[0].getComponents()[i].getNumberOfMolesInPhase() - * Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() - * Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); - } - logger.info("Testing fugacity coefficients..................."); - logger.info("Total fug gas : " + temp1); - logger.info("Total fug liq : " + temp2); - // System.out.println("Testing fugacity coefficients..................."); - // System.out.println("Total fug gas : " + temp1); - // System.out.println("Total fug liq : " + temp2); - temp1 -= system.getPhases()[0].getGresTP() / (R * system.getTemperature()); - temp2 -= system.getPhases()[1].getGresTP() / (R * system.getTemperature()); - double sum = Math.abs(temp1) + Math.abs(temp2); - logger.info("Diffference fug gas : " + temp1); - logger.info("Difference fug liq : " + temp2); - // System.out.println("Diffference fug gas : " + temp1); - // System.out.println("Difference fug liq : " + temp2); - return Math.abs(sum) < 1e-10; + } + sum += Math.abs(temp1) ; + logger.info("Testing composition derivatives of fugacity coefficients..................."); + logger.info("Diffference : " + sum); + // System.out.println("Testing composition derivatives of fugacity + // coefficients..................."); + // System.out.println("Difference : " + sum); + return Math.abs(sum) < 1e-10; + } + + + /** + *

+ * checkFugacityCoefficientsDn2. + *

+ * + * @return a boolean + */ + public boolean checkFugacityCoefficientsDn2() { + // boolean test1 = false, test2 = false; + double temp1 = 0; + double sum = 0; + + for (int k = 0; k < system.getNumberOfPhases(); k++) { + for (int j = 0; j < system.getPhase(k).getNumberOfComponents(); j++) { + temp1 = 0; + //temp2 = 0; + // temp1 += + // Math.log(system.getPhases()[0].getComponents()[j].getFugacityCoefficient()); + // temp2 += + // Math.log(system.getPhases()[1].getComponents()[j].getFugacityCoefficient()); + for (int i = 0; i < system.getPhase(k).getNumberOfComponents(); i++) { + temp1 += system.getPhase(k).getComponents()[i].getdfugdn(j) + - system.getPhase(k).getComponents()[j].getdfugdn(i); + //temp2 += system.getPhases()[1].getComponents()[i].getdfugdn(j) + // - system.getPhases()[1].getComponents()[j].getdfugdn(i); + } + //sum += Math.abs(temp1) + Math.abs(temp2); + // System.out.println("test fugdn gas : " + j + " " + temp1); + // System.out.println("test fugdn liq : " + j + " " + temp2); } + + //logger.info("Testing composition derivatives2 of fugacity coefficients..................."); + //logger.info("Diffference : " + sum); + // System.out.println("Testing composition derivatives2 of fugacity + // coefficients..................."); + // System.out.println("Difference : " + sum); + } + sum += Math.abs(temp1) ; + logger.info("Testing composition derivatives2 of fugacity coefficients..................."); + logger.info("Diffference : " + sum); + return Math.abs(sum) < 1e-10; + } + + /** + *

+ * checkFugacityCoefficientsDP. + *

+ * + * @return a boolean + */ + public boolean checkFugacityCoefficientsDP() { + // boolean test1 = false, test2 = false; + double temp1 = 0, temp2 = 0; + double sum = 0; + for (int j = 0; j < system.getNumberOfPhases(); j++) { + for (int i = 0; i < system.getPhase(j).getNumberOfComponents(); i++) { + temp1 += system.getPhase(j).getComponents()[i].getNumberOfMolesInPhase() + * system.getPhase(j).getComponents()[i].getdfugdp(); + + } + temp1 -= (system.getPhase(j).getZ() - 1.0) * system.getPhase(j).getNumberOfMolesInPhase() + / system.getPhase(j).getPressure(); - /** - *

- * checkFugacityCoefficientsDn. - *

- * - * @return a boolean - */ - public boolean checkFugacityCoefficientsDn() { - double temp1 = 0, temp2 = 0; - double sum = 0; - - for (int j = 0; j < system.getPhases()[0].getNumberOfComponents(); j++) { - temp1 = 0; - temp2 = 0; - // temp1 += - // Math.log(system.getPhases()[0].getComponents()[j].getFugacityCoefficient()); - // temp2 += - // Math.log(system.getPhases()[1].getComponents()[j].getFugacityCoefficient()); - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - temp1 += system.getPhases()[0].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[0].getComponents()[i].getdfugdn(j); - temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[1].getComponents()[i].getdfugdn(j); - // System.out.println("fug " + - // system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase()*system.getPhases()[1].getComponents()[i].getdfugdn(j)); - } - - sum += Math.abs(temp1) + Math.abs(temp2); - // System.out.println("test fugdn gas : " + j + " " + temp1 + " name " + - // system.getPhases()[0].getComponents()[j].getComponentName()); - // System.out.println("test fugdn liq : " + j + " " + temp2); - } - logger.info("Testing composition derivatives of fugacity coefficients..................."); - logger.info("Diffference : " + sum); - // System.out.println("Testing composition derivatives of fugacity - // coefficients..................."); - // System.out.println("Difference : " + sum); - return Math.abs(sum) < 1e-10; + } + sum = Math.abs(temp1) + Math.abs(temp2); + // System.out.println("test fugdp gas : " + temp1); + // System.out.println("test fugdp liq : " + temp2); + logger.info("Testing pressure derivatives of fugacity coefficients..................."); + logger.info("Error : " + sum); + // System.out.println("Testing pressure derivatives of fugacity + // coefficients..................."); + // System.out.println("Error : " + sum); + + return Math.abs(sum) < 1e-10; + } + + /** + *

+ * checkFugacityCoefficientsDT. + *

+ * + * @return a boolean + */ + public boolean checkFugacityCoefficientsDT() { + // boolean test1 = false, test2 = false; + double temp1 = 0; + double sum = 0; + for (int j = 0; j < system.getNumberOfPhases(); j++) { + for (int i = 0; i < system.getPhase(j).getNumberOfComponents(); i++) { + temp1 += system.getPhase(j).getComponents()[i].getNumberOfMolesInPhase() + * system.getPhase(j).getComponents()[i].getdfugdt(); + // temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() + // * system.getPhases()[1].getComponents()[i].getdfugdt(); + } + temp1 += system.getPhase(j).getHresTP() / (R * Math.pow(system.getTemperature(), 2.0)); + // temp2 += system.getPhases()[1].getHresTP() / (R * Math.pow(system.getTemperature(), 2.0)); + } + // sum = Math.abs(temp1) + Math.abs(temp2); + sum = Math.abs(temp1); + // System.out.println("test fugdp gas : " + system.getPhases()[0].getHresTP()); + // System.out.println("test fugdp liq : " + temp2); + logger.info("Testing temperature derivatives of fugacity coefficients..................."); + logger.info("Error : " + sum); + // System.out.println("Testing temperature derivatives of fugacity + // coefficients..................."); + // System.out.println("Error : " + sum); + return Math.abs(sum) < 1e-10; + } + + /** + *

+ * checkNumerically. + *

+ * + * @return a boolean + */ + public boolean checkNumerically() { + double[][] gasfug = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][] liqfug = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][] gasnumericDfugdt = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][] liqnumericDfugdt = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][] gasnumericDfugdp = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][] liqnumericDfugdp = new double[2][system.getPhases()[0].getNumberOfComponents()]; + double[][][] gasnumericDfugdn = new double[2][system.getPhases()[0] + .getNumberOfComponents()][system.getPhases()[0].getNumberOfComponents()]; + double[][][] liqnumericDfugdn = new double[2][system.getPhases()[0] + .getNumberOfComponents()][system.getPhases()[0].getNumberOfComponents()]; + system.init(3); + + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + gasnumericDfugdt[0][i] = system.getPhases()[0].getComponents()[i].getdfugdt(); + gasnumericDfugdp[0][i] = system.getPhases()[0].getComponents()[i].getdfugdp(); + liqnumericDfugdt[0][i] = system.getPhases()[1].getComponents()[i].getdfugdt(); + liqnumericDfugdp[0][i] = system.getPhases()[1].getComponents()[i].getdfugdp(); + for (int k = 0; k < system.getPhases()[0].getNumberOfComponents(); k++) { + gasnumericDfugdn[0][i][k] = system.getPhases()[0].getComponents()[i].getdfugdn(k); + liqnumericDfugdn[0][i][k] = system.getPhases()[1].getComponents()[i].getdfugdn(k); + } } - /** - *

- * checkFugacityCoefficientsDn2. - *

- * - * @return a boolean - */ - public boolean checkFugacityCoefficientsDn2() { - // boolean test1 = false, test2 = false; - double temp1 = 0, temp2 = 0; - double sum = 0; - - for (int j = 0; j < system.getPhases()[0].getNumberOfComponents(); j++) { - temp1 = 0; - temp2 = 0; - // temp1 += - // Math.log(system.getPhases()[0].getComponents()[j].getFugacityCoefficient()); - // temp2 += - // Math.log(system.getPhases()[1].getComponents()[j].getFugacityCoefficient()); - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - temp1 += system.getPhases()[0].getComponents()[i].getdfugdn(j) - - system.getPhases()[0].getComponents()[j].getdfugdn(i); - temp2 += system.getPhases()[1].getComponents()[i].getdfugdn(j) - - system.getPhases()[1].getComponents()[j].getdfugdn(i); - } - sum += Math.abs(temp1) + Math.abs(temp2); - // System.out.println("test fugdn gas : " + j + " " + temp1); - // System.out.println("test fugdn liq : " + j + " " + temp2); - } - logger.info("Testing composition derivatives2 of fugacity coefficients..................."); - logger.info("Diffference : " + sum); - // System.out.println("Testing composition derivatives2 of fugacity - // coefficients..................."); - // System.out.println("Difference : " + sum); + double dt = system.getTemperature() / 1e5; + system.setTemperature(system.getTemperature() + dt); + system.init(3); - return Math.abs(sum) < 1e-10; + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + gasfug[0][i] = Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[0][i] = Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); } - /** - *

- * checkFugacityCoefficientsDP. - *

- * - * @return a boolean - */ - public boolean checkFugacityCoefficientsDP() { - // boolean test1 = false, test2 = false; - double temp1 = 0, temp2 = 0; - double sum = 0; + system.setTemperature(system.getTemperature() - 2 * dt); + system.init(3); - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - temp1 += system.getPhases()[0].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[0].getComponents()[i].getdfugdp(); - temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[1].getComponents()[i].getdfugdp(); - } - temp1 -= (system.getPhases()[0].getZ() - 1.0) - * system.getPhases()[0].getNumberOfMolesInPhase() - / system.getPhases()[0].getPressure(); - temp2 -= (system.getPhases()[1].getZ() - 1.0) - * system.getPhases()[1].getNumberOfMolesInPhase() - / system.getPhases()[1].getPressure(); - sum = Math.abs(temp1) + Math.abs(temp2); - // System.out.println("test fugdp gas : " + temp1); - // System.out.println("test fugdp liq : " + temp2); - logger.info("Testing pressure derivatives of fugacity coefficients..................."); - logger.info("Error : " + sum); - // System.out.println("Testing pressure derivatives of fugacity - // coefficients..................."); - // System.out.println("Error : " + sum); - - return Math.abs(sum) < 1e-10; + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + gasfug[1][i] = Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[1][i] = Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); } - /** - *

- * checkFugacityCoefficientsDT. - *

- * - * @return a boolean - */ - public boolean checkFugacityCoefficientsDT() { - // boolean test1 = false, test2 = false; - double temp1 = 0, temp2 = 0; - double sum = 0; - - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - temp1 += system.getPhases()[0].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[0].getComponents()[i].getdfugdt(); - temp2 += system.getPhases()[1].getComponents()[i].getNumberOfMolesInPhase() - * system.getPhases()[1].getComponents()[i].getdfugdt(); - } - temp1 += system.getPhases()[0].getHresTP() / (R * Math.pow(system.getTemperature(), 2.0)); - temp2 += system.getPhases()[1].getHresTP() / (R * Math.pow(system.getTemperature(), 2.0)); - sum = Math.abs(temp1) + Math.abs(temp2); - // System.out.println("test fugdp gas : " + system.getPhases()[0].getHresTP()); - // System.out.println("test fugdp liq : " + temp2); - logger.info("Testing temperature derivatives of fugacity coefficients..................."); - logger.info("Error : " + sum); - // System.out.println("Testing temperature derivatives of fugacity - // coefficients..................."); - // System.out.println("Error : " + sum); - return Math.abs(sum) < 1e-10; + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + logger.info("dt: gas phase comp " + i + " % error " + + ((gasfug[0][i] - gasfug[1][i]) / (2 * dt) - gasnumericDfugdt[0][i]) + / gasnumericDfugdt[0][i] * 100.0); + logger.info("dt: liq phase comp " + i + " % error " + + ((liqfug[0][i] - liqfug[1][i]) / (2 * dt) - liqnumericDfugdt[0][i]) + / liqnumericDfugdt[0][i] * 100.0); + // System.out.println("dt: gas phase comp " + i + " % error " + ((gasfug[0][i] - + // gasfug[1][i])/(2*dt) - gasnumericDfugdt[0][i])/gasnumericDfugdt[0][i]*100.0); + // System.out.println("dt: liq phase comp " + i + " % error " + ((liqfug[0][i] - + // liqfug[1][i])/(2*dt) - liqnumericDfugdt[0][i])/liqnumericDfugdt[0][i]*100.0); } - /** - *

- * checkNumerically. - *

- * - * @return a boolean - */ - public boolean checkNumerically() { - double[][] gasfug = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][] liqfug = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][] gasnumericDfugdt = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][] liqnumericDfugdt = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][] gasnumericDfugdp = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][] liqnumericDfugdp = new double[2][system.getPhases()[0].getNumberOfComponents()]; - double[][][] gasnumericDfugdn = new double[2][system.getPhases()[0] - .getNumberOfComponents()][system.getPhases()[0].getNumberOfComponents()]; - double[][][] liqnumericDfugdn = new double[2][system.getPhases()[0] - .getNumberOfComponents()][system.getPhases()[0].getNumberOfComponents()]; - system.init(3); + system.setTemperature(system.getTemperature() + dt); + system.init(3); - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - gasnumericDfugdt[0][i] = system.getPhases()[0].getComponents()[i].getdfugdt(); - gasnumericDfugdp[0][i] = system.getPhases()[0].getComponents()[i].getdfugdp(); - liqnumericDfugdt[0][i] = system.getPhases()[1].getComponents()[i].getdfugdt(); - liqnumericDfugdp[0][i] = system.getPhases()[1].getComponents()[i].getdfugdp(); - for (int k = 0; k < system.getPhases()[0].getNumberOfComponents(); k++) { - gasnumericDfugdn[0][i][k] = system.getPhases()[0].getComponents()[i].getdfugdn(k); - liqnumericDfugdn[0][i][k] = system.getPhases()[1].getComponents()[i].getdfugdn(k); - } - } + double dp = system.getPressure() / 1e5; + system.setPressure(system.getPressure() + dp); + system.init(3); - double dt = system.getTemperature() / 1e5; - system.setTemperature(system.getTemperature() + dt); - system.init(3); + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + gasfug[0][i] = Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[0][i] = Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); + } - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - gasfug[0][i] = - Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[0][i] = - Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); - } + system.setPressure(system.getPressure() - 2 * dp); + system.init(3); - system.setTemperature(system.getTemperature() - 2 * dt); - system.init(3); + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + gasfug[1][i] = Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[1][i] = Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); + } - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - gasfug[1][i] = - Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[1][i] = - Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); - } + for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { + logger.info("dp: gas phase comp " + i + " % error " + + ((gasfug[0][i] - gasfug[1][i]) / (2 * dp) - gasnumericDfugdp[0][i]) + / gasnumericDfugdp[0][i] * 100.0); + logger.info("dp: liq phase comp " + i + " % error " + + ((liqfug[0][i] - liqfug[1][i]) / (2 * dp) - liqnumericDfugdp[0][i]) + / liqnumericDfugdp[0][i] * 100.0); + // System.out.println("dp: gas phase comp " + i + " % error " + ((gasfug[0][i] - + // gasfug[1][i])/(2*dp) - gasnumericDfugdp[0][i])/gasnumericDfugdp[0][i]*100.0); + // System.out.println("dp: liq phase comp " + i + " % error " + ((liqfug[0][i] - + // liqfug[1][i])/(2*dp) - liqnumericDfugdp[0][i])/liqnumericDfugdp[0][i]*100.0); + } - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - logger.info("dt: gas phase comp " + i + " % error " - + ((gasfug[0][i] - gasfug[1][i]) / (2 * dt) - gasnumericDfugdt[0][i]) - / gasnumericDfugdt[0][i] * 100.0); - logger.info("dt: liq phase comp " + i + " % error " - + ((liqfug[0][i] - liqfug[1][i]) / (2 * dt) - liqnumericDfugdt[0][i]) - / liqnumericDfugdt[0][i] * 100.0); - // System.out.println("dt: gas phase comp " + i + " % error " + ((gasfug[0][i] - - // gasfug[1][i])/(2*dt) - gasnumericDfugdt[0][i])/gasnumericDfugdt[0][i]*100.0); - // System.out.println("dt: liq phase comp " + i + " % error " + ((liqfug[0][i] - - // liqfug[1][i])/(2*dt) - liqnumericDfugdt[0][i])/liqnumericDfugdt[0][i]*100.0); + system.setPressure(system.getPressure() + dp); + system.init(3); + + for (int phase = 0; phase < 2; phase++) { + for (int k = 0; k < system.getPhases()[0].getNumberOfComponents(); k++) { + double dn = system.getPhases()[phase].getComponents()[k].getNumberOfMolesInPhase() / 1.0e5; + logger.info( + "component name " + system.getPhases()[phase].getComponents()[k].getComponentName()); + logger.info("dn " + dn); + // System.out.println("component name " + + // system.getPhases()[phase].getComponents()[k].getComponentName()); + // System.out.println("dn " + dn); + if (dn < 1e-12) { + dn = 1e-12; } - - system.setTemperature(system.getTemperature() + dt); - system.init(3); - - double dp = system.getPressure() / 1e5; - system.setPressure(system.getPressure() + dp); + system.addComponent(k, dn, phase); + // system.initBeta(); + system.init_x_y(); system.init(3); for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - gasfug[0][i] = - Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[0][i] = - Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); + // gasfug[0][i] = + // Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[0][i] = + Math.log(system.getPhases()[phase].getComponents()[i].getFugacityCoefficient()); } - system.setPressure(system.getPressure() - 2 * dp); + system.addComponent(k, -2.0 * dn, phase); + // system.initBeta(); + system.init_x_y(); system.init(3); for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - gasfug[1][i] = - Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[1][i] = - Math.log(system.getPhases()[1].getComponents()[i].getFugacityCoefficient()); + // gasfug[1][i] = + // Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); + liqfug[1][i] = + Math.log(system.getPhases()[phase].getComponents()[i].getFugacityCoefficient()); } for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - logger.info("dp: gas phase comp " + i + " % error " - + ((gasfug[0][i] - gasfug[1][i]) / (2 * dp) - gasnumericDfugdp[0][i]) - / gasnumericDfugdp[0][i] * 100.0); - logger.info("dp: liq phase comp " + i + " % error " - + ((liqfug[0][i] - liqfug[1][i]) / (2 * dp) - liqnumericDfugdp[0][i]) - / liqnumericDfugdp[0][i] * 100.0); - // System.out.println("dp: gas phase comp " + i + " % error " + ((gasfug[0][i] - - // gasfug[1][i])/(2*dp) - gasnumericDfugdp[0][i])/gasnumericDfugdp[0][i]*100.0); - // System.out.println("dp: liq phase comp " + i + " % error " + ((liqfug[0][i] - - // liqfug[1][i])/(2*dp) - liqnumericDfugdp[0][i])/liqnumericDfugdp[0][i]*100.0); + if (phase == 0) { + logger.info("dn: gas phase comp " + i + " % error " + + ((liqfug[0][i] - liqfug[1][i]) / (2 * dn) - gasnumericDfugdn[0][i][k]) + / gasnumericDfugdn[0][i][k] * 100.0); + // System.out.println("dn: gas phase comp " + i + " % error " + + // ((liqfug[0][i] - + // liqfug[1][i])/(2*dn) - + // gasnumericDfugdn[0][i][k])/gasnumericDfugdn[0][i][k]*100.0); + } + if (phase == 1) { + logger.info("dn: liq phase comp " + i + " % error " + + ((liqfug[0][i] - liqfug[1][i]) / (2 * dn) - liqnumericDfugdn[0][i][k]) + / liqnumericDfugdn[0][i][k] * 100.0); + // System.out.println("dn: liq phase comp " + i + " % error " + + // ((liqfug[0][i] - + // liqfug[1][i])/(2*dn) - + // liqnumericDfugdn[0][i][k])/liqnumericDfugdn[0][i][k]*100.0); + } } - system.setPressure(system.getPressure() + dp); + system.addComponent(k, dn, phase); + // system.initBeta(); + system.init_x_y(); system.init(3); - - for (int phase = 0; phase < 2; phase++) { - for (int k = 0; k < system.getPhases()[0].getNumberOfComponents(); k++) { - double dn = system.getPhases()[phase].getComponents()[k].getNumberOfMolesInPhase() - / 1.0e5; - logger.info("component name " - + system.getPhases()[phase].getComponents()[k].getComponentName()); - logger.info("dn " + dn); - // System.out.println("component name " + - // system.getPhases()[phase].getComponents()[k].getComponentName()); - // System.out.println("dn " + dn); - if (dn < 1e-12) { - dn = 1e-12; - } - system.addComponent(k, dn, phase); - // system.initBeta(); - system.init_x_y(); - system.init(3); - - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - // gasfug[0][i] = - // Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[0][i] = Math.log( - system.getPhases()[phase].getComponents()[i].getFugacityCoefficient()); - } - - system.addComponent(k, -2.0 * dn, phase); - // system.initBeta(); - system.init_x_y(); - system.init(3); - - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - // gasfug[1][i] = - // Math.log(system.getPhases()[0].getComponents()[i].getFugacityCoefficient()); - liqfug[1][i] = Math.log( - system.getPhases()[phase].getComponents()[i].getFugacityCoefficient()); - } - - for (int i = 0; i < system.getPhases()[0].getNumberOfComponents(); i++) { - if (phase == 0) { - logger.info("dn: gas phase comp " + i + " % error " - + ((liqfug[0][i] - liqfug[1][i]) / (2 * dn) - - gasnumericDfugdn[0][i][k]) / gasnumericDfugdn[0][i][k] - * 100.0); - // System.out.println("dn: gas phase comp " + i + " % error " + - // ((liqfug[0][i] - - // liqfug[1][i])/(2*dn) - - // gasnumericDfugdn[0][i][k])/gasnumericDfugdn[0][i][k]*100.0); - } - if (phase == 1) { - logger.info("dn: liq phase comp " + i + " % error " - + ((liqfug[0][i] - liqfug[1][i]) / (2 * dn) - - liqnumericDfugdn[0][i][k]) / liqnumericDfugdn[0][i][k] - * 100.0); - // System.out.println("dn: liq phase comp " + i + " % error " + - // ((liqfug[0][i] - - // liqfug[1][i])/(2*dn) - - // liqnumericDfugdn[0][i][k])/liqnumericDfugdn[0][i][k]*100.0); - } - } - - system.addComponent(k, dn, phase); - // system.initBeta(); - system.init_x_y(); - system.init(3); - } - } - return true; + } } + return true; + } } diff --git a/src/main/java/neqsim/thermo/component/Component.java b/src/main/java/neqsim/thermo/component/Component.java index 93cb661aca..66707bb032 100644 --- a/src/main/java/neqsim/thermo/component/Component.java +++ b/src/main/java/neqsim/thermo/component/Component.java @@ -14,2292 +14,2277 @@ import neqsim.util.database.NeqSimDataBase; abstract class Component implements ComponentInterface { - private static final long serialVersionUID = 1000; - - double[] surfTensInfluenceParam = {0.28367, -0.05164, -0.81594, 1.06810, -1.1147}; - protected int index, componentNumber, attractiveTermNumber = 0, numberOfAssociationSites = 0; - protected double logFugacityCoefficient = 0.0, associationVolume = 0.0, associationEnergy = 0.0, - aCPA = 0.0, bCPA = 0.0, mCPA = 0.0, srkacentricFactor = 0.0; - protected String componentName = "default", referenceStateType = "solvent", - associationScheme = "0", antoineLiqVapPresType = null; - private String formulae = "", CASnumber = ""; - protected Element elements = null; - protected boolean isTBPfraction = false, isPlusFraction = false, isNormalComponent = true, - isIon = false; - private boolean isHydrateFormer = false; - private boolean waxFormer = false; - private String componentType = "Component"; - protected double qPure = 0, voli = 1.0; - protected int calcActivity = 1; - protected boolean solidCheck = false; - protected double dqPuredT = 0, dqPuredTdT = 0; - private double racketZCPA = 0; - private double criticalCompressibilityFactor = 0.0; - private double volumeCorrectionConst = 0.0, volumeCorrectionT = 0.0, - volumeCorrectionT_CPA = 0.0; - protected double criticalPressure, criticalTemperature, molarMass, acentricFactor, - numberOfMoles = 0.0, numberOfMolesInPhase = 0.0, normalLiquidDensity = 0; - protected double reducedPressure, reducedTemperature, fugacityCoefficient, - debyeDipoleMoment = 0, viscosityCorrectionFactor = 0, criticalVolume = 0, racketZ = 0; - protected double gibbsEnergyOfFormation = 0, criticalViscosity = 0.0; - protected double referencePotential = 0, viscosityFrictionK = 1.0; - protected int liquidViscosityModel = 0; - protected int ionicCharge = 0; - private double referenceEnthalpy = 0.0; - protected double parachorParameter = 0.0, normalBoilingPoint = 0, sphericalCoreRadius = 0.384, - standardDensity = 0, AntoineASolid = 0.0, AntoineBSolid = 0.0, AntoineCSolid = 0.0; - protected double[] liquidViscosityParameter = new double[4]; - protected double[] liquidConductivityParameter = new double[3]; - protected double[] henryCoefParameter = new double[4]; - protected double[] dielectricParameter = new double[5]; - protected double[] schwartzentruberParams = new double[3], matiascopemanParams = new double[3], - matiascopemanParamsPR = new double[3], TwuCoonParams = new double[3], - matiascopemanSolidParams = new double[3]; - protected double lennardJonesMolecularDiameter = 0, lennardJonesEnergyParameter = 0, - stokesCationicDiameter = 0, paulingAnionicDiameter = 0; - protected double K, z; - protected double x = 0; - private int orginalNumberOfAssociationSites = 0; - protected double dfugdt = 0.1, dfugdp = 0.1; - protected double[] dfugdn = new double[MAX_NUMBER_OF_COMPONENTS]; - public double[] dfugdx = new double[MAX_NUMBER_OF_COMPONENTS]; - double AntoineA = 0, AntoineB = 0, AntoineC = 0, AntoineD = 0, AntoineE = 0; - private double CpA = 100.0; - private double CpB = 0; - private double CpC = 0; - private double CpD = 0; - private double CpE = 0; - private double[] CpSolid = new double[5]; - private double[] CpLiquid = new double[5]; - private double heatOfFusion = 0.0; - double triplePointDensity = 10.0, triplePointPressure = 0.0; - private double triplePointTemperature = 1000.0; - double meltingPointTemperature = 110.0; - private double idealGasEnthalpyOfFormation = 0.0; - double idealGasGibsEnergyOfFormation = 0.0, idealGasAbsoluteEntropy = 0.0; - double Hsub = 0.0; - double[] solidDensityCoefs = new double[5]; - double[] liquidDensityCoefs = new double[5]; - double[] heatOfVaporizationCoefs = new double[5]; - protected double mSAFTi = 0; - protected double sigmaSAFTi = 0; - protected double epsikSAFT = 0; - private double associationVolumeSAFT; - private double associationEnergySAFT = 0; - static Logger logger = LogManager.getLogger(Component.class); - - /** - *

- * Constructor for Component. - *

- * - * @param number a int - * @param TC a double - * @param PC a double - * @param M a double - * @param a a double - * @param moles a double - */ - public Component(int number, double TC, double PC, double M, double a, double moles) { - criticalPressure = PC; - criticalTemperature = TC; - molarMass = M; - acentricFactor = a; - numberOfMoles = moles; - } - - /** - *

- * Constructor for Component. - *

- * - * @param component_name a {@link java.lang.String} object - * @param moles a double - * @param molesInPhase a double - * @param compnumber a int - */ - public Component(String component_name, double moles, double molesInPhase, int compnumber) { - createComponent(component_name, moles, molesInPhase, compnumber); - } - - /** {@inheritDoc} */ - @Override - public void insertComponentIntoDatabase(String databaseName) { - databaseName = "comptemp"; - neqsim.util.database.NeqSimDataBase database = new neqsim.util.database.NeqSimDataBase(); - try { - int isW = 0; - if (isWaxFormer()) { - isW = 1; - } - if (NeqSimDataBase.createTemporaryTables()) { - database.execute("insert into comptemp VALUES (" + (1000 + componentNumber) + ", '" - + componentName + "', '00-00-0','" + getComponentType() + "', " - + (1000 + componentNumber) + ", 'HC', " + (molarMass * 1000.0) + ", " - + normalLiquidDensity + ", " + (getTC() - 273.15) + ", " + getPC() + ", " - + getAcentricFactor() + "," + (getNormalBoilingPoint() - 273.15) - + ", 39.948, 74.9, 'Classic', 0, " + getCpA() + ", " + getCpB() + ", " - + getCpC() + ", " + getCpD() + ", " + getCpE() - + ", 'log', 5.2012, 1936.281, -20.143, -1.23303, 1000, 1.8, 0.076, 0.0, 0.0, 2.52, 809.1, 0, 3, -24.71, 4210, 0.0453, -3.38e-005, -229000, -19.2905, 29814.5, -0.019678, 0.000132, -3.11e-007, 0, 'solvent', 0, 0, 0, 0, 0.0789, -1.16, 0, -0.384, 0.00525, -6.37e-006, 207, " - + getHeatOfFusion() + ", 1000, 0.00611, " + getTriplePointTemperature() - + ", " + getMeltingPointTemperature() - + ", -242000, 189, 53, -0.00784, 0, 0, 0, 5.46, 0.305, 647, 0.081, 0, 52100000, 0.32, -0.212, 0.258, 0, 0.999, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '0', 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'no', " - + getmSAFTi() + ", " + (getSigmaSAFTi() * 1e10) + ", " + getEpsikSAFT() - + ", 0, 0,0,0,0,0," + isW - + ",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)"); - } - index = 1000 + componentNumber; - CASnumber = "00-00-0"; - } catch (Exception e) { - logger.error("error in inserting to database", e); - } finally { - try { - if (database.getStatement() != null) { - database.getStatement().close(); - } - if (database.getConnection() != null) { - database.getConnection().close(); - } - } catch (Exception e) { - logger.error("error closing database.....", e); - } + private static final long serialVersionUID = 1000; + + double[] surfTensInfluenceParam = {0.28367, -0.05164, -0.81594, 1.06810, -1.1147}; + protected int index, componentNumber, attractiveTermNumber = 0, numberOfAssociationSites = 0; + protected double logFugacityCoefficient = 0.0, associationVolume = 0.0, associationEnergy = 0.0, + aCPA = 0.0, bCPA = 0.0, mCPA = 0.0, srkacentricFactor = 0.0; + protected String componentName = "default", referenceStateType = "solvent", + associationScheme = "0", antoineLiqVapPresType = null; + private String formulae = "", CASnumber = ""; + protected Element elements = null; + protected boolean isTBPfraction = false, isPlusFraction = false, isNormalComponent = true, + isIon = false; + private boolean isHydrateFormer = false; + private boolean waxFormer = false; + private String componentType = "Component"; + protected double qPure = 0, voli = 1.0; + protected int calcActivity = 1; + protected boolean solidCheck = false; + protected double dqPuredT = 0, dqPuredTdT = 0; + private double racketZCPA = 0; + private double criticalCompressibilityFactor = 0.0; + private double volumeCorrectionConst = 0.0, volumeCorrectionT = 0.0, volumeCorrectionT_CPA = 0.0; + protected double criticalPressure, criticalTemperature, molarMass, acentricFactor, + numberOfMoles = 0.0, numberOfMolesInPhase = 0.0, normalLiquidDensity = 0; + protected double reducedPressure, reducedTemperature, fugacityCoefficient, debyeDipoleMoment = 0, + viscosityCorrectionFactor = 0, criticalVolume = 0, racketZ = 0; + protected double gibbsEnergyOfFormation = 0, criticalViscosity = 0.0; + protected double referencePotential = 0, viscosityFrictionK = 1.0; + protected int liquidViscosityModel = 0; + protected int ionicCharge = 0; + private double referenceEnthalpy = 0.0; + protected double parachorParameter = 0.0, normalBoilingPoint = 0, sphericalCoreRadius = 0.384, + standardDensity = 0, AntoineASolid = 0.0, AntoineBSolid = 0.0, AntoineCSolid = 0.0; + protected double[] liquidViscosityParameter = new double[4]; + protected double[] liquidConductivityParameter = new double[3]; + protected double[] henryCoefParameter = new double[4]; + protected double[] dielectricParameter = new double[5]; + protected double[] schwartzentruberParams = new double[3], matiascopemanParams = new double[3], + matiascopemanParamsPR = new double[3], TwuCoonParams = new double[3], + matiascopemanSolidParams = new double[3], matiascopemanParamsUMRPRU = new double[5]; + protected double lennardJonesMolecularDiameter = 0, lennardJonesEnergyParameter = 0, + stokesCationicDiameter = 0, paulingAnionicDiameter = 0; + protected double K, z; + protected double x = 0; + private int orginalNumberOfAssociationSites = 0; + protected double dfugdt = 0.1, dfugdp = 0.1; + protected double[] dfugdn = new double[MAX_NUMBER_OF_COMPONENTS]; + public double[] dfugdx = new double[MAX_NUMBER_OF_COMPONENTS]; + double AntoineA = 0, AntoineB = 0, AntoineC = 0, AntoineD = 0, AntoineE = 0; + private double CpA = 100.0; + private double CpB = 0; + private double CpC = 0; + private double CpD = 0; + private double CpE = 0; + private double[] CpSolid = new double[5]; + private double[] CpLiquid = new double[5]; + private double heatOfFusion = 0.0; + double triplePointDensity = 10.0, triplePointPressure = 0.0; + private double triplePointTemperature = 1000.0; + double meltingPointTemperature = 110.0; + private double idealGasEnthalpyOfFormation = 0.0; + double idealGasGibsEnergyOfFormation = 0.0, idealGasAbsoluteEntropy = 0.0; + double Hsub = 0.0; + double[] solidDensityCoefs = new double[5]; + double[] liquidDensityCoefs = new double[5]; + double[] heatOfVaporizationCoefs = new double[5]; + protected double mSAFTi = 0; + protected double sigmaSAFTi = 0; + protected double epsikSAFT = 0; + private double associationVolumeSAFT; + private double associationEnergySAFT = 0; + static Logger logger = LogManager.getLogger(Component.class); + + /** + *

+ * Constructor for Component. + *

+ * + * @param number a int + * @param TC a double + * @param PC a double + * @param M a double + * @param a a double + * @param moles a double + */ + public Component(int number, double TC, double PC, double M, double a, double moles) { + criticalPressure = PC; + criticalTemperature = TC; + molarMass = M; + acentricFactor = a; + numberOfMoles = moles; + } + + /** + *

+ * Constructor for Component. + *

+ * + * @param component_name a {@link java.lang.String} object + * @param moles a double + * @param molesInPhase a double + * @param compnumber a int + */ + public Component(String component_name, double moles, double molesInPhase, int compnumber) { + createComponent(component_name, moles, molesInPhase, compnumber); + } + + /** {@inheritDoc} */ + @Override + public void insertComponentIntoDatabase(String databaseName) { + databaseName = "comptemp"; + neqsim.util.database.NeqSimDataBase database = new neqsim.util.database.NeqSimDataBase(); + try { + int isW = 0; + if (isWaxFormer()) { + isW = 1; + } + if (NeqSimDataBase.createTemporaryTables()) { + database.execute("insert into comptemp VALUES (" + (1000 + componentNumber) + ", '" + + componentName + "', '00-00-0','" + getComponentType() + "', " + + (1000 + componentNumber) + ", 'HC', " + (molarMass * 1000.0) + ", " + + normalLiquidDensity + ", " + (getTC() - 273.15) + ", " + getPC() + ", " + + getAcentricFactor() + "," + (getNormalBoilingPoint() - 273.15) + + ", 39.948, 74.9, 'Classic', 0, " + getCpA() + ", " + getCpB() + ", " + getCpC() + ", " + + getCpD() + ", " + getCpE() + + ", 'log', 5.2012, 1936.281, -20.143, -1.23303, 1000, 1.8, 0.076, 0.0, 0.0, 2.52, 809.1, 0, 3, -24.71, 4210, 0.0453, -3.38e-005, -229000, -19.2905, 29814.5, -0.019678, 0.000132, -3.11e-007, 0, 'solvent', 0, 0, 0, 0, 0.0789, -1.16, 0, -0.384, 0.00525, -6.37e-006, 207, " + + getHeatOfFusion() + ", 1000, 0.00611, " + getTriplePointTemperature() + ", " + + getMeltingPointTemperature() + + ", -242000, 189, 53, -0.00784, 0, 0, 0, 5.46, 0.305, 647, 0.081, 0, 52100000, 0.32, -0.212, 0.258, 0, 0.999, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, '0', 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'no', " + + getmSAFTi() + ", " + (getSigmaSAFTi() * 1e10) + ", " + getEpsikSAFT() + + ", 0, 0,0,0,0,0," + isW + ",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)"); + } + index = 1000 + componentNumber; + CASnumber = "00-00-0"; + } catch (Exception e) { + logger.error("error in inserting to database", e); + } finally { + try { + if (database.getStatement() != null) { + database.getStatement().close(); } - } - - /** {@inheritDoc} */ - @Override - public void createComponent(String component_name, double moles, double molesInPhase, - int compnumber) { - component_name = ComponentInterface.getComponentName(component_name); - componentName = component_name; - numberOfMoles = moles; - numberOfMolesInPhase = molesInPhase; - neqsim.util.database.NeqSimDataBase database = new neqsim.util.database.NeqSimDataBase(); - java.sql.ResultSet dataSet = null; - try { - if (!component_name.equals("default")) { - try { - if (NeqSimDataBase.createTemporaryTables()) { - dataSet = database.getResultSet( - ("SELECT * FROM comptemp WHERE name='" + component_name + "'")); - } else { - dataSet = database.getResultSet( - ("SELECT * FROM comp WHERE name='" + component_name + "'")); - } - dataSet.next(); - dataSet.getString("ID"); - // if(dataSet.isAfterLast()) dataSet.next(); - } catch (Exception e) { - try { - dataSet.close(); - // logger.info("no parameters in tempcomp -- trying comp.. " + - // component_name); - dataSet = database.getResultSet( - ("SELECT * FROM comp WHERE name='" + component_name + "'")); - dataSet.next(); - } catch (Exception e2) { - throw new RuntimeException(e2); - } - } - - setComponentType(dataSet.getString("comptype")); - setCASnumber(dataSet.getString("CASnumber")); - index = Integer.parseInt(dataSet.getString("compindex")); - setFormulae(dataSet.getString("FORMULA").trim()); // C - molarMass = Double.parseDouble(dataSet.getString("molarmass")) / 1000.0; // D - normalLiquidDensity = Double.parseDouble(dataSet.getString("liqdens")); // E - criticalTemperature = (Double.parseDouble(dataSet.getString("TC")) + 273.15); // F - criticalPressure = Double.parseDouble(dataSet.getString("PC")); // G - acentricFactor = Double.parseDouble(dataSet.getString("acsfact")); // J - criticalVolume = Double.parseDouble(dataSet.getString("critvol")); - criticalCompressibilityFactor = criticalPressure * criticalVolume - / ThermodynamicConstantsInterface.R / criticalTemperature / 10.0; - referenceEnthalpy = Double.parseDouble(dataSet.getString("Href")); - setCpA(dataSet.getDouble("CPA")); // R //S - setCpB(dataSet.getDouble("CPB")); // S - setCpC(dataSet.getDouble("CPC")); // T - setCpD(dataSet.getDouble("CPD")); - setCpE(dataSet.getDouble("CPE")); - - CpSolid[0] = Double.parseDouble(dataSet.getString("CPsolid1")); - CpSolid[1] = Double.parseDouble(dataSet.getString("CPsolid2")); - CpSolid[2] = Double.parseDouble(dataSet.getString("CPsolid3")); - CpSolid[3] = Double.parseDouble(dataSet.getString("CPsolid4")); - CpSolid[4] = Double.parseDouble(dataSet.getString("CPsolid5")); - - CpLiquid[0] = Double.parseDouble(dataSet.getString("CPliquid1")); - CpLiquid[1] = Double.parseDouble(dataSet.getString("CPliquid2")); - CpLiquid[2] = Double.parseDouble(dataSet.getString("CPliquid3")); - CpLiquid[3] = Double.parseDouble(dataSet.getString("CPliquid4")); - CpLiquid[4] = Double.parseDouble(dataSet.getString("CPliquid5")); - - antoineLiqVapPresType = dataSet.getString("AntoineVapPresLiqType"); - AntoineA = Double.parseDouble(dataSet.getString("ANTOINEA")); // AY - AntoineB = Double.parseDouble(dataSet.getString("ANTOINEB")); // AZ - AntoineC = Double.parseDouble(dataSet.getString("ANTOINEC")); // AX - AntoineD = Double.parseDouble(dataSet.getString("ANTOINED")); - AntoineE = Double.parseDouble(dataSet.getString("ANTOINEE")); - - if (AntoineA == 0) { - AntoineA = 1.0; - AntoineB = getNormalBoilingPoint(); - } - - AntoineASolid = Double.parseDouble(dataSet.getString("ANTOINESolidA")); - AntoineBSolid = Double.parseDouble(dataSet.getString("ANTOINESolidB")); - AntoineCSolid = Double.parseDouble(dataSet.getString("ANTOINESolidC")); - - debyeDipoleMoment = Double.parseDouble(dataSet.getString("dipolemoment")); - normalBoilingPoint = Double.parseDouble(dataSet.getString("normboil")); - standardDensity = Double.parseDouble(dataSet.getString("stddens")); - viscosityCorrectionFactor = Double.parseDouble(dataSet.getString("viscfact")); // BC - racketZ = Double.parseDouble(dataSet.getString("racketZ")); // BE - lennardJonesMolecularDiameter = Double.parseDouble(dataSet.getString("LJdiameter")); // BF - lennardJonesEnergyParameter = Double.parseDouble(dataSet.getString("LJeps")); - sphericalCoreRadius = Double.parseDouble(dataSet.getString("SphericalCoreRadius")); - liquidViscosityModel = Integer.parseInt(dataSet.getString("liqviscmodel")); - liquidViscosityParameter[0] = Double.parseDouble(dataSet.getString("liqvisc1")); - liquidViscosityParameter[1] = Double.parseDouble(dataSet.getString("liqvisc2")); - liquidViscosityParameter[2] = Double.parseDouble(dataSet.getString("liqvisc3")); - liquidViscosityParameter[3] = Double.parseDouble(dataSet.getString("liqvisc4")); - - gibbsEnergyOfFormation = - Double.parseDouble(dataSet.getString("gibbsEnergyOfFormation")); - dielectricParameter[0] = - Double.parseDouble(dataSet.getString("dielectricParameter1")); - dielectricParameter[1] = - Double.parseDouble(dataSet.getString("dielectricParameter2")); - dielectricParameter[2] = - Double.parseDouble(dataSet.getString("dielectricParameter3")); - dielectricParameter[3] = - Double.parseDouble(dataSet.getString("dielectricParameter4")); - dielectricParameter[4] = - Double.parseDouble(dataSet.getString("dielectricParameter5")); - - ionicCharge = Integer.parseInt(dataSet.getString("ionicCharge")); - - referenceStateType = dataSet.getString("referenceStateType").trim(); - henryCoefParameter[0] = Double.parseDouble(dataSet.getString("HenryCoef1")); - henryCoefParameter[1] = Double.parseDouble(dataSet.getString("HenryCoef2")); - henryCoefParameter[2] = Double.parseDouble(dataSet.getString("HenryCoef3")); - henryCoefParameter[3] = Double.parseDouble(dataSet.getString("HenryCoef4")); - - schwartzentruberParams[0] = - Double.parseDouble(dataSet.getString("schwartzentruber1")); - schwartzentruberParams[1] = - Double.parseDouble(dataSet.getString("schwartzentruber2")); - schwartzentruberParams[2] = - Double.parseDouble(dataSet.getString("schwartzentruber3")); - - matiascopemanParams[0] = Double.parseDouble(dataSet.getString("MC1")); - matiascopemanParams[1] = Double.parseDouble(dataSet.getString("MC2")); - matiascopemanParams[2] = Double.parseDouble(dataSet.getString("MC3")); - - matiascopemanParamsPR[0] = Double.parseDouble(dataSet.getString("MCPR1")); - matiascopemanParamsPR[1] = Double.parseDouble(dataSet.getString("MCPR2")); - matiascopemanParamsPR[2] = Double.parseDouble(dataSet.getString("MCPR3")); - - matiascopemanSolidParams[0] = Double.parseDouble(dataSet.getString("MC1Solid")); - matiascopemanSolidParams[1] = Double.parseDouble(dataSet.getString("MC2Solid")); - matiascopemanSolidParams[2] = Double.parseDouble(dataSet.getString("MC3Solid")); - - TwuCoonParams[0] = Double.parseDouble(dataSet.getString("TwuCoon1")); - TwuCoonParams[1] = Double.parseDouble(dataSet.getString("TwuCoon2")); - TwuCoonParams[2] = Double.parseDouble(dataSet.getString("TwuCoon3")); - - liquidConductivityParameter[0] = - Double.parseDouble(dataSet.getString("liquidConductivity1")); - liquidConductivityParameter[1] = - Double.parseDouble(dataSet.getString("liquidConductivity2")); - liquidConductivityParameter[2] = - Double.parseDouble(dataSet.getString("liquidConductivity3")); - - if (this.getClass().getName().equals("neqsim.thermo.component.ComponentSrkCPA") - || this.getClass().getName() - .equals("neqsim.thermo.component.ComponentSrkCPAs")) { - parachorParameter = Double.parseDouble(dataSet.getString("PARACHOR_CPA")); - } else { - parachorParameter = Double.parseDouble(dataSet.getString("parachor")); - } - - setHeatOfFusion(Double.parseDouble(dataSet.getString("heatOfFusion"))); - - triplePointDensity = Double.parseDouble(dataSet.getString("triplePointDensity")); - triplePointPressure = Double.parseDouble(dataSet.getString("triplePointPressure")); - setTriplePointTemperature( - Double.parseDouble(dataSet.getString("triplePointTemperature"))); - meltingPointTemperature = - Double.parseDouble(dataSet.getString("meltingPointTemperature")); - - Hsub = Double.parseDouble(dataSet.getString("Hsub")); - - setIdealGasEnthalpyOfFormation( - Double.parseDouble(dataSet.getString("EnthalpyOfFormation"))); - idealGasGibsEnergyOfFormation = gibbsEnergyOfFormation; - idealGasAbsoluteEntropy = Double.parseDouble(dataSet.getString("AbsoluteEntropy")); - - for (int i = 0; i < 5; i++) { - solidDensityCoefs[i] = - Double.parseDouble((dataSet.getString("solidDensityCoefs" + (i + 1)))); - } - for (int i = 0; i < 5; i++) { - liquidDensityCoefs[i] = - Double.parseDouble((dataSet.getString("liquidDensityCoefs" + (i + 1)))); - } - for (int i = 0; i < 5; i++) { - heatOfVaporizationCoefs[i] = Double - .parseDouble((dataSet.getString("heatOfVaporizationCoefs" + (i + 1)))); - } - // disse maa settes inn fra database ssociationsites - numberOfAssociationSites = Integer.parseInt(dataSet.getString("associationsites")); - orginalNumberOfAssociationSites = numberOfAssociationSites; - associationScheme = dataSet.getString("associationscheme"); - associationEnergy = Double.parseDouble(dataSet.getString("associationenergy")); - - calcActivity = Integer.parseInt(dataSet.getString("calcActivity")); - setRacketZCPA(Double.parseDouble(dataSet.getString("racketZCPA"))); - - setVolumeCorrectionT_CPA(Double.parseDouble(dataSet.getString("volcorrCPA_T"))); - volumeCorrectionT = Double.parseDouble(dataSet.getString("volcorrSRK_T")); - - if (this.getClass().getName().equals("neqsim.thermo.component.ComponentPrCPA")) { - // System.out.println("pr-cpa"); - associationVolume = - Double.parseDouble(dataSet.getString("associationboundingvolume_PR")); - aCPA = Double.parseDouble(dataSet.getString("aCPA_PR")); - bCPA = Double.parseDouble(dataSet.getString("bCPA_PR")); - mCPA = Double.parseDouble(dataSet.getString("mCPA_PR")); - } else { - // System.out.println("srk-cpa"); - associationVolume = - Double.parseDouble(dataSet.getString("associationboundingvolume_SRK")); - aCPA = Double.parseDouble(dataSet.getString("aCPA_SRK")); - bCPA = Double.parseDouble(dataSet.getString("bCPA_SRK")); - mCPA = Double.parseDouble(dataSet.getString("mCPA_SRK")); - } - - criticalViscosity = Double.parseDouble(dataSet.getString("criticalViscosity")); - if (criticalViscosity < 1e-20) { - criticalViscosity = 7.94830 * Math.sqrt(1e3 * molarMass) - * Math.pow(criticalPressure, 2.0 / 3.0) - / Math.pow(criticalTemperature, 1.0 / 6.0) * 1e-7; - } - mSAFTi = Double.parseDouble(dataSet.getString("mSAFT")); - sigmaSAFTi = Double.parseDouble(dataSet.getString("sigmaSAFT")) / 1.0e10; - epsikSAFT = Double.parseDouble(dataSet.getString("epsikSAFT")); - setAssociationVolumeSAFT( - Double.parseDouble(dataSet.getString("associationboundingvolume_PCSAFT"))); - setAssociationEnergySAFT( - Double.parseDouble(dataSet.getString("associationenergy_PCSAFT"))); - if (Math.abs(criticalViscosity) < 1e-12) { - criticalViscosity = 7.94830 * Math.sqrt(molarMass * 1e3) - * Math.pow(criticalPressure, 2.0 / 3.0) - / Math.pow(criticalTemperature, 1.0 / 6.0) * 1e-7; - } - // System.out.println("crit visc " + criticalViscosity); - if (normalLiquidDensity == 0) { - normalLiquidDensity = - molarMass / (0.285 * Math.pow(criticalVolume, 1.048)) * 1000.0; - } - if (dataSet.getString("HydrateFormer").equals("yes")) { - setIsHydrateFormer(true); - } else { - setIsHydrateFormer(false); - } - - waxFormer = Integer.parseInt(dataSet.getString("waxformer")) == 1; - // System.out.println(componentName + " pure component parameters: ok..."); - } - componentNumber = compnumber; - } catch (Exception e) { - logger.error("error in comp", e); - } finally { - try { - if (dataSet != null) { - dataSet.close(); - } - if (database.getStatement() != null) { - database.getStatement().close(); - } - if (database.getConnection() != null) { - database.getConnection().close(); - } - } catch (Exception e) { - logger.error("error closing database.....", e); - } + if (database.getConnection() != null) { + database.getConnection().close(); } - - srkacentricFactor = acentricFactor; - stokesCationicDiameter = lennardJonesMolecularDiameter; - paulingAnionicDiameter = lennardJonesMolecularDiameter; - } - - /** {@inheritDoc} */ - @Override - public Component clone() { - Component clonedComponent = null; + } catch (Exception e) { + logger.error("error closing database.....", e); + } + } + } + + /** {@inheritDoc} */ + @Override + public void createComponent(String component_name, double moles, double molesInPhase, + int compnumber) { + component_name = ComponentInterface.getComponentName(component_name); + componentName = component_name; + numberOfMoles = moles; + numberOfMolesInPhase = molesInPhase; + neqsim.util.database.NeqSimDataBase database = new neqsim.util.database.NeqSimDataBase(); + java.sql.ResultSet dataSet = null; + try { + if (!component_name.equals("default")) { try { - clonedComponent = (Component) super.clone(); + if (NeqSimDataBase.createTemporaryTables()) { + dataSet = database + .getResultSet(("SELECT * FROM comptemp WHERE name='" + component_name + "'")); + } else { + dataSet = + database.getResultSet(("SELECT * FROM comp WHERE name='" + component_name + "'")); + } + dataSet.next(); + dataSet.getString("ID"); + // if(dataSet.isAfterLast()) dataSet.next(); } catch (Exception e) { - logger.error("Cloning failed.", e); + try { + dataSet.close(); + // logger.info("no parameters in tempcomp -- trying comp.. " + + // component_name); + dataSet = + database.getResultSet(("SELECT * FROM comp WHERE name='" + component_name + "'")); + dataSet.next(); + } catch (Exception e2) { + throw new RuntimeException(e2); + } } - return clonedComponent; - } - - /** {@inheritDoc} */ - @Override - public void addMolesChemReac(double dn) { - numberOfMoles += dn; - numberOfMolesInPhase += dn; - if (numberOfMoles < 0) { - numberOfMoles = 0; - } - if (numberOfMolesInPhase < 0) { - numberOfMolesInPhase = 0; + setComponentType(dataSet.getString("comptype")); + setCASnumber(dataSet.getString("CASnumber")); + index = Integer.parseInt(dataSet.getString("compindex")); + setFormulae(dataSet.getString("FORMULA").trim()); // C + molarMass = Double.parseDouble(dataSet.getString("molarmass")) / 1000.0; // D + normalLiquidDensity = Double.parseDouble(dataSet.getString("liqdens")); // E + criticalTemperature = (Double.parseDouble(dataSet.getString("TC")) + 273.15); // F + criticalPressure = Double.parseDouble(dataSet.getString("PC")); // G + acentricFactor = Double.parseDouble(dataSet.getString("acsfact")); // J + criticalVolume = Double.parseDouble(dataSet.getString("critvol")); + criticalCompressibilityFactor = criticalPressure * criticalVolume + / ThermodynamicConstantsInterface.R / criticalTemperature / 10.0; + referenceEnthalpy = Double.parseDouble(dataSet.getString("Href")); + setCpA(dataSet.getDouble("CPA")); // R //S + setCpB(dataSet.getDouble("CPB")); // S + setCpC(dataSet.getDouble("CPC")); // T + setCpD(dataSet.getDouble("CPD")); + setCpE(dataSet.getDouble("CPE")); + + CpSolid[0] = Double.parseDouble(dataSet.getString("CPsolid1")); + CpSolid[1] = Double.parseDouble(dataSet.getString("CPsolid2")); + CpSolid[2] = Double.parseDouble(dataSet.getString("CPsolid3")); + CpSolid[3] = Double.parseDouble(dataSet.getString("CPsolid4")); + CpSolid[4] = Double.parseDouble(dataSet.getString("CPsolid5")); + + CpLiquid[0] = Double.parseDouble(dataSet.getString("CPliquid1")); + CpLiquid[1] = Double.parseDouble(dataSet.getString("CPliquid2")); + CpLiquid[2] = Double.parseDouble(dataSet.getString("CPliquid3")); + CpLiquid[3] = Double.parseDouble(dataSet.getString("CPliquid4")); + CpLiquid[4] = Double.parseDouble(dataSet.getString("CPliquid5")); + + antoineLiqVapPresType = dataSet.getString("AntoineVapPresLiqType"); + AntoineA = Double.parseDouble(dataSet.getString("ANTOINEA")); // AY + AntoineB = Double.parseDouble(dataSet.getString("ANTOINEB")); // AZ + AntoineC = Double.parseDouble(dataSet.getString("ANTOINEC")); // AX + AntoineD = Double.parseDouble(dataSet.getString("ANTOINED")); + AntoineE = Double.parseDouble(dataSet.getString("ANTOINEE")); + + if (AntoineA == 0) { + AntoineA = 1.0; + AntoineB = getNormalBoilingPoint(); } - } - - /** {@inheritDoc} */ - @Override - public void addMolesChemReac(double dn, double totdn) { - numberOfMoles += totdn; - if (numberOfMoles < 0) { - numberOfMoles = 0; + AntoineASolid = Double.parseDouble(dataSet.getString("ANTOINESolidA")); + AntoineBSolid = Double.parseDouble(dataSet.getString("ANTOINESolidB")); + AntoineCSolid = Double.parseDouble(dataSet.getString("ANTOINESolidC")); + + debyeDipoleMoment = Double.parseDouble(dataSet.getString("dipolemoment")); + normalBoilingPoint = Double.parseDouble(dataSet.getString("normboil")); + standardDensity = Double.parseDouble(dataSet.getString("stddens")); + viscosityCorrectionFactor = Double.parseDouble(dataSet.getString("viscfact")); // BC + racketZ = Double.parseDouble(dataSet.getString("racketZ")); // BE + lennardJonesMolecularDiameter = Double.parseDouble(dataSet.getString("LJdiameter")); // BF + lennardJonesEnergyParameter = Double.parseDouble(dataSet.getString("LJeps")); + sphericalCoreRadius = Double.parseDouble(dataSet.getString("SphericalCoreRadius")); + liquidViscosityModel = Integer.parseInt(dataSet.getString("liqviscmodel")); + liquidViscosityParameter[0] = Double.parseDouble(dataSet.getString("liqvisc1")); + liquidViscosityParameter[1] = Double.parseDouble(dataSet.getString("liqvisc2")); + liquidViscosityParameter[2] = Double.parseDouble(dataSet.getString("liqvisc3")); + liquidViscosityParameter[3] = Double.parseDouble(dataSet.getString("liqvisc4")); + + gibbsEnergyOfFormation = Double.parseDouble(dataSet.getString("gibbsEnergyOfFormation")); + dielectricParameter[0] = Double.parseDouble(dataSet.getString("dielectricParameter1")); + dielectricParameter[1] = Double.parseDouble(dataSet.getString("dielectricParameter2")); + dielectricParameter[2] = Double.parseDouble(dataSet.getString("dielectricParameter3")); + dielectricParameter[3] = Double.parseDouble(dataSet.getString("dielectricParameter4")); + dielectricParameter[4] = Double.parseDouble(dataSet.getString("dielectricParameter5")); + + ionicCharge = Integer.parseInt(dataSet.getString("ionicCharge")); + + referenceStateType = dataSet.getString("referenceStateType").trim(); + henryCoefParameter[0] = Double.parseDouble(dataSet.getString("HenryCoef1")); + henryCoefParameter[1] = Double.parseDouble(dataSet.getString("HenryCoef2")); + henryCoefParameter[2] = Double.parseDouble(dataSet.getString("HenryCoef3")); + henryCoefParameter[3] = Double.parseDouble(dataSet.getString("HenryCoef4")); + + schwartzentruberParams[0] = Double.parseDouble(dataSet.getString("schwartzentruber1")); + schwartzentruberParams[1] = Double.parseDouble(dataSet.getString("schwartzentruber2")); + schwartzentruberParams[2] = Double.parseDouble(dataSet.getString("schwartzentruber3")); + + matiascopemanParams[0] = Double.parseDouble(dataSet.getString("MC1")); + matiascopemanParams[1] = Double.parseDouble(dataSet.getString("MC2")); + matiascopemanParams[2] = Double.parseDouble(dataSet.getString("MC3")); + + matiascopemanParamsPR[0] = Double.parseDouble(dataSet.getString("MCPR1")); + matiascopemanParamsPR[1] = Double.parseDouble(dataSet.getString("MCPR2")); + matiascopemanParamsPR[2] = Double.parseDouble(dataSet.getString("MCPR3")); + + matiascopemanParamsUMRPRU[0] = Double.parseDouble(dataSet.getString("MCPR1")); + matiascopemanParamsUMRPRU[1] = Double.parseDouble(dataSet.getString("MCPR2")); + matiascopemanParamsUMRPRU[2] = Double.parseDouble(dataSet.getString("MCPR3")); + matiascopemanParamsUMRPRU[3] = 0.0; + matiascopemanParamsUMRPRU[4] = 0.0; + + matiascopemanSolidParams[0] = Double.parseDouble(dataSet.getString("MC1Solid")); + matiascopemanSolidParams[1] = Double.parseDouble(dataSet.getString("MC2Solid")); + matiascopemanSolidParams[2] = Double.parseDouble(dataSet.getString("MC3Solid")); + + TwuCoonParams[0] = Double.parseDouble(dataSet.getString("TwuCoon1")); + TwuCoonParams[1] = Double.parseDouble(dataSet.getString("TwuCoon2")); + TwuCoonParams[2] = Double.parseDouble(dataSet.getString("TwuCoon3")); + + liquidConductivityParameter[0] = + Double.parseDouble(dataSet.getString("liquidConductivity1")); + liquidConductivityParameter[1] = + Double.parseDouble(dataSet.getString("liquidConductivity2")); + liquidConductivityParameter[2] = + Double.parseDouble(dataSet.getString("liquidConductivity3")); + + if (this.getClass().getName().equals("neqsim.thermo.component.ComponentSrkCPA") + || this.getClass().getName().equals("neqsim.thermo.component.ComponentSrkCPAs")) { + parachorParameter = Double.parseDouble(dataSet.getString("PARACHOR_CPA")); + } else { + parachorParameter = Double.parseDouble(dataSet.getString("parachor")); } - numberOfMolesInPhase += dn; - if (numberOfMolesInPhase < 0) { - numberOfMolesInPhase = 0; - } - } + setHeatOfFusion(Double.parseDouble(dataSet.getString("heatOfFusion"))); - /** {@inheritDoc} */ - @Override - public void addMoles(double dn) { - numberOfMolesInPhase += dn; - if (numberOfMolesInPhase < 0) { - numberOfMolesInPhase = 0; - } - } + triplePointDensity = Double.parseDouble(dataSet.getString("triplePointDensity")); + triplePointPressure = Double.parseDouble(dataSet.getString("triplePointPressure")); + setTriplePointTemperature(Double.parseDouble(dataSet.getString("triplePointTemperature"))); + meltingPointTemperature = Double.parseDouble(dataSet.getString("meltingPointTemperature")); - /** {@inheritDoc} */ - @Override - public void setProperties(ComponentInterface component) { - x = component.getx(); - z = component.getz(); - numberOfMolesInPhase = component.getNumberOfMolesInPhase(); - numberOfMoles = component.getNumberOfmoles(); - K = component.getK(); - } + Hsub = Double.parseDouble(dataSet.getString("Hsub")); - /** {@inheritDoc} */ - @Override - public void init(double temperature, double pressure, double totalNumberOfMoles, double beta, - int type) { + setIdealGasEnthalpyOfFormation( + Double.parseDouble(dataSet.getString("EnthalpyOfFormation"))); + idealGasGibsEnergyOfFormation = gibbsEnergyOfFormation; + idealGasAbsoluteEntropy = Double.parseDouble(dataSet.getString("AbsoluteEntropy")); - if (totalNumberOfMoles == 0) { - throw new RuntimeException(new neqsim.util.exception.InvalidInputException(this, "init", - "totalNumberOfMoles", "must be larger than 0")); + for (int i = 0; i < 5; i++) { + solidDensityCoefs[i] = + Double.parseDouble((dataSet.getString("solidDensityCoefs" + (i + 1)))); } - if (type == 0) { - K = Math.exp(Math.log(criticalPressure / pressure) + 5.373 * (1.0 + srkacentricFactor) - * (1.0 - criticalTemperature / temperature)); - z = numberOfMoles / totalNumberOfMoles; - x = z; - // System.out.println("K " + K); + for (int i = 0; i < 5; i++) { + liquidDensityCoefs[i] = + Double.parseDouble((dataSet.getString("liquidDensityCoefs" + (i + 1)))); } - numberOfMolesInPhase = totalNumberOfMoles * x * beta; - numberOfMoles = totalNumberOfMoles * z; // added late by Even 22/10-06 - z = numberOfMoles / totalNumberOfMoles; - } - - /** {@inheritDoc} */ - @Override - public Element getElements() { - if (elements == null) { - elements = new Element(componentName); + for (int i = 0; i < 5; i++) { + heatOfVaporizationCoefs[i] = + Double.parseDouble((dataSet.getString("heatOfVaporizationCoefs" + (i + 1)))); } - return elements; - } - - /** {@inheritDoc} */ - @Override - public void Finit(PhaseInterface phase, double temp, double pres, double totMoles, double beta, - int numberOfComponents, int type) {} - - /** {@inheritDoc} */ - @Override - public final double getx() { - return x; - } - - /** {@inheritDoc} */ - @Override - public final double getz() { - return z; - } - - /** {@inheritDoc} */ - @Override - public final void setz(double z) { - this.z = z; - } - - /** {@inheritDoc} */ - @Override - public final double getReferencePotential() { - return referencePotential; - } - - /** {@inheritDoc} */ - @Override - public final void setReferencePotential(double ref) { - this.referencePotential = ref; - } - - /** {@inheritDoc} */ - @Override - public final double getK() { - return K; - } - - /** {@inheritDoc} */ - @Override - public final double getHeatOfFusion() { - return heatOfFusion; - } - - /** {@inheritDoc} */ - @Override - public double getHeatOfVapourization(double temp) { - return heatOfVaporizationCoefs[0] + heatOfVaporizationCoefs[1] * temp - + heatOfVaporizationCoefs[2] * temp * temp + heatOfVaporizationCoefs[3] * temp - * temp * temp * heatOfVaporizationCoefs[4] * temp * temp * temp * temp; // maa - // settes - // paa - // rett - // form - } - - /** {@inheritDoc} */ - @Override - public final double getTripplePointDensity() { - return triplePointDensity; - } - - /** {@inheritDoc} */ - @Override - public final double getTriplePointPressure() { - return triplePointPressure; - } - - /** {@inheritDoc} */ - @Override - public final double getTriplePointTemperature() { - return triplePointTemperature; - } - - /** {@inheritDoc} */ - @Override - public final double getMeltingPointTemperature() { - return meltingPointTemperature; - } - - /** {@inheritDoc} */ - @Override - public final double getIdealGasEnthalpyOfFormation() { - return idealGasEnthalpyOfFormation; - } - - /** {@inheritDoc} */ - @Override - public final double getIdealGasGibsEnergyOfFormation() { - return idealGasGibsEnergyOfFormation; - } - - /** {@inheritDoc} */ - @Override - public final double getIdealGasAbsoluteEntropy() { - return idealGasAbsoluteEntropy; - } - - /** {@inheritDoc} */ - @Override - public final double getTC() { - return criticalTemperature; - } - - /** {@inheritDoc} */ - @Override - public final void setTC(double val) { - criticalTemperature = val; - } - - /** {@inheritDoc} */ - @Override - public final void setPC(double val) { - criticalPressure = val; - } - - /** {@inheritDoc} */ - @Override - public final String getComponentName() { - return componentName; - } - - /** {@inheritDoc} */ - @Override - public final String getReferenceStateType() { - return referenceStateType; - } - - /** {@inheritDoc} */ - @Override - public final double getPC() { - return criticalPressure; - } - - /** {@inheritDoc} */ - @Override - public double getGibbsEnergyOfFormation() { - return gibbsEnergyOfFormation; - } - - /** {@inheritDoc} */ - @Override - public double getDiElectricConstant(double temperature) { - return dielectricParameter[0] + dielectricParameter[1] / temperature - + dielectricParameter[2] * temperature - + dielectricParameter[3] * temperature * temperature - + dielectricParameter[4] * Math.pow(temperature, 3.0); - } - - /** {@inheritDoc} */ - @Override - public double getDiElectricConstantdT(double temperature) { - return -dielectricParameter[1] / Math.pow(temperature, 2.0) + dielectricParameter[2] - + 2.0 * dielectricParameter[3] * temperature - + 3.0 * dielectricParameter[4] * Math.pow(temperature, 2.0); - } - - /** {@inheritDoc} */ - @Override - public double getDiElectricConstantdTdT(double temperature) { - return 2.0 * dielectricParameter[1] / Math.pow(temperature, 3.0) - + 2.0 * dielectricParameter[3] - + 6.0 * dielectricParameter[4] * Math.pow(temperature, 1.0); - } - - /** {@inheritDoc} */ - @Override - public double getDebyeDipoleMoment() { - return debyeDipoleMoment; - } - - /** {@inheritDoc} */ - @Override - public final double getIonicCharge() { - return ionicCharge; - } - - /** {@inheritDoc} */ - @Override - public final void setViscosityAssociationFactor(double val) { - viscosityCorrectionFactor = val; - } - - /** {@inheritDoc} */ - @Override - public final double getRacketZ() { - return racketZ; - } - - /** {@inheritDoc} */ - @Override - public double getVolumeCorrectionConst() { - return volumeCorrectionConst; - } - - /** {@inheritDoc} */ - @Override - public double getNormalLiquidDensity() { - return normalLiquidDensity; - } - - /** {@inheritDoc} */ - @Override - public double getViscosityCorrectionFactor() { - return viscosityCorrectionFactor; - } - - /** {@inheritDoc} */ - @Override - public double getCriticalVolume() { - return criticalVolume; - } - - /** {@inheritDoc} */ - @Override - public final int getLiquidViscosityModel() { - return liquidViscosityModel; - } - - /** {@inheritDoc} */ - @Override - public final double getParachorParameter() { - return parachorParameter; - } - - /** {@inheritDoc} */ - @Override - public final void setParachorParameter(double parachorParameter) { - this.parachorParameter = parachorParameter; - } - - /** {@inheritDoc} */ - @Override - public final void setLiquidViscosityModel(int modelNumber) { - liquidViscosityModel = modelNumber; - } - - /** {@inheritDoc} */ - @Override - public final void setLiquidViscosityParameter(double number, int i) { - liquidViscosityParameter[i] = number; - } - - /** {@inheritDoc} */ - @Override - public final double getLiquidViscosityParameter(int i) { - return liquidViscosityParameter[i]; - } - - /** {@inheritDoc} */ - @Override - public void setLiquidConductivityParameter(double number, int i) { - liquidConductivityParameter[i] = number; - } - - /** {@inheritDoc} */ - @Override - public double getLiquidConductivityParameter(int i) { - return liquidConductivityParameter[i]; - } - - /** - * {@inheritDoc} - * - * Units in m*e10 - */ - @Override - public double getLennardJonesMolecularDiameter() { - return lennardJonesMolecularDiameter; - } - - /** {@inheritDoc} */ - @Override - public double getLennardJonesEnergyParameter() { - return lennardJonesEnergyParameter; - } - - /** {@inheritDoc} */ - @Override - public double getHsub() { - return Hsub; - } - - /** - * {@inheritDoc} - * - * Calculates the pure comonent solid vapor pressure (bar) with the C-C equation, based on Hsub - * Should only be used in the valid temperature range below the triple point (specified in - * component database). - */ - @Override - public double getCCsolidVaporPressure(double temperature) { - return triplePointPressure - * (Math.exp(Hsub / R * (1.0 / getTriplePointTemperature() - 1.0 / temperature))); - } - - /** - * {@inheritDoc} - * - * Calculates the DT of pure comonent solid vapor pressure (bar) with the C-C equation, based on - * Hsub Should only be used in the valid temperature range below the triple point (specified in - * component database). - */ - @Override - public double getCCsolidVaporPressuredT(double temperature) { - return triplePointPressure * Hsub / R * (1.0 / (temperature * temperature)) - * (Math.exp(Hsub / R * (1.0 / getTriplePointTemperature() - 1.0 / temperature))); - } - - /** - * {@inheritDoc} - * - * Calculates the pure component solid density in kg/liter Should only be used in the valid - * temperature range (specified in component database). - */ - @Override - public double getPureComponentSolidDensity(double temperature) { - return molarMass * 1000.0 - * (solidDensityCoefs[0] + solidDensityCoefs[1] * Math.pow(temperature, 1.0) - + solidDensityCoefs[2] * Math.pow(temperature, 2.0) - + solidDensityCoefs[3] * Math.pow(temperature, 3.0) - + solidDensityCoefs[4] * Math.pow(temperature, 4.0)); - } - - /** - * {@inheritDoc} - * - * Calculates the pure component liquid density in kg/liter Should only be used in the valid - * temperature range (specified in component database). This method seems to give bad results at - * the moment - */ - @Override - public double getPureComponentLiquidDensity(double temperature) { - return molarMass * 1000.0 - * (liquidDensityCoefs[0] + liquidDensityCoefs[1] * Math.pow(temperature, 1.0) - + liquidDensityCoefs[2] * Math.pow(temperature, 2.0) - + liquidDensityCoefs[3] * Math.pow(temperature, 3.0) - + liquidDensityCoefs[4] * Math.pow(temperature, 4.0)); - // return Math.pow(liquidDensityCoefs[0] / liquidDensityCoefs[1], 1.0 + - // Math.pow(1.0 - temperature / liquidDensityCoefs[2], liquidDensityCoefs[3])); - } - - /** - * {@inheritDoc} - * - * Calculates the pure comonent heat of vaporization in J/mol - */ - @Override - public double getPureComponentHeatOfVaporization(double temperature) { - return 1.0e-3 * heatOfVaporizationCoefs[0] - * Math.pow((1.0 - temperature / criticalTemperature), - heatOfVaporizationCoefs[1] - + heatOfVaporizationCoefs[2] * temperature / criticalTemperature - + heatOfVaporizationCoefs[3] - * Math.pow(temperature / criticalTemperature, 2.0)); - } - - /** {@inheritDoc} */ - @Override - public final void setx(double newx) { - if (Double.isNaN(newx) || Double.isInfinite(newx)) { - return; - } - if (newx < 0) { - x = 1.0e-50; - } - if (newx > 0) { - x = newx; - } - if (newx > 5) { - x = 5; - } - } - - /** {@inheritDoc} */ - @Override - public final void setNumberOfmoles(double newmoles) { - numberOfMoles = newmoles; - } - - /** {@inheritDoc} */ - @Override - public final void setNumberOfMolesInPhase(double totmoles) { - numberOfMolesInPhase = totmoles * x; - } - - /** {@inheritDoc} */ - @Override - public final double getNumberOfmoles() { - return this.numberOfMoles; - } - - /** {@inheritDoc} */ - @Override - public final double getMolarMass() { - return this.molarMass; - } - - /** {@inheritDoc} */ - @Override - public final double getNumberOfMolesInPhase() { - return this.numberOfMolesInPhase; - } - - /** {@inheritDoc} */ - @Override - public double getRate(String unitName) { - neqsim.util.unit.Unit unit = new neqsim.util.unit.RateUnit(numberOfMolesInPhase, "mol/sec", - molarMass, normalLiquidDensity, normalBoilingPoint); - double val = unit.getValue(unitName); - return val; - } - - /** {@inheritDoc} */ - @Override - public final void setK(double newK) { - K = newK; - } - - /** {@inheritDoc} */ - @Override - public final double getFugacityCoefficient() { - return fugacityCoefficient; - } - - /** {@inheritDoc} */ - @Override - public double fugcoef(PhaseInterface phase) { - fugacityCoefficient = 1.0;// this.fugcoef(phase, phase.getNumberOfComponents(), - // phase.getTemperature(), - // phase.getPressure()); - logFugacityCoefficient = Math.log(fugacityCoefficient); - return fugacityCoefficient; - } - - /** {@inheritDoc} */ - @Override - public double logfugcoefdT(PhaseInterface phase) { - dfugdt = 0.0;// this.fugcoefDiffTemp(phase, phase.getNumberOfComponents(), - // phase.getTemperature(), phase.getPressure()); - return dfugdt; - } - - /** {@inheritDoc} */ - @Override - public double logfugcoefdP(PhaseInterface phase) { - dfugdp = 0.0;// this.fugcoefDiffPres(phase, phase.getNumberOfComponents(), - // phase.getTemperature(), phase.getPressure()); - return dfugdp; - } - - /** {@inheritDoc} */ - @Override - public double[] logfugcoefdN(PhaseInterface phase) { - // dfugdn = this.fugcoefDiffN(phase, phase.getNumberOfComponents(), - // phase.getTemperature(), phase.getPressure()); - return new double[2]; - } - - /** {@inheritDoc} */ - @Override - public double logfugcoefdNi(PhaseInterface phase, int k) { - return 0.0; - } - - /** {@inheritDoc} */ - @Override - public double getdfugdt() { - return dfugdt; - } - - /** {@inheritDoc} */ - @Override - public double getdfugdp() { - return dfugdp; - } - - /** {@inheritDoc} */ - @Override - public void setdfugdt(double val) { - dfugdt = val; - } - - /** {@inheritDoc} */ - @Override - public void setdfugdp(double val) { - dfugdp = val; - } - - /** {@inheritDoc} */ - @Override - public void setdfugdn(int i, double val) { - dfugdn[i] = val; - } - - /** {@inheritDoc} */ - @Override - public void setdfugdx(int i, double val) { - dfugdx[i] = val; - } - - /** {@inheritDoc} */ - @Override - public double getAcentricFactor() { - return acentricFactor; - } - - /** {@inheritDoc} */ - @Override - public double getdfugdx(int i) { - return dfugdx[i]; - } - - /** {@inheritDoc} */ - @Override - public double getdfugdn(int i) { - return dfugdn[i]; - } - - /** {@inheritDoc} */ - @Override - public int getIndex() { - return index; - } - - /** {@inheritDoc} */ - @Override - public int getComponentNumber() { - return componentNumber; - } - - /** {@inheritDoc} */ - @Override - public final double getGibbsEnergy(double temperature, double pressure) { - return getEnthalpy(temperature) - temperature * getEntropy(temperature, pressure); - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialIdealReference(PhaseInterface phase) { - return (getHID(phase.getTemperature()) - - phase.getTemperature() * getIdEntropy(phase.getTemperature())); - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotential(double temperature, double pressure) { - return getGibbsEnergy(temperature, pressure) / numberOfMolesInPhase; - } - - /** {@inheritDoc} */ - @Override - public double getChemicalPotential(PhaseInterface phase) { - return getGibbsEnergy(phase.getTemperature(), phase.getPressure()) / numberOfMolesInPhase; - // return getGresTV; - } - - /** - *

- * getFugacitydN. - *

- * - * @param i a int - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public final double getFugacitydN(int i, PhaseInterface phase) { - double tempFug = 0.0; - if (i == componentNumber) { - tempFug = 1.0 / getNumberOfMolesInPhase(); - } - return getdfugdn(i) + tempFug - 1.0 / phase.getNumberOfMolesInPhase(); - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialdNTV(int i, PhaseInterface phase) { - return getChemicalPotentialdN(i, phase) - - getVoli() * phase.getComponent(i).getVoli() * phase.getdPdVTn(); - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialdN(int i, PhaseInterface phase) { - return R * phase.getTemperature() * getFugacitydN(i, phase); - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialdP() { - return voli; - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialdT(PhaseInterface phase) { - return -getEntropy(phase.getTemperature(), phase.getPressure()) / numberOfMolesInPhase; - } - - /** {@inheritDoc} */ - @Override - public final double getChemicalPotentialdV(PhaseInterface phase) { - return getChemicalPotentialdP() * phase.getdPdVTn(); - } - - /** - *

- * getChemicalPotentialdP. - *

- * - * @param i a int - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public final double getChemicalPotentialdP(int i, PhaseInterface phase) { - return R * phase.getTemperature() * getFugacitydN(i, phase); - } - - /** {@inheritDoc} */ - @Override - public void setComponentNumber(int numb) { - componentNumber = numb; - } - - /** {@inheritDoc} */ - @Override - public double getAntoineVaporPressure(double temp) { - if (antoineLiqVapPresType.equals("pow10")) { - return Math.pow(10.0, AntoineA - (AntoineB / (temp + AntoineC - 273.15))); // equation - // and - // parameter - // from - // properties - // o liquids - // and - // gases - // (poling - // 5th ed) - } else if (antoineLiqVapPresType.equals("exp") || antoineLiqVapPresType.equals("log")) { - return Math.exp(AntoineA - (AntoineB / (temp + AntoineC))); // equation and parameter - // from properties o - // liquids and gases (poling - // 5th ed) - } else if (Math.abs(AntoineE) > 1e-12) { - return Math.exp(AntoineA + AntoineB / temp + AntoineC * Math.log(temp) - + AntoineD * Math.pow(temp, AntoineE)) / 100000; + // disse maa settes inn fra database ssociationsites + numberOfAssociationSites = Integer.parseInt(dataSet.getString("associationsites")); + orginalNumberOfAssociationSites = numberOfAssociationSites; + associationScheme = dataSet.getString("associationscheme"); + associationEnergy = Double.parseDouble(dataSet.getString("associationenergy")); + + calcActivity = Integer.parseInt(dataSet.getString("calcActivity")); + setRacketZCPA(Double.parseDouble(dataSet.getString("racketZCPA"))); + + setVolumeCorrectionT_CPA(Double.parseDouble(dataSet.getString("volcorrCPA_T"))); + volumeCorrectionT = Double.parseDouble(dataSet.getString("volcorrSRK_T")); + + if (this.getClass().getName().equals("neqsim.thermo.component.ComponentPrCPA")) { + // System.out.println("pr-cpa"); + associationVolume = Double.parseDouble(dataSet.getString("associationboundingvolume_PR")); + aCPA = Double.parseDouble(dataSet.getString("aCPA_PR")); + bCPA = Double.parseDouble(dataSet.getString("bCPA_PR")); + mCPA = Double.parseDouble(dataSet.getString("mCPA_PR")); } else { - double x = 1 - (temp / criticalTemperature); - return (Math - .exp(Math.pow((1 - x), -1) * (AntoineA * x + AntoineB * Math.pow(x, 1.5) - + AntoineC * Math.pow(x, 3) + AntoineD * Math.pow(x, 6))) - * criticalPressure); + // System.out.println("srk-cpa"); + associationVolume = + Double.parseDouble(dataSet.getString("associationboundingvolume_SRK")); + aCPA = Double.parseDouble(dataSet.getString("aCPA_SRK")); + bCPA = Double.parseDouble(dataSet.getString("bCPA_SRK")); + mCPA = Double.parseDouble(dataSet.getString("mCPA_SRK")); } - } - /** {@inheritDoc} */ - @Override - public double getAntoineVaporPressuredT(double temp) { - if (antoineLiqVapPresType.equals("pow10")) { - // (10^ (A - B/(C + x - 5463/20)) *B*log(10))/(C + x - 5463/20)^2 - double ans = (Math.pow(AntoineA - AntoineB / (AntoineC + temp - 273.15), 10.0) - * AntoineB * Math.log(10.0)) / Math.pow((AntoineC + temp - 273.15), 2.0); - return ans; - } else if (antoineLiqVapPresType.equals("exp") || antoineLiqVapPresType.equals("log")) { - // (B*exp(A - B/(C + x)))/(C + x)^2 - double ans = AntoineB * (Math.exp(AntoineA - AntoineB / (AntoineC + temp))) - / Math.pow((AntoineC + temp), 2.0); - return ans; - } else { - return 0.0; + criticalViscosity = Double.parseDouble(dataSet.getString("criticalViscosity")); + if (criticalViscosity < 1e-20) { + criticalViscosity = + 7.94830 * Math.sqrt(1e3 * molarMass) * Math.pow(criticalPressure, 2.0 / 3.0) + / Math.pow(criticalTemperature, 1.0 / 6.0) * 1e-7; } - } - - /** {@inheritDoc} */ - @Override - public double getAntoineVaporTemperature(double pres) { - double nyPres = 0, nyTemp = criticalTemperature * 0.7; - int iter = 0; - do { - iter++; - - nyPres = getAntoineVaporPressure(nyTemp); - nyTemp -= (nyPres - pres); - // nyTemp = nyTemp-(nyPres - pres)/getAntoineVaporPressuredT(nyTemp); - // System.out.println("temp Antoine " +nyTemp + " error "+Math.abs((nyPres - - // pres) / pres)); - } while (Math.abs((nyPres - pres) / pres) > 0.00001 && iter < 1000); - return nyTemp; - } - - /** {@inheritDoc} */ - @Override - public final double getHresTP(double temperature) { - return R * temperature * (-temperature * getdfugdt()); - } - - /** {@inheritDoc} */ - @Override - public final double getGresTP(double temperature) { - return R * temperature * (Math.log(getFugacityCoefficient())); - } - - /** {@inheritDoc} */ - @Override - public final double getSresTP(double temperature) { - return (getHresTP(temperature) - getGresTP(temperature)) / temperature; - } - - /** {@inheritDoc} */ - @Override - public final double getCp0(double temperature) { - return getCpA() + getCpB() * temperature + getCpC() * Math.pow(temperature, 2) - + getCpD() * Math.pow(temperature, 3) + getCpE() * Math.pow(temperature, 4); - } - - /** {@inheritDoc} */ - @Override - public final double getCv0(double temperature) { - return getCpA() + getCpB() * temperature + getCpC() * Math.pow(temperature, 2) - + getCpD() * Math.pow(temperature, 3) + getCpE() * Math.pow(temperature, 4) - R; - } - - // integralet av Cp0 mhp T - /** {@inheritDoc} */ - @Override - public final double getHID(double T) { - return 0 * getIdealGasEnthalpyOfFormation() - + (getCpA() * T + 1.0 / 2.0 * getCpB() * T * T + 1.0 / 3.0 * getCpC() * T * T * T - + 1.0 / 4.0 * getCpD() * T * T * T * T) - + 1.0 / 5.0 * getCpE() * T * T * T * T * T - - (getCpA() * referenceTemperature - + 1.0 / 2.0 * getCpB() * referenceTemperature * referenceTemperature - + 1.0 / 3.0 * getCpC() * referenceTemperature * referenceTemperature - * referenceTemperature - + 1.0 / 4.0 * getCpD() * referenceTemperature * referenceTemperature - * referenceTemperature * referenceTemperature - + 1.0 / 5.0 * getCpE() * referenceTemperature * referenceTemperature - * referenceTemperature * referenceTemperature - * referenceTemperature); - } - - /** {@inheritDoc} */ - @Override - public final double getEnthalpy(double temperature) { - return getHID(temperature) * numberOfMolesInPhase - + getHresTP(temperature) * numberOfMolesInPhase; - } - - /** {@inheritDoc} */ - @Override - public double getIdEntropy(double temperature) { - return (getCpE() * temperature * temperature * temperature * temperature / 4.0 - + getCpD() * temperature * temperature * temperature / 3.0 - + getCpC() * temperature * temperature / 2.0 + getCpB() * temperature - + getCpA() * Math.log(temperature) - - getCpE() * referenceTemperature * referenceTemperature * referenceTemperature - * referenceTemperature / 4.0 - - getCpD() * referenceTemperature * referenceTemperature * referenceTemperature - / 3.0 - - getCpC() * referenceTemperature * referenceTemperature / 2.0 - - getCpB() * referenceTemperature - getCpA() * Math.log(referenceTemperature)); - } - - /** {@inheritDoc} */ - @Override - public double getEntropy(double temperature, double pressure) { - if (x < 1e-100) { - return 0.0; - } - return numberOfMolesInPhase * (getIdEntropy(temperature) - - (R * Math.log(pressure / referencePressure)) - R * Math.log(x)) - + getSresTP(temperature) * numberOfMolesInPhase; // 1 bor vaere Z - } - - /** {@inheritDoc} */ - @Override - public final String getName() { - return componentName; - } - - /** {@inheritDoc} */ - @Override - public void setAcentricFactor(double val) { - acentricFactor = val; - getAttractiveTerm().init(); - } - - /** {@inheritDoc} */ - @Override - public void setRacketZ(double val) { - racketZ = val; - } - - /** {@inheritDoc} */ - @Override - public void setAttractiveTerm(int i) { - attractiveTermNumber = i; - } - - /** {@inheritDoc} */ - @Override - public AttractiveTermInterface getAttractiveTerm() { - return null; - } - - /** {@inheritDoc} */ - @Override - public final double[] getSchwartzentruberParams() { - return schwartzentruberParams; - } - - /** {@inheritDoc} */ - @Override - public final void setSchwartzentruberParams(int i, double param) { - schwartzentruberParams[i] = param; - } - - /** {@inheritDoc} */ - @Override - public final double[] getTwuCoonParams() { - return TwuCoonParams; - } - - /** {@inheritDoc} */ - @Override - public final void setTwuCoonParams(int i, double param) { - TwuCoonParams[i] = param; - } - - /** {@inheritDoc} */ - @Override - public double fugcoefDiffPresNumeric(PhaseInterface phase, int numberOfComponents, - double temperature, double pressure) { - double temp1 = 0.0, temp2 = 0.0; - double dp = phase.getPressure() / 1.0e5; - temp1 = phase.getComponents()[componentNumber].getFugacityCoefficient(); - phase.setPressure(phase.getPressure() - dp); - phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), - phase.getBeta()); - phase.getComponents()[componentNumber].fugcoef(phase); - temp2 = phase.getComponents()[componentNumber].getFugacityCoefficient(); - phase.setPressure(phase.getPressure() + dp); - phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), - phase.getBeta()); - phase.getComponents()[componentNumber].fugcoef(phase); - dfugdp = (Math.log(temp1) - Math.log(temp2)) / dp; - return dfugdp; - } - - /** {@inheritDoc} */ - @Override - public double fugcoefDiffTempNumeric(PhaseInterface phase, int numberOfComponents, - double temperature, double pressure) { - double temp1 = 0.0, temp2 = 0.0; - double dt = phase.getTemperature() / 1.0e6; - temp1 = phase.getComponents()[componentNumber].getFugacityCoefficient(); - phase.setTemperature(phase.getTemperature() - dt); - phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), - phase.getBeta()); - phase.getComponents()[componentNumber].fugcoef(phase); - temp2 = phase.getComponents()[componentNumber].getFugacityCoefficient(); - // phase.setTemperature(phase.getTemperature()+dt); - // System.out.println("temp " + phase.getTemperature()); - // phase.init(numberOfMolesInPhase, numberOfComponents, 1,phase.getPhaseType(), - // phase.getBeta()); - // phase.getComponents()[componentNumber].fugcoef(phase, numberOfComponents, - // phase.getTemperature(), phase.getPressure()); - dfugdt = (Math.log(temp1) - Math.log(temp2)) / dt; - return dfugdt; - } - - /** - *

- * getIonicDiameter. - *

- * - * @return a double - */ - public final double getIonicDiameter() { - if (ionicCharge < 0) { - return paulingAnionicDiameter; - } else if (ionicCharge > 0) { - return stokesCationicDiameter; - } else { - return lennardJonesMolecularDiameter; + mSAFTi = Double.parseDouble(dataSet.getString("mSAFT")); + sigmaSAFTi = Double.parseDouble(dataSet.getString("sigmaSAFT")) / 1.0e10; + epsikSAFT = Double.parseDouble(dataSet.getString("epsikSAFT")); + setAssociationVolumeSAFT( + Double.parseDouble(dataSet.getString("associationboundingvolume_PCSAFT"))); + setAssociationEnergySAFT(Double.parseDouble(dataSet.getString("associationenergy_PCSAFT"))); + if (Math.abs(criticalViscosity) < 1e-12) { + criticalViscosity = + 7.94830 * Math.sqrt(molarMass * 1e3) * Math.pow(criticalPressure, 2.0 / 3.0) + / Math.pow(criticalTemperature, 1.0 / 6.0) * 1e-7; } - } - - /** {@inheritDoc} */ - @Override - public double getStokesCationicDiameter() { - return stokesCationicDiameter; - } - - /** {@inheritDoc} */ - @Override - public void setStokesCationicDiameter(double stokesCationicDiameter) { - this.stokesCationicDiameter = stokesCationicDiameter; - } - - /** {@inheritDoc} */ - @Override - public final double getPaulingAnionicDiameter() { - return paulingAnionicDiameter; - } - - /** - * Setter for property paulingAnionicDiameter. - * - * @param paulingAnionicDiameter New value of property paulingAnionicDiameter. - */ - public void setPaulingAnionicDiameter(double paulingAnionicDiameter) { - this.paulingAnionicDiameter = paulingAnionicDiameter; - } - - /** {@inheritDoc} */ - @Override - public final double getLogFugacityCoefficient() { - return logFugacityCoefficient; - } - - /** {@inheritDoc} */ - @Override - public final int getAttractiveTermNumber() { - return attractiveTermNumber; - } - - /** {@inheritDoc} */ - @Override - public double getVoli() { - return voli; - } - - /** - *

- * Setter for the field voli. - *

- * - * @param molarVol a double - */ - public void setVoli(double molarVol) { - voli = molarVol; - } - - /** - * Indexed getter for property matiascopemanParams. - * - * @param index Index of the property. - * @return Value of the property at index. - */ - public final double getMatiascopemanParams(int index) { - return matiascopemanParams[index]; - } - - /** {@inheritDoc} */ - @Override - public final double[] getMatiascopemanParams() { - return matiascopemanParams; - } - - /** - *

- * Getter for the field matiascopemanParamsPR. - *

- * - * @return an array of {@link double} objects - */ - public final double[] getMatiascopemanParamsPR() { - return matiascopemanParamsPR; - } - - /** - *

- * Setter for the field matiascopemanParamsPR. - *

- * - * @param index a int - * @param matiascopemanParams a double - */ - public void setMatiascopemanParamsPR(int index, double matiascopemanParams) { - this.matiascopemanParamsPR[index] = matiascopemanParams; - } - - /** {@inheritDoc} */ - @Override - public void setMatiascopemanParams(int index, double matiascopemanParams) { - this.matiascopemanParams[index] = matiascopemanParams; - } - - /** {@inheritDoc} */ - @Override - public void setMatiascopemanParams(double[] matiascopemanParams) { - this.matiascopemanParams = matiascopemanParams; - } - - /** {@inheritDoc} */ - @Override - public void setFugacityCoefficient(double val) { - fugacityCoefficient = val; - logFugacityCoefficient = Math.log(fugacityCoefficient); - } - - /** {@inheritDoc} */ - @Override - public final int getNumberOfAssociationSites() { - return numberOfAssociationSites; - } - - /** {@inheritDoc} */ - @Override - public void setNumberOfAssociationSites(int numberOfAssociationSites) { - this.numberOfAssociationSites = numberOfAssociationSites; - } - - /** {@inheritDoc} */ - @Override - public void seta(double a) { - logger.error("no method set a"); - } - - /** {@inheritDoc} */ - @Override - public void setb(double b) { - logger.error("no method set b"); - } - - /** {@inheritDoc} */ - @Override - public final double getAssociationVolume() { - return associationVolume; - } - - /** {@inheritDoc} */ - @Override - public void setAssociationVolume(double associationVolume) { - this.associationVolume = associationVolume; - } - - /** {@inheritDoc} */ - @Override - public final double getAssociationEnergy() { - return associationEnergy; - } - - /** {@inheritDoc} */ - @Override - public void setAssociationEnergy(double associationEnergy) { - this.associationEnergy = associationEnergy; - } - - /** {@inheritDoc} */ - @Override - public double getNormalBoilingPoint() { - return normalBoilingPoint; - } - - /** {@inheritDoc} */ - @Override - public void setNormalBoilingPoint(double normalBoilingPoint) { - this.normalBoilingPoint = normalBoilingPoint; - } - - /** - * Getter for property standardDensity. - * - * @return Value of property standardDensity. - */ - public double getStandardDensity() { - return standardDensity; - } - - /** - * Setter for property standardDensity. - * - * @param standardDensity New value of property standardDensity. - */ - public void setStandardDensity(double standardDensity) { - this.standardDensity = standardDensity; - } - - /** {@inheritDoc} */ - @Override - public double getAntoineASolid() { - return AntoineASolid; - } - - /** {@inheritDoc} */ - @Override - public void setAntoineASolid(double AntoineASolid) { - this.AntoineASolid = AntoineASolid; - } - - /** {@inheritDoc} */ - @Override - public double getAntoineBSolid() { - return AntoineBSolid; - } - - /** {@inheritDoc} */ - @Override - public void setAntoineBSolid(double AntoineBSolid) { - this.AntoineBSolid = AntoineBSolid; - } - - /** {@inheritDoc} */ - @Override - public double getAntoineCSolid() { - return AntoineBSolid; - } - - /** {@inheritDoc} */ - @Override - public void setAntoineCSolid(double AntoineCSolid) { - this.AntoineCSolid = AntoineCSolid; - } - - /** {@inheritDoc} */ - @Override - public final double getSolidVaporPressure(double temperature) { - if (Math.abs(AntoineCSolid) < 1e-10) { - return Math.exp(AntoineASolid + AntoineBSolid / temperature); - } else { - return Math.pow(10.0, AntoineASolid - AntoineBSolid / (temperature + AntoineCSolid)); + // System.out.println("crit visc " + criticalViscosity); + if (normalLiquidDensity == 0) { + normalLiquidDensity = molarMass / (0.285 * Math.pow(criticalVolume, 1.048)) * 1000.0; } - } - - /** {@inheritDoc} */ - @Override - public final double getSolidVaporPressuredT(double temperature) { - if (Math.abs(AntoineCSolid) < 1e-10) { - return -AntoineBSolid / (temperature * temperature) - * Math.exp(AntoineASolid + AntoineBSolid / temperature); + if (dataSet.getString("HydrateFormer").equals("yes")) { + setIsHydrateFormer(true); } else { - return AntoineBSolid * Math.log(10) - * Math.pow((1 / 10), - (AntoineASolid - AntoineBSolid / (temperature + AntoineCSolid))) - * Math.pow(10, AntoineASolid) / Math.pow((temperature + AntoineCSolid), 2); + setIsHydrateFormer(false); } - } - - /** {@inheritDoc} */ - @Override - public final double getSphericalCoreRadius() { - return sphericalCoreRadius; - } - - /** {@inheritDoc} */ - @Override - public void setComponentName(java.lang.String componentName) { - this.componentName = componentName; - } - - /** {@inheritDoc} */ - @Override - public void setLennardJonesEnergyParameter(double lennardJonesEnergyParameter) { - this.lennardJonesEnergyParameter = lennardJonesEnergyParameter; - } - - /** {@inheritDoc} */ - @Override - public void setLennardJonesMolecularDiameter(double lennardJonesMolecularDiameter) { - this.lennardJonesMolecularDiameter = lennardJonesMolecularDiameter; - } - - /** {@inheritDoc} */ - @Override - public void setSphericalCoreRadius(double sphericalCoreRadius) { - this.sphericalCoreRadius = sphericalCoreRadius; - } - - /** {@inheritDoc} */ - @Override - public boolean calcActivity() { - return calcActivity != 0; - } - - /** {@inheritDoc} */ - @Override - public boolean isIsTBPfraction() { - return isTBPfraction; - } - - /** {@inheritDoc} */ - @Override - public boolean isHydrocarbon() { - return isIsTBPfraction() || isPlusFraction || componentType.equals("HC"); - } - - /** {@inheritDoc} */ - @Override - public void setIsTBPfraction(boolean isTBPfraction) { - setIsAllTypesFalse(); - this.isTBPfraction = isTBPfraction; - } - - /** - *

- * setIsAllTypesFalse. - *

- */ - protected void setIsAllTypesFalse() { - this.isTBPfraction = false; - this.isPlusFraction = false; - this.isNormalComponent = false; - this.isIon = false; - } - - /** {@inheritDoc} */ - @Override - public boolean isIsPlusFraction() { - return isPlusFraction; - } - /** {@inheritDoc} */ - @Override - public void setIsPlusFraction(boolean isPlusFraction) { - setIsAllTypesFalse(); - this.isPlusFraction = isPlusFraction; - } - - /** {@inheritDoc} */ - @Override - public boolean isIsNormalComponent() { - return isNormalComponent; - } - - /** {@inheritDoc} */ - @Override - public boolean isInert() { - return componentType.equals("inert"); - } - - /** {@inheritDoc} */ - @Override - public void setIsNormalComponent(boolean isNormalComponent) { - setIsAllTypesFalse(); - this.isNormalComponent = isNormalComponent; - } - - /** {@inheritDoc} */ - @Override - public boolean isIsIon() { - if (componentType.equals("ion")) - setIsIon(true); - return isIon; - } - - /** {@inheritDoc} */ - @Override - public void setIsIon(boolean isIon) { - setIsAllTypesFalse(); - this.isIon = isIon; - } - - /** {@inheritDoc} */ - @Override - public void setNormalLiquidDensity(double normalLiquidDensity) { - this.normalLiquidDensity = normalLiquidDensity; - } - - /** {@inheritDoc} */ - @Override - public void setMolarMass(double molarMass) { - this.molarMass = molarMass; - } - - /** {@inheritDoc} */ - @Override - public final boolean doSolidCheck() { - return solidCheck; - } - - /** {@inheritDoc} */ - @Override - public void setSolidCheck(boolean solidCheck) { - this.solidCheck = solidCheck; - } - - /** {@inheritDoc} */ - @Override - public java.lang.String getAssociationScheme() { - return associationScheme; - } - - /** {@inheritDoc} */ - @Override - public void setAssociationScheme(java.lang.String associationScheme) { - this.associationScheme = associationScheme; - } - - /** {@inheritDoc} */ - @Override - public java.lang.String getComponentType() { - if (isTBPfraction) { - componentType = "TBP"; - } else if (isPlusFraction) { - componentType = "plus"; - } else if (isNormalComponent) { - componentType = "normal"; - } else if (isIon) { - componentType = "ion"; + waxFormer = Integer.parseInt(dataSet.getString("waxformer")) == 1; + // System.out.println(componentName + " pure component parameters: ok..."); + } + componentNumber = compnumber; + } catch (Exception e) { + logger.error("error in comp", e); + } finally { + try { + if (dataSet != null) { + dataSet.close(); } - return componentType; - } - - /** - * {@inheritDoc} - * - * Getter for property Henrys Coefficient. Unit is bar. ln H = C1 + C2/T + C3lnT + C4*T - */ - @Override - public double getHenryCoef(double temperature) { - // System.out.println("henry " + - // Math.exp(henryCoefParameter[0]+henryCoefParameter[1]/temperature+henryCoefParameter[2]*Math.log(temperature)+henryCoefParameter[3]*temperature)*100*0.01802); - return Math.exp(henryCoefParameter[0] + henryCoefParameter[1] / temperature - + henryCoefParameter[2] * Math.log(temperature) - + henryCoefParameter[3] * temperature) * 0.01802 * 100; - } - - /** {@inheritDoc} */ - @Override - public double getHenryCoefdT(double temperature) { - return getHenryCoef(temperature) * (-henryCoefParameter[1] / (temperature * temperature) - + henryCoefParameter[2] / temperature + henryCoefParameter[3]); - } - - /** {@inheritDoc} */ - @Override - public double[] getHenryCoefParameter() { - return this.henryCoefParameter; - } - - /** {@inheritDoc} */ - @Override - public void setHenryCoefParameter(double[] henryCoefParameter) { - this.henryCoefParameter = henryCoefParameter; - } - - /** {@inheritDoc} */ - @Override - public double[] getMatiascopemanSolidParams() { - return this.matiascopemanSolidParams; - } - - /** - * Setter for property matiascopemanSolidParams. - * - * @param matiascopemanSolidParams New value of property matiascopemanSolidParams. - */ - public void setMatiascopemanSolidParams(double[] matiascopemanSolidParams) { - this.matiascopemanSolidParams = matiascopemanSolidParams; - } - - /** {@inheritDoc} */ - @Override - public double getPureComponentCpSolid(double temperature) { - // unit J/mol*K DIPPR function - return 1. / 1000.0 - * (CpSolid[0] + CpSolid[1] * temperature + CpSolid[2] * Math.pow(temperature, 2.0) - + CpSolid[3] * Math.pow(temperature, 3.0) - + CpSolid[4] * Math.pow(temperature, 4.0)); - } - - // A^2/(1-Tr)+B-2*A*C*(1-Tr)-A*D*(1-Tr)^2-C^2*(1-Tr)^3/3-C*D*(1-Tr)^4/2-D^2*(1-Tr)^5/5 - /** {@inheritDoc} */ - @Override - public double getPureComponentCpLiquid(double temperature) { - // unit J/mol*K DIPPR function - return 1. / 1000.0 - * (CpLiquid[0] + CpLiquid[1] * temperature - + CpLiquid[2] * Math.pow(temperature, 2.0) - + CpLiquid[3] * Math.pow(temperature, 3.0) - + CpLiquid[4] * Math.pow(temperature, 4.0)); - } - - /** {@inheritDoc} */ - @Override - public void setCriticalVolume(double criticalVolume) { - this.criticalVolume = criticalVolume; - } - - /** {@inheritDoc} */ - @Override - public double getCriticalViscosity() { - return criticalViscosity; - } - - /** {@inheritDoc} */ - @Override - public void setCriticalViscosity(double criticalViscosity) { - this.criticalViscosity = criticalViscosity; - } - - // return mol/litre - /** {@inheritDoc} */ - @Override - public double getMolarity(PhaseInterface phase) { - return x * 1.0 / (phase.getMolarVolume() * 1e-5) / 1e3; - } - - // return mol/kg - /** {@inheritDoc} */ - @Override - public double getMolality(PhaseInterface phase) { - return getMolarity(phase) / (phase.getDensity() / 1.0e3); - } - - /** {@inheritDoc} */ - @Override - public boolean isHydrateFormer() { - return isIsHydrateFormer(); - } - - /** {@inheritDoc} */ - @Override - public void setIsHydrateFormer(boolean isHydrateFormer) { - this.isHydrateFormer = isHydrateFormer; - } - - /** {@inheritDoc} */ - @Override - public double getmSAFTi() { - return mSAFTi; - } - - /** {@inheritDoc} */ - @Override - public void setmSAFTi(double mSAFTi) { - this.mSAFTi = mSAFTi; - } - - /** {@inheritDoc} */ - @Override - public double getSigmaSAFTi() { - return sigmaSAFTi; - } - - /** {@inheritDoc} */ - @Override - public void setSigmaSAFTi(double sigmaSAFTi) { - this.sigmaSAFTi = sigmaSAFTi; - } - - /** {@inheritDoc} */ - @Override - public double getEpsikSAFT() { - return epsikSAFT; - } - - /** {@inheritDoc} */ - @Override - public void setEpsikSAFT(double epsikSAFT) { - this.epsikSAFT = epsikSAFT; - } - - /** {@inheritDoc} */ - @Override - public double getAssociationVolumeSAFT() { - return associationVolumeSAFT; - } - - /** {@inheritDoc} */ - @Override - public void setAssociationVolumeSAFT(double associationVolumeSAFT) { - this.associationVolumeSAFT = associationVolumeSAFT; - } - - /** {@inheritDoc} */ - @Override - public double getAssociationEnergySAFT() { - return associationEnergySAFT; - } - - /** {@inheritDoc} */ - @Override - public void setAssociationEnergySAFT(double associationEnergySAFT) { - this.associationEnergySAFT = associationEnergySAFT; - } - - /** {@inheritDoc} */ - @Override - public double getCriticalCompressibilityFactor() { - return criticalCompressibilityFactor; - } - - /** {@inheritDoc} */ - @Override - public void setCriticalCompressibilityFactor(double criticalCompressibilityFactor) { - this.criticalCompressibilityFactor = criticalCompressibilityFactor; - } - - /** {@inheritDoc} */ - @Override - public double getSurfaceTenisionInfluenceParameter(double temperature) { - return 1.0; - } - - /** {@inheritDoc} */ - @Override - public void setSurfTensInfluenceParam(int factNum, double val) { - surfTensInfluenceParam[factNum] = val; - } - - /** {@inheritDoc} */ - @Override - public double getSurfTensInfluenceParam(int factNum) { - return surfTensInfluenceParam[factNum]; - } - - /** {@inheritDoc} */ - @Override - public boolean isWaxFormer() { - return waxFormer; - } - - /** {@inheritDoc} */ - @Override - public void setWaxFormer(boolean waxFormer) { - this.waxFormer = waxFormer; - } - - /** {@inheritDoc} */ - @Override - public void setHeatOfFusion(double heatOfFusion) { - this.heatOfFusion = heatOfFusion; - } - - /** {@inheritDoc} */ - @Override - public void setTriplePointTemperature(double triplePointTemperature) { - this.triplePointTemperature = triplePointTemperature; - } - - /** {@inheritDoc} */ - @Override - public void setComponentType(String componentType) { - this.componentType = componentType; - if (componentType.equals("TBP")) { - setIsTBPfraction(true); - } - } - - /** - *

- * isIsHydrateFormer. - *

- * - * @return the isHydrateFormer - */ - public boolean isIsHydrateFormer() { - return isHydrateFormer; - } - - /** - *

- * Getter for the field referenceEnthalpy. - *

- * - * @return the referenceEnthalpy - */ - public double getReferenceEnthalpy() { - return referenceEnthalpy; - } - - /** - *

- * Setter for the field referenceEnthalpy. - *

- * - * @param referenceEnthalpy the referenceEnthalpy to set - */ - public void setReferenceEnthalpy(double referenceEnthalpy) { - this.referenceEnthalpy = referenceEnthalpy; - } - - /** {@inheritDoc} */ - @Override - public double getCpA() { - return CpA; - } - - /** {@inheritDoc} */ - @Override - public void setCpA(double CpA) { - this.CpA = CpA; - } - - /** {@inheritDoc} */ - @Override - public double getCpB() { - return CpB; - } - - /** {@inheritDoc} */ - @Override - public void setCpB(double CpB) { - this.CpB = CpB; - } - - /** {@inheritDoc} */ - @Override - public double getCpC() { - return CpC; - } - - /** {@inheritDoc} */ - @Override - public void setCpC(double CpC) { - this.CpC = CpC; - } - - /** {@inheritDoc} */ - @Override - public double getCpD() { - return CpD + 1e-10; - } - - /** {@inheritDoc} */ - @Override - public void setCpD(double CpD) { - this.CpD = CpD; - } - - /** {@inheritDoc} */ - @Override - public String getFormulae() { - return formulae; - } - - /** {@inheritDoc} */ - @Override - public void setFormulae(String formulae) { - this.formulae = formulae; - } - - /** {@inheritDoc} */ - @Override - public String getCASnumber() { - return CASnumber; - } - - /** {@inheritDoc} */ - @Override - public void setCASnumber(String CASnumber) { - this.CASnumber = CASnumber; - } - - /** {@inheritDoc} */ - @Override - public int getOrginalNumberOfAssociationSites() { - return orginalNumberOfAssociationSites; - } - - /** {@inheritDoc} */ - @Override - public double getdrhodN() { - return molarMass; - } - - /** {@inheritDoc} */ - @Override - public double getCpE() { - return CpE; - } - - /** {@inheritDoc} */ - @Override - public void setCpE(double CpE) { - this.CpE = CpE; - } - - /** {@inheritDoc} */ - @Override - public double getRacketZCPA() { - return racketZCPA; - } - - /** {@inheritDoc} */ - @Override - public void setRacketZCPA(double racketZCPA) { - this.racketZCPA = racketZCPA; - } - - /** {@inheritDoc} */ - @Override - public double getVolumeCorrectionT() { - return volumeCorrectionT; - } - - /** - *

- * getVolumeCorrection. - *

- * - * @return a double - */ - public double getVolumeCorrection() { - return 0.0; - } - - /** {@inheritDoc} */ - @Override - public void setVolumeCorrectionConst(double getVolumeCorrectionConst) { - this.volumeCorrectionConst = getVolumeCorrectionConst; - } - - /** {@inheritDoc} */ - @Override - public void setVolumeCorrectionT(double volumeCorrectionT) { - this.volumeCorrectionT = volumeCorrectionT; - } - - /** {@inheritDoc} */ - @Override - public double getVolumeCorrectionT_CPA() { - return volumeCorrectionT_CPA; - } - - /** {@inheritDoc} */ - @Override - public void setVolumeCorrectionT_CPA(double volumeCorrectionT_CPA) { - this.volumeCorrectionT_CPA = volumeCorrectionT_CPA; - } - - /** {@inheritDoc} */ - @Override - public void setIdealGasEnthalpyOfFormation(double idealGasEnthalpyOfFormation) { - this.idealGasEnthalpyOfFormation = idealGasEnthalpyOfFormation; - } - - /** {@inheritDoc} */ - @Override - public double getFlowRate(String flowunit) { - if (flowunit.equals("kg/sec")) { - return numberOfMolesInPhase * getMolarMass(); - } else if (flowunit.equals("kg/min")) { - return numberOfMolesInPhase * getMolarMass() * 60.0; - } else if (flowunit.equals("kg/hr")) { - return numberOfMolesInPhase * getMolarMass() * 3600.0; - } else if (flowunit.equals("m3/hr")) { - return getVoli() / 1.0e5 * 3600.0; - } else if (flowunit.equals("m3/min")) { - return getVoli() / 1.0e5 * 60.0; - } else if (flowunit.equals("m3/sec")) { - return getVoli() / 1.0e5; - } else if (flowunit.equals("mole/sec")) { - return numberOfMolesInPhase; - } else if (flowunit.equals("mole/min")) { - return numberOfMolesInPhase * 60.0; - } else if (flowunit.equals("mole/hr")) { - return numberOfMolesInPhase * 3600.0; - } else { - throw new RuntimeException("failed.. unit: " + flowunit + " not supported"); + if (database.getStatement() != null) { + database.getStatement().close(); } - } - - /** {@inheritDoc} */ - @Override - public double getTotalFlowRate(String flowunit) { - if (flowunit.equals("kg/sec")) { - return numberOfMoles * getMolarMass(); - } else if (flowunit.equals("kg/min")) { - return numberOfMoles * getMolarMass() * 60.0; - } else if (flowunit.equals("kg/hr")) { - return numberOfMoles * getMolarMass() * 3600.0; - } else if (flowunit.equals("mole/sec")) { - return numberOfMoles; - } else if (flowunit.equals("mole/min")) { - return numberOfMoles * 60.0; - } else if (flowunit.equals("mole/hr")) { - return numberOfMoles * 3600.0; - } else { - throw new RuntimeException("failed.. unit: " + flowunit + " not supported"); + if (database.getConnection() != null) { + database.getConnection().close(); } - } + } catch (Exception e) { + logger.error("error closing database.....", e); + } + } + + srkacentricFactor = acentricFactor; + stokesCationicDiameter = lennardJonesMolecularDiameter; + paulingAnionicDiameter = lennardJonesMolecularDiameter; + } + + /** {@inheritDoc} */ + @Override + public Component clone() { + Component clonedComponent = null; + try { + clonedComponent = (Component) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + + return clonedComponent; + } + + /** {@inheritDoc} */ + @Override + public void addMolesChemReac(double dn) { + numberOfMoles += dn; + numberOfMolesInPhase += dn; + if (numberOfMoles < 0) { + numberOfMoles = 0; + } + if (numberOfMolesInPhase < 0) { + numberOfMolesInPhase = 0; + } + } + + /** {@inheritDoc} */ + @Override + public void addMolesChemReac(double dn, double totdn) { + numberOfMoles += totdn; + + if (numberOfMoles < 0) { + numberOfMoles = 0; + } + + numberOfMolesInPhase += dn; + if (numberOfMolesInPhase < 0) { + numberOfMolesInPhase = 0; + } + } + + /** {@inheritDoc} */ + @Override + public void addMoles(double dn) { + numberOfMolesInPhase += dn; + if (numberOfMolesInPhase < 0) { + numberOfMolesInPhase = 0; + } + } + + /** {@inheritDoc} */ + @Override + public void setProperties(ComponentInterface component) { + x = component.getx(); + z = component.getz(); + numberOfMolesInPhase = component.getNumberOfMolesInPhase(); + numberOfMoles = component.getNumberOfmoles(); + K = component.getK(); + } + + /** {@inheritDoc} */ + @Override + public void init(double temperature, double pressure, double totalNumberOfMoles, double beta, + int type) { + + if (totalNumberOfMoles == 0) { + throw new RuntimeException(new neqsim.util.exception.InvalidInputException(this, "init", + "totalNumberOfMoles", "must be larger than 0")); + } + if (type == 0) { + K = Math.exp(Math.log(criticalPressure / pressure) + + 5.373 * (1.0 + srkacentricFactor) * (1.0 - criticalTemperature / temperature)); + z = numberOfMoles / totalNumberOfMoles; + x = z; + // System.out.println("K " + K); + } + numberOfMolesInPhase = totalNumberOfMoles * x * beta; + numberOfMoles = totalNumberOfMoles * z; // added late by Even 22/10-06 + z = numberOfMoles / totalNumberOfMoles; + } + + /** {@inheritDoc} */ + @Override + public Element getElements() { + if (elements == null) { + elements = new Element(componentName); + } + return elements; + } + + /** {@inheritDoc} */ + @Override + public void Finit(PhaseInterface phase, double temp, double pres, double totMoles, double beta, + int numberOfComponents, int type) {} + + /** {@inheritDoc} */ + @Override + public final double getx() { + return x; + } + + /** {@inheritDoc} */ + @Override + public final double getz() { + return z; + } + + /** {@inheritDoc} */ + @Override + public final void setz(double z) { + this.z = z; + } + + /** {@inheritDoc} */ + @Override + public final double getReferencePotential() { + return referencePotential; + } + + /** {@inheritDoc} */ + @Override + public final void setReferencePotential(double ref) { + this.referencePotential = ref; + } + + /** {@inheritDoc} */ + @Override + public final double getK() { + return K; + } + + /** {@inheritDoc} */ + @Override + public final double getHeatOfFusion() { + return heatOfFusion; + } + + /** {@inheritDoc} */ + @Override + public double getHeatOfVapourization(double temp) { + return heatOfVaporizationCoefs[0] + heatOfVaporizationCoefs[1] * temp + + heatOfVaporizationCoefs[2] * temp * temp + heatOfVaporizationCoefs[3] * temp * temp * temp + * heatOfVaporizationCoefs[4] * temp * temp * temp * temp; // maa + // settes + // paa + // rett + // form + } + + /** {@inheritDoc} */ + @Override + public final double getTripplePointDensity() { + return triplePointDensity; + } + + /** {@inheritDoc} */ + @Override + public final double getTriplePointPressure() { + return triplePointPressure; + } + + /** {@inheritDoc} */ + @Override + public final double getTriplePointTemperature() { + return triplePointTemperature; + } + + /** {@inheritDoc} */ + @Override + public final double getMeltingPointTemperature() { + return meltingPointTemperature; + } + + /** {@inheritDoc} */ + @Override + public final double getIdealGasEnthalpyOfFormation() { + return idealGasEnthalpyOfFormation; + } + + /** {@inheritDoc} */ + @Override + public final double getIdealGasGibsEnergyOfFormation() { + return idealGasGibsEnergyOfFormation; + } + + /** {@inheritDoc} */ + @Override + public final double getIdealGasAbsoluteEntropy() { + return idealGasAbsoluteEntropy; + } + + /** {@inheritDoc} */ + @Override + public final double getTC() { + return criticalTemperature; + } + + /** {@inheritDoc} */ + @Override + public final void setTC(double val) { + criticalTemperature = val; + } + + /** {@inheritDoc} */ + @Override + public final void setPC(double val) { + criticalPressure = val; + } + + /** {@inheritDoc} */ + @Override + public final String getComponentName() { + return componentName; + } + + /** {@inheritDoc} */ + @Override + public final String getReferenceStateType() { + return referenceStateType; + } + + /** {@inheritDoc} */ + @Override + public final double getPC() { + return criticalPressure; + } + + /** {@inheritDoc} */ + @Override + public double getGibbsEnergyOfFormation() { + return gibbsEnergyOfFormation; + } + + /** {@inheritDoc} */ + @Override + public double getDiElectricConstant(double temperature) { + return dielectricParameter[0] + dielectricParameter[1] / temperature + + dielectricParameter[2] * temperature + dielectricParameter[3] * temperature * temperature + + dielectricParameter[4] * Math.pow(temperature, 3.0); + } + + /** {@inheritDoc} */ + @Override + public double getDiElectricConstantdT(double temperature) { + return -dielectricParameter[1] / Math.pow(temperature, 2.0) + dielectricParameter[2] + + 2.0 * dielectricParameter[3] * temperature + + 3.0 * dielectricParameter[4] * Math.pow(temperature, 2.0); + } + + /** {@inheritDoc} */ + @Override + public double getDiElectricConstantdTdT(double temperature) { + return 2.0 * dielectricParameter[1] / Math.pow(temperature, 3.0) + 2.0 * dielectricParameter[3] + + 6.0 * dielectricParameter[4] * Math.pow(temperature, 1.0); + } + + /** {@inheritDoc} */ + @Override + public double getDebyeDipoleMoment() { + return debyeDipoleMoment; + } + + /** {@inheritDoc} */ + @Override + public final double getIonicCharge() { + return ionicCharge; + } + + /** {@inheritDoc} */ + @Override + public final void setViscosityAssociationFactor(double val) { + viscosityCorrectionFactor = val; + } + + /** {@inheritDoc} */ + @Override + public final double getRacketZ() { + return racketZ; + } + + /** {@inheritDoc} */ + @Override + public double getVolumeCorrectionConst() { + return volumeCorrectionConst; + } + + /** {@inheritDoc} */ + @Override + public double getNormalLiquidDensity() { + return normalLiquidDensity; + } + + /** {@inheritDoc} */ + @Override + public double getViscosityCorrectionFactor() { + return viscosityCorrectionFactor; + } + + /** {@inheritDoc} */ + @Override + public double getCriticalVolume() { + return criticalVolume; + } + + /** {@inheritDoc} */ + @Override + public final int getLiquidViscosityModel() { + return liquidViscosityModel; + } + + /** {@inheritDoc} */ + @Override + public final double getParachorParameter() { + return parachorParameter; + } + + /** {@inheritDoc} */ + @Override + public final void setParachorParameter(double parachorParameter) { + this.parachorParameter = parachorParameter; + } + + /** {@inheritDoc} */ + @Override + public final void setLiquidViscosityModel(int modelNumber) { + liquidViscosityModel = modelNumber; + } + + /** {@inheritDoc} */ + @Override + public final void setLiquidViscosityParameter(double number, int i) { + liquidViscosityParameter[i] = number; + } + + /** {@inheritDoc} */ + @Override + public final double getLiquidViscosityParameter(int i) { + return liquidViscosityParameter[i]; + } + + /** {@inheritDoc} */ + @Override + public void setLiquidConductivityParameter(double number, int i) { + liquidConductivityParameter[i] = number; + } + + /** {@inheritDoc} */ + @Override + public double getLiquidConductivityParameter(int i) { + return liquidConductivityParameter[i]; + } + + /** + * {@inheritDoc} + * + * Units in m*e10 + */ + @Override + public double getLennardJonesMolecularDiameter() { + return lennardJonesMolecularDiameter; + } + + /** {@inheritDoc} */ + @Override + public double getLennardJonesEnergyParameter() { + return lennardJonesEnergyParameter; + } + + /** {@inheritDoc} */ + @Override + public double getHsub() { + return Hsub; + } + + /** + * {@inheritDoc} + * + * Calculates the pure comonent solid vapor pressure (bar) with the C-C equation, based on Hsub + * Should only be used in the valid temperature range below the triple point (specified in + * component database). + */ + @Override + public double getCCsolidVaporPressure(double temperature) { + return triplePointPressure + * (Math.exp(Hsub / R * (1.0 / getTriplePointTemperature() - 1.0 / temperature))); + } + + /** + * {@inheritDoc} + * + * Calculates the DT of pure comonent solid vapor pressure (bar) with the C-C equation, based on + * Hsub Should only be used in the valid temperature range below the triple point (specified in + * component database). + */ + @Override + public double getCCsolidVaporPressuredT(double temperature) { + return triplePointPressure * Hsub / R * (1.0 / (temperature * temperature)) + * (Math.exp(Hsub / R * (1.0 / getTriplePointTemperature() - 1.0 / temperature))); + } + + /** + * {@inheritDoc} + * + * Calculates the pure component solid density in kg/liter Should only be used in the valid + * temperature range (specified in component database). + */ + @Override + public double getPureComponentSolidDensity(double temperature) { + return molarMass * 1000.0 + * (solidDensityCoefs[0] + solidDensityCoefs[1] * Math.pow(temperature, 1.0) + + solidDensityCoefs[2] * Math.pow(temperature, 2.0) + + solidDensityCoefs[3] * Math.pow(temperature, 3.0) + + solidDensityCoefs[4] * Math.pow(temperature, 4.0)); + } + + /** + * {@inheritDoc} + * + * Calculates the pure component liquid density in kg/liter Should only be used in the valid + * temperature range (specified in component database). This method seems to give bad results at + * the moment + */ + @Override + public double getPureComponentLiquidDensity(double temperature) { + return molarMass * 1000.0 + * (liquidDensityCoefs[0] + liquidDensityCoefs[1] * Math.pow(temperature, 1.0) + + liquidDensityCoefs[2] * Math.pow(temperature, 2.0) + + liquidDensityCoefs[3] * Math.pow(temperature, 3.0) + + liquidDensityCoefs[4] * Math.pow(temperature, 4.0)); + // return Math.pow(liquidDensityCoefs[0] / liquidDensityCoefs[1], 1.0 + + // Math.pow(1.0 - temperature / liquidDensityCoefs[2], liquidDensityCoefs[3])); + } + + /** + * {@inheritDoc} + * + * Calculates the pure comonent heat of vaporization in J/mol + */ + @Override + public double getPureComponentHeatOfVaporization(double temperature) { + return 1.0e-3 * heatOfVaporizationCoefs[0] + * Math.pow((1.0 - temperature / criticalTemperature), + heatOfVaporizationCoefs[1] + + heatOfVaporizationCoefs[2] * temperature / criticalTemperature + + heatOfVaporizationCoefs[3] * Math.pow(temperature / criticalTemperature, 2.0)); + } + + /** {@inheritDoc} */ + @Override + public final void setx(double newx) { + if (Double.isNaN(newx) || Double.isInfinite(newx)) { + return; + } + if (newx < 0) { + x = 1.0e-50; + } + if (newx > 0) { + x = newx; + } + if (newx > 5) { + x = 5; + } + } + + /** {@inheritDoc} */ + @Override + public final void setNumberOfmoles(double newmoles) { + numberOfMoles = newmoles; + } + + /** {@inheritDoc} */ + @Override + public final void setNumberOfMolesInPhase(double totmoles) { + numberOfMolesInPhase = totmoles * x; + } + + /** {@inheritDoc} */ + @Override + public final double getNumberOfmoles() { + return this.numberOfMoles; + } + + /** {@inheritDoc} */ + @Override + public final double getMolarMass() { + return this.molarMass; + } + + /** {@inheritDoc} */ + @Override + public final double getNumberOfMolesInPhase() { + return this.numberOfMolesInPhase; + } + + /** {@inheritDoc} */ + @Override + public double getRate(String unitName) { + neqsim.util.unit.Unit unit = new neqsim.util.unit.RateUnit(numberOfMolesInPhase, "mol/sec", + molarMass, normalLiquidDensity, normalBoilingPoint); + double val = unit.getValue(unitName); + return val; + } + + /** {@inheritDoc} */ + @Override + public final void setK(double newK) { + K = newK; + } + + /** {@inheritDoc} */ + @Override + public final double getFugacityCoefficient() { + return fugacityCoefficient; + } + + /** {@inheritDoc} */ + @Override + public double fugcoef(PhaseInterface phase) { + fugacityCoefficient = 1.0;// this.fugcoef(phase, phase.getNumberOfComponents(), + // phase.getTemperature(), + // phase.getPressure()); + logFugacityCoefficient = Math.log(fugacityCoefficient); + return fugacityCoefficient; + } + + /** {@inheritDoc} */ + @Override + public double logfugcoefdT(PhaseInterface phase) { + dfugdt = 0.0;// this.fugcoefDiffTemp(phase, phase.getNumberOfComponents(), + // phase.getTemperature(), phase.getPressure()); + return dfugdt; + } + + /** {@inheritDoc} */ + @Override + public double logfugcoefdP(PhaseInterface phase) { + dfugdp = 0.0;// this.fugcoefDiffPres(phase, phase.getNumberOfComponents(), + // phase.getTemperature(), phase.getPressure()); + return dfugdp; + } + + /** {@inheritDoc} */ + @Override + public double[] logfugcoefdN(PhaseInterface phase) { + // dfugdn = this.fugcoefDiffN(phase, phase.getNumberOfComponents(), + // phase.getTemperature(), phase.getPressure()); + return new double[2]; + } + + /** {@inheritDoc} */ + @Override + public double logfugcoefdNi(PhaseInterface phase, int k) { + return 0.0; + } + + /** {@inheritDoc} */ + @Override + public double getdfugdt() { + return dfugdt; + } + + /** {@inheritDoc} */ + @Override + public double getdfugdp() { + return dfugdp; + } + + /** {@inheritDoc} */ + @Override + public void setdfugdt(double val) { + dfugdt = val; + } + + /** {@inheritDoc} */ + @Override + public void setdfugdp(double val) { + dfugdp = val; + } + + /** {@inheritDoc} */ + @Override + public void setdfugdn(int i, double val) { + dfugdn[i] = val; + } + + /** {@inheritDoc} */ + @Override + public void setdfugdx(int i, double val) { + dfugdx[i] = val; + } + + /** {@inheritDoc} */ + @Override + public double getAcentricFactor() { + return acentricFactor; + } + + /** {@inheritDoc} */ + @Override + public double getdfugdx(int i) { + return dfugdx[i]; + } + + /** {@inheritDoc} */ + @Override + public double getdfugdn(int i) { + return dfugdn[i]; + } + + /** {@inheritDoc} */ + @Override + public int getIndex() { + return index; + } + + /** {@inheritDoc} */ + @Override + public int getComponentNumber() { + return componentNumber; + } + + /** {@inheritDoc} */ + @Override + public final double getGibbsEnergy(double temperature, double pressure) { + return getEnthalpy(temperature) - temperature * getEntropy(temperature, pressure); + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialIdealReference(PhaseInterface phase) { + return (getHID(phase.getTemperature()) + - phase.getTemperature() * getIdEntropy(phase.getTemperature())); + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotential(double temperature, double pressure) { + return getGibbsEnergy(temperature, pressure) / numberOfMolesInPhase; + } + + /** {@inheritDoc} */ + @Override + public double getChemicalPotential(PhaseInterface phase) { + return getGibbsEnergy(phase.getTemperature(), phase.getPressure()) / numberOfMolesInPhase; + // return getGresTV; + } + + /** + *

+ * getFugacitydN. + *

+ * + * @param i a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public final double getFugacitydN(int i, PhaseInterface phase) { + double tempFug = 0.0; + if (i == componentNumber) { + tempFug = 1.0 / getNumberOfMolesInPhase(); + } + return getdfugdn(i) + tempFug - 1.0 / phase.getNumberOfMolesInPhase(); + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialdNTV(int i, PhaseInterface phase) { + return getChemicalPotentialdN(i, phase) + - getVoli() * phase.getComponent(i).getVoli() * phase.getdPdVTn(); + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialdN(int i, PhaseInterface phase) { + return R * phase.getTemperature() * getFugacitydN(i, phase); + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialdP() { + return voli; + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialdT(PhaseInterface phase) { + return -getEntropy(phase.getTemperature(), phase.getPressure()) / numberOfMolesInPhase; + } + + /** {@inheritDoc} */ + @Override + public final double getChemicalPotentialdV(PhaseInterface phase) { + return getChemicalPotentialdP() * phase.getdPdVTn(); + } + + /** + *

+ * getChemicalPotentialdP. + *

+ * + * @param i a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public final double getChemicalPotentialdP(int i, PhaseInterface phase) { + return R * phase.getTemperature() * getFugacitydN(i, phase); + } + + /** {@inheritDoc} */ + @Override + public void setComponentNumber(int numb) { + componentNumber = numb; + } + + /** {@inheritDoc} */ + @Override + public double getAntoineVaporPressure(double temp) { + if (antoineLiqVapPresType.equals("pow10")) { + return Math.pow(10.0, AntoineA - (AntoineB / (temp + AntoineC - 273.15))); // equation + // and + // parameter + // from + // properties + // o liquids + // and + // gases + // (poling + // 5th ed) + } else if (antoineLiqVapPresType.equals("exp") || antoineLiqVapPresType.equals("log")) { + return Math.exp(AntoineA - (AntoineB / (temp + AntoineC))); // equation and parameter + // from properties o + // liquids and gases (poling + // 5th ed) + } else if (Math.abs(AntoineE) > 1e-12) { + return Math.exp(AntoineA + AntoineB / temp + AntoineC * Math.log(temp) + + AntoineD * Math.pow(temp, AntoineE)) / 100000; + } else { + double x = 1 - (temp / criticalTemperature); + return (Math.exp(Math.pow((1 - x), -1) * (AntoineA * x + AntoineB * Math.pow(x, 1.5) + + AntoineC * Math.pow(x, 3) + AntoineD * Math.pow(x, 6))) * criticalPressure); + } + } + + /** {@inheritDoc} */ + @Override + public double getAntoineVaporPressuredT(double temp) { + if (antoineLiqVapPresType.equals("pow10")) { + // (10^ (A - B/(C + x - 5463/20)) *B*log(10))/(C + x - 5463/20)^2 + double ans = (Math.pow(AntoineA - AntoineB / (AntoineC + temp - 273.15), 10.0) * AntoineB + * Math.log(10.0)) / Math.pow((AntoineC + temp - 273.15), 2.0); + return ans; + } else if (antoineLiqVapPresType.equals("exp") || antoineLiqVapPresType.equals("log")) { + // (B*exp(A - B/(C + x)))/(C + x)^2 + double ans = AntoineB * (Math.exp(AntoineA - AntoineB / (AntoineC + temp))) + / Math.pow((AntoineC + temp), 2.0); + return ans; + } else { + return 0.0; + } + } + + /** {@inheritDoc} */ + @Override + public double getAntoineVaporTemperature(double pres) { + double nyPres = 0, nyTemp = criticalTemperature * 0.7; + int iter = 0; + do { + iter++; + + nyPres = getAntoineVaporPressure(nyTemp); + nyTemp -= (nyPres - pres); + // nyTemp = nyTemp-(nyPres - pres)/getAntoineVaporPressuredT(nyTemp); + // System.out.println("temp Antoine " +nyTemp + " error "+Math.abs((nyPres - + // pres) / pres)); + } while (Math.abs((nyPres - pres) / pres) > 0.00001 && iter < 1000); + return nyTemp; + } + + /** {@inheritDoc} */ + @Override + public final double getHresTP(double temperature) { + return R * temperature * (-temperature * getdfugdt()); + } + + /** {@inheritDoc} */ + @Override + public final double getGresTP(double temperature) { + return R * temperature * (Math.log(getFugacityCoefficient())); + } + + /** {@inheritDoc} */ + @Override + public final double getSresTP(double temperature) { + return (getHresTP(temperature) - getGresTP(temperature)) / temperature; + } + + /** {@inheritDoc} */ + @Override + public final double getCp0(double temperature) { + return getCpA() + getCpB() * temperature + getCpC() * Math.pow(temperature, 2) + + getCpD() * Math.pow(temperature, 3) + getCpE() * Math.pow(temperature, 4); + } + + /** {@inheritDoc} */ + @Override + public final double getCv0(double temperature) { + return getCpA() + getCpB() * temperature + getCpC() * Math.pow(temperature, 2) + + getCpD() * Math.pow(temperature, 3) + getCpE() * Math.pow(temperature, 4) - R; + } + + // integralet av Cp0 mhp T + /** {@inheritDoc} */ + @Override + public final double getHID(double T) { + return 0 * getIdealGasEnthalpyOfFormation() + + (getCpA() * T + 1.0 / 2.0 * getCpB() * T * T + 1.0 / 3.0 * getCpC() * T * T * T + + 1.0 / 4.0 * getCpD() * T * T * T * T) + + 1.0 / 5.0 * getCpE() * T * T * T * T * T + - (getCpA() * referenceTemperature + + 1.0 / 2.0 * getCpB() * referenceTemperature * referenceTemperature + + 1.0 / 3.0 * getCpC() * referenceTemperature * referenceTemperature + * referenceTemperature + + 1.0 / 4.0 * getCpD() * referenceTemperature * referenceTemperature + * referenceTemperature * referenceTemperature + + 1.0 / 5.0 * getCpE() * referenceTemperature * referenceTemperature + * referenceTemperature * referenceTemperature * referenceTemperature); + } + + /** {@inheritDoc} */ + @Override + public final double getEnthalpy(double temperature) { + return getHID(temperature) * numberOfMolesInPhase + + getHresTP(temperature) * numberOfMolesInPhase; + } + + /** {@inheritDoc} */ + @Override + public double getIdEntropy(double temperature) { + return (getCpE() * temperature * temperature * temperature * temperature / 4.0 + + getCpD() * temperature * temperature * temperature / 3.0 + + getCpC() * temperature * temperature / 2.0 + getCpB() * temperature + + getCpA() * Math.log(temperature) + - getCpE() * referenceTemperature * referenceTemperature * referenceTemperature + * referenceTemperature / 4.0 + - getCpD() * referenceTemperature * referenceTemperature * referenceTemperature / 3.0 + - getCpC() * referenceTemperature * referenceTemperature / 2.0 + - getCpB() * referenceTemperature - getCpA() * Math.log(referenceTemperature)); + } + + /** {@inheritDoc} */ + @Override + public double getEntropy(double temperature, double pressure) { + if (x < 1e-100) { + return 0.0; + } + return numberOfMolesInPhase * (getIdEntropy(temperature) + - (R * Math.log(pressure / referencePressure)) - R * Math.log(x)) + + getSresTP(temperature) * numberOfMolesInPhase; // 1 bor vaere Z + } + + /** {@inheritDoc} */ + @Override + public final String getName() { + return componentName; + } + + /** {@inheritDoc} */ + @Override + public void setAcentricFactor(double val) { + acentricFactor = val; + getAttractiveTerm().init(); + } + + /** {@inheritDoc} */ + @Override + public void setRacketZ(double val) { + racketZ = val; + } + + /** {@inheritDoc} */ + @Override + public void setAttractiveTerm(int i) { + attractiveTermNumber = i; + } + + /** {@inheritDoc} */ + @Override + public AttractiveTermInterface getAttractiveTerm() { + return null; + } + + /** {@inheritDoc} */ + @Override + public final double[] getSchwartzentruberParams() { + return schwartzentruberParams; + } + + /** {@inheritDoc} */ + @Override + public final void setSchwartzentruberParams(int i, double param) { + schwartzentruberParams[i] = param; + } + + /** {@inheritDoc} */ + @Override + public final double[] getTwuCoonParams() { + return TwuCoonParams; + } + + /** {@inheritDoc} */ + @Override + public final void setTwuCoonParams(int i, double param) { + TwuCoonParams[i] = param; + } + + /** {@inheritDoc} */ + @Override + public double fugcoefDiffPresNumeric(PhaseInterface phase, int numberOfComponents, + double temperature, double pressure) { + double temp1 = 0.0, temp2 = 0.0; + double dp = phase.getPressure() / 1.0e5; + temp1 = phase.getComponents()[componentNumber].getFugacityCoefficient(); + phase.setPressure(phase.getPressure() - dp); + phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), phase.getBeta()); + phase.getComponents()[componentNumber].fugcoef(phase); + temp2 = phase.getComponents()[componentNumber].getFugacityCoefficient(); + phase.setPressure(phase.getPressure() + dp); + phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), phase.getBeta()); + phase.getComponents()[componentNumber].fugcoef(phase); + dfugdp = (Math.log(temp1) - Math.log(temp2)) / dp; + return dfugdp; + } + + /** {@inheritDoc} */ + @Override + public double fugcoefDiffTempNumeric(PhaseInterface phase, int numberOfComponents, + double temperature, double pressure) { + double temp1 = 0.0, temp2 = 0.0; + double dt = phase.getTemperature() / 1.0e6; + temp1 = phase.getComponents()[componentNumber].getFugacityCoefficient(); + phase.setTemperature(phase.getTemperature() - dt); + phase.init(numberOfMolesInPhase, numberOfComponents, 1, phase.getPhaseType(), phase.getBeta()); + phase.getComponents()[componentNumber].fugcoef(phase); + temp2 = phase.getComponents()[componentNumber].getFugacityCoefficient(); + // phase.setTemperature(phase.getTemperature()+dt); + // System.out.println("temp " + phase.getTemperature()); + // phase.init(numberOfMolesInPhase, numberOfComponents, 1,phase.getPhaseType(), + // phase.getBeta()); + // phase.getComponents()[componentNumber].fugcoef(phase, numberOfComponents, + // phase.getTemperature(), phase.getPressure()); + dfugdt = (Math.log(temp1) - Math.log(temp2)) / dt; + return dfugdt; + } + + /** + *

+ * getIonicDiameter. + *

+ * + * @return a double + */ + public final double getIonicDiameter() { + if (ionicCharge < 0) { + return paulingAnionicDiameter; + } else if (ionicCharge > 0) { + return stokesCationicDiameter; + } else { + return lennardJonesMolecularDiameter; + } + } + + /** {@inheritDoc} */ + @Override + public double getStokesCationicDiameter() { + return stokesCationicDiameter; + } + + /** {@inheritDoc} */ + @Override + public void setStokesCationicDiameter(double stokesCationicDiameter) { + this.stokesCationicDiameter = stokesCationicDiameter; + } + + /** {@inheritDoc} */ + @Override + public final double getPaulingAnionicDiameter() { + return paulingAnionicDiameter; + } + + /** + * Setter for property paulingAnionicDiameter. + * + * @param paulingAnionicDiameter New value of property paulingAnionicDiameter. + */ + public void setPaulingAnionicDiameter(double paulingAnionicDiameter) { + this.paulingAnionicDiameter = paulingAnionicDiameter; + } + + /** {@inheritDoc} */ + @Override + public final double getLogFugacityCoefficient() { + return logFugacityCoefficient; + } + + /** {@inheritDoc} */ + @Override + public final int getAttractiveTermNumber() { + return attractiveTermNumber; + } + + /** {@inheritDoc} */ + @Override + public double getVoli() { + return voli; + } + + /** + *

+ * Setter for the field voli. + *

+ * + * @param molarVol a double + */ + public void setVoli(double molarVol) { + voli = molarVol; + } + + /** + * Indexed getter for property matiascopemanParams. + * + * @param index Index of the property. + * @return Value of the property at index. + */ + public final double getMatiascopemanParams(int index) { + return matiascopemanParams[index]; + } + + /** {@inheritDoc} */ + @Override + public final double[] getMatiascopemanParams() { + return matiascopemanParams; + } + + /** + *

+ * Getter for the field matiascopemanParamsPR. + *

+ * + * @return an array of {@link double} objects + */ + public final double[] getMatiascopemanParamsPR() { + return matiascopemanParamsPR; + } + + /** + *

+ * Setter for the field matiascopemanParamsPR. + *

+ * + * @param index a int + * @param matiascopemanParams a double + */ + public void setMatiascopemanParamsPR(int index, double matiascopemanParams) { + this.matiascopemanParamsPR[index] = matiascopemanParams; + } + + /** {@inheritDoc} */ + @Override + public void setMatiascopemanParams(int index, double matiascopemanParams) { + this.matiascopemanParams[index] = matiascopemanParams; + } + + /** {@inheritDoc} */ + @Override + public void setMatiascopemanParams(double[] matiascopemanParams) { + this.matiascopemanParams = matiascopemanParams; + } + + /** {@inheritDoc} */ + @Override + public void setFugacityCoefficient(double val) { + fugacityCoefficient = val; + logFugacityCoefficient = Math.log(fugacityCoefficient); + } + + /** {@inheritDoc} */ + @Override + public final int getNumberOfAssociationSites() { + return numberOfAssociationSites; + } + + /** {@inheritDoc} */ + @Override + public void setNumberOfAssociationSites(int numberOfAssociationSites) { + this.numberOfAssociationSites = numberOfAssociationSites; + } + + /** {@inheritDoc} */ + @Override + public void seta(double a) { + logger.error("no method set a"); + } + + /** {@inheritDoc} */ + @Override + public void setb(double b) { + logger.error("no method set b"); + } + + /** {@inheritDoc} */ + @Override + public final double getAssociationVolume() { + return associationVolume; + } + + /** {@inheritDoc} */ + @Override + public void setAssociationVolume(double associationVolume) { + this.associationVolume = associationVolume; + } + + /** {@inheritDoc} */ + @Override + public final double getAssociationEnergy() { + return associationEnergy; + } + + /** {@inheritDoc} */ + @Override + public void setAssociationEnergy(double associationEnergy) { + this.associationEnergy = associationEnergy; + } + + /** {@inheritDoc} */ + @Override + public double getNormalBoilingPoint() { + return normalBoilingPoint; + } + + /** {@inheritDoc} */ + @Override + public void setNormalBoilingPoint(double normalBoilingPoint) { + this.normalBoilingPoint = normalBoilingPoint; + } + + /** + * Getter for property standardDensity. + * + * @return Value of property standardDensity. + */ + public double getStandardDensity() { + return standardDensity; + } + + /** + * Setter for property standardDensity. + * + * @param standardDensity New value of property standardDensity. + */ + public void setStandardDensity(double standardDensity) { + this.standardDensity = standardDensity; + } + + /** {@inheritDoc} */ + @Override + public double getAntoineASolid() { + return AntoineASolid; + } + + /** {@inheritDoc} */ + @Override + public void setAntoineASolid(double AntoineASolid) { + this.AntoineASolid = AntoineASolid; + } + + /** {@inheritDoc} */ + @Override + public double getAntoineBSolid() { + return AntoineBSolid; + } + + /** {@inheritDoc} */ + @Override + public void setAntoineBSolid(double AntoineBSolid) { + this.AntoineBSolid = AntoineBSolid; + } + + /** {@inheritDoc} */ + @Override + public double getAntoineCSolid() { + return AntoineBSolid; + } + + /** {@inheritDoc} */ + @Override + public void setAntoineCSolid(double AntoineCSolid) { + this.AntoineCSolid = AntoineCSolid; + } + + /** {@inheritDoc} */ + @Override + public final double getSolidVaporPressure(double temperature) { + if (Math.abs(AntoineCSolid) < 1e-10) { + return Math.exp(AntoineASolid + AntoineBSolid / temperature); + } else { + return Math.pow(10.0, AntoineASolid - AntoineBSolid / (temperature + AntoineCSolid)); + } + } + + /** {@inheritDoc} */ + @Override + public final double getSolidVaporPressuredT(double temperature) { + if (Math.abs(AntoineCSolid) < 1e-10) { + return -AntoineBSolid / (temperature * temperature) + * Math.exp(AntoineASolid + AntoineBSolid / temperature); + } else { + return AntoineBSolid * Math.log(10) + * Math.pow((1 / 10), (AntoineASolid - AntoineBSolid / (temperature + AntoineCSolid))) + * Math.pow(10, AntoineASolid) / Math.pow((temperature + AntoineCSolid), 2); + } + } + + /** {@inheritDoc} */ + @Override + public final double getSphericalCoreRadius() { + return sphericalCoreRadius; + } + + /** {@inheritDoc} */ + @Override + public void setComponentName(java.lang.String componentName) { + this.componentName = componentName; + } + + /** {@inheritDoc} */ + @Override + public void setLennardJonesEnergyParameter(double lennardJonesEnergyParameter) { + this.lennardJonesEnergyParameter = lennardJonesEnergyParameter; + } + + /** {@inheritDoc} */ + @Override + public void setLennardJonesMolecularDiameter(double lennardJonesMolecularDiameter) { + this.lennardJonesMolecularDiameter = lennardJonesMolecularDiameter; + } + + /** {@inheritDoc} */ + @Override + public void setSphericalCoreRadius(double sphericalCoreRadius) { + this.sphericalCoreRadius = sphericalCoreRadius; + } + + /** {@inheritDoc} */ + @Override + public boolean calcActivity() { + return calcActivity != 0; + } + + /** {@inheritDoc} */ + @Override + public boolean isIsTBPfraction() { + return isTBPfraction; + } + + /** {@inheritDoc} */ + @Override + public boolean isHydrocarbon() { + return isIsTBPfraction() || isPlusFraction || componentType.equals("HC"); + } + + /** {@inheritDoc} */ + @Override + public void setIsTBPfraction(boolean isTBPfraction) { + setIsAllTypesFalse(); + this.isTBPfraction = isTBPfraction; + } + + /** + *

+ * setIsAllTypesFalse. + *

+ */ + protected void setIsAllTypesFalse() { + this.isTBPfraction = false; + this.isPlusFraction = false; + this.isNormalComponent = false; + this.isIon = false; + } + + /** {@inheritDoc} */ + @Override + public boolean isIsPlusFraction() { + return isPlusFraction; + } + + /** {@inheritDoc} */ + @Override + public void setIsPlusFraction(boolean isPlusFraction) { + setIsAllTypesFalse(); + this.isPlusFraction = isPlusFraction; + } + + /** {@inheritDoc} */ + @Override + public boolean isIsNormalComponent() { + return isNormalComponent; + } + + /** {@inheritDoc} */ + @Override + public boolean isInert() { + return componentType.equals("inert"); + } + + /** {@inheritDoc} */ + @Override + public void setIsNormalComponent(boolean isNormalComponent) { + setIsAllTypesFalse(); + this.isNormalComponent = isNormalComponent; + } + + /** {@inheritDoc} */ + @Override + public boolean isIsIon() { + if (componentType.equals("ion")) + setIsIon(true); + return isIon; + } + + /** {@inheritDoc} */ + @Override + public void setIsIon(boolean isIon) { + setIsAllTypesFalse(); + this.isIon = isIon; + } + + /** {@inheritDoc} */ + @Override + public void setNormalLiquidDensity(double normalLiquidDensity) { + this.normalLiquidDensity = normalLiquidDensity; + } + + /** {@inheritDoc} */ + @Override + public void setMolarMass(double molarMass) { + this.molarMass = molarMass; + } + + /** {@inheritDoc} */ + @Override + public final boolean doSolidCheck() { + return solidCheck; + } + + /** {@inheritDoc} */ + @Override + public void setSolidCheck(boolean solidCheck) { + this.solidCheck = solidCheck; + } + + /** {@inheritDoc} */ + @Override + public java.lang.String getAssociationScheme() { + return associationScheme; + } + + /** {@inheritDoc} */ + @Override + public void setAssociationScheme(java.lang.String associationScheme) { + this.associationScheme = associationScheme; + } + + /** {@inheritDoc} */ + @Override + public java.lang.String getComponentType() { + if (isTBPfraction) { + componentType = "TBP"; + } else if (isPlusFraction) { + componentType = "plus"; + } else if (isNormalComponent) { + componentType = "normal"; + } else if (isIon) { + componentType = "ion"; + } + return componentType; + } + + /** + * {@inheritDoc} + * + * Getter for property Henrys Coefficient. Unit is bar. ln H = C1 + C2/T + C3lnT + C4*T + */ + @Override + public double getHenryCoef(double temperature) { + // System.out.println("henry " + + // Math.exp(henryCoefParameter[0]+henryCoefParameter[1]/temperature+henryCoefParameter[2]*Math.log(temperature)+henryCoefParameter[3]*temperature)*100*0.01802); + return Math + .exp(henryCoefParameter[0] + henryCoefParameter[1] / temperature + + henryCoefParameter[2] * Math.log(temperature) + henryCoefParameter[3] * temperature) + * 0.01802 * 100; + } + + /** {@inheritDoc} */ + @Override + public double getHenryCoefdT(double temperature) { + return getHenryCoef(temperature) * (-henryCoefParameter[1] / (temperature * temperature) + + henryCoefParameter[2] / temperature + henryCoefParameter[3]); + } + + /** {@inheritDoc} */ + @Override + public double[] getHenryCoefParameter() { + return this.henryCoefParameter; + } + + /** {@inheritDoc} */ + @Override + public void setHenryCoefParameter(double[] henryCoefParameter) { + this.henryCoefParameter = henryCoefParameter; + } + + /** {@inheritDoc} */ + @Override + public double[] getMatiascopemanSolidParams() { + return this.matiascopemanSolidParams; + } + + /** + * Setter for property matiascopemanSolidParams. + * + * @param matiascopemanSolidParams New value of property matiascopemanSolidParams. + */ + public void setMatiascopemanSolidParams(double[] matiascopemanSolidParams) { + this.matiascopemanSolidParams = matiascopemanSolidParams; + } + + /** {@inheritDoc} */ + @Override + public double getPureComponentCpSolid(double temperature) { + // unit J/mol*K DIPPR function + return 1. / 1000.0 + * (CpSolid[0] + CpSolid[1] * temperature + CpSolid[2] * Math.pow(temperature, 2.0) + + CpSolid[3] * Math.pow(temperature, 3.0) + CpSolid[4] * Math.pow(temperature, 4.0)); + } + + // A^2/(1-Tr)+B-2*A*C*(1-Tr)-A*D*(1-Tr)^2-C^2*(1-Tr)^3/3-C*D*(1-Tr)^4/2-D^2*(1-Tr)^5/5 + /** {@inheritDoc} */ + @Override + public double getPureComponentCpLiquid(double temperature) { + // unit J/mol*K DIPPR function + return 1. / 1000.0 + * (CpLiquid[0] + CpLiquid[1] * temperature + CpLiquid[2] * Math.pow(temperature, 2.0) + + CpLiquid[3] * Math.pow(temperature, 3.0) + CpLiquid[4] * Math.pow(temperature, 4.0)); + } + + /** {@inheritDoc} */ + @Override + public void setCriticalVolume(double criticalVolume) { + this.criticalVolume = criticalVolume; + } + + /** {@inheritDoc} */ + @Override + public double getCriticalViscosity() { + return criticalViscosity; + } + + /** {@inheritDoc} */ + @Override + public void setCriticalViscosity(double criticalViscosity) { + this.criticalViscosity = criticalViscosity; + } + + // return mol/litre + /** {@inheritDoc} */ + @Override + public double getMolarity(PhaseInterface phase) { + return x * 1.0 / (phase.getMolarVolume() * 1e-5) / 1e3; + } + + // return mol/kg + /** {@inheritDoc} */ + @Override + public double getMolality(PhaseInterface phase) { + return getMolarity(phase) / (phase.getDensity() / 1.0e3); + } + + /** {@inheritDoc} */ + @Override + public boolean isHydrateFormer() { + return isIsHydrateFormer(); + } + + /** {@inheritDoc} */ + @Override + public void setIsHydrateFormer(boolean isHydrateFormer) { + this.isHydrateFormer = isHydrateFormer; + } + + /** {@inheritDoc} */ + @Override + public double getmSAFTi() { + return mSAFTi; + } + + /** {@inheritDoc} */ + @Override + public void setmSAFTi(double mSAFTi) { + this.mSAFTi = mSAFTi; + } + + /** {@inheritDoc} */ + @Override + public double getSigmaSAFTi() { + return sigmaSAFTi; + } + + /** {@inheritDoc} */ + @Override + public void setSigmaSAFTi(double sigmaSAFTi) { + this.sigmaSAFTi = sigmaSAFTi; + } + + /** {@inheritDoc} */ + @Override + public double getEpsikSAFT() { + return epsikSAFT; + } + + /** {@inheritDoc} */ + @Override + public void setEpsikSAFT(double epsikSAFT) { + this.epsikSAFT = epsikSAFT; + } + + /** {@inheritDoc} */ + @Override + public double getAssociationVolumeSAFT() { + return associationVolumeSAFT; + } + + /** {@inheritDoc} */ + @Override + public void setAssociationVolumeSAFT(double associationVolumeSAFT) { + this.associationVolumeSAFT = associationVolumeSAFT; + } + + /** {@inheritDoc} */ + @Override + public double getAssociationEnergySAFT() { + return associationEnergySAFT; + } + + /** {@inheritDoc} */ + @Override + public void setAssociationEnergySAFT(double associationEnergySAFT) { + this.associationEnergySAFT = associationEnergySAFT; + } + + /** {@inheritDoc} */ + @Override + public double getCriticalCompressibilityFactor() { + return criticalCompressibilityFactor; + } + + /** {@inheritDoc} */ + @Override + public void setCriticalCompressibilityFactor(double criticalCompressibilityFactor) { + this.criticalCompressibilityFactor = criticalCompressibilityFactor; + } + + /** {@inheritDoc} */ + @Override + public double getSurfaceTenisionInfluenceParameter(double temperature) { + return 1.0; + } + + /** {@inheritDoc} */ + @Override + public void setSurfTensInfluenceParam(int factNum, double val) { + surfTensInfluenceParam[factNum] = val; + } + + /** {@inheritDoc} */ + @Override + public double getSurfTensInfluenceParam(int factNum) { + return surfTensInfluenceParam[factNum]; + } + + /** {@inheritDoc} */ + @Override + public boolean isWaxFormer() { + return waxFormer; + } + + /** {@inheritDoc} */ + @Override + public void setWaxFormer(boolean waxFormer) { + this.waxFormer = waxFormer; + } + + /** {@inheritDoc} */ + @Override + public void setHeatOfFusion(double heatOfFusion) { + this.heatOfFusion = heatOfFusion; + } + + /** {@inheritDoc} */ + @Override + public void setTriplePointTemperature(double triplePointTemperature) { + this.triplePointTemperature = triplePointTemperature; + } + + /** {@inheritDoc} */ + @Override + public void setComponentType(String componentType) { + this.componentType = componentType; + if (componentType.equals("TBP")) { + setIsTBPfraction(true); + } + } + + /** + *

+ * isIsHydrateFormer. + *

+ * + * @return the isHydrateFormer + */ + public boolean isIsHydrateFormer() { + return isHydrateFormer; + } + + /** + *

+ * Getter for the field referenceEnthalpy. + *

+ * + * @return the referenceEnthalpy + */ + public double getReferenceEnthalpy() { + return referenceEnthalpy; + } + + /** + *

+ * Setter for the field referenceEnthalpy. + *

+ * + * @param referenceEnthalpy the referenceEnthalpy to set + */ + public void setReferenceEnthalpy(double referenceEnthalpy) { + this.referenceEnthalpy = referenceEnthalpy; + } + + /** {@inheritDoc} */ + @Override + public double getCpA() { + return CpA; + } + + /** {@inheritDoc} */ + @Override + public void setCpA(double CpA) { + this.CpA = CpA; + } + + /** {@inheritDoc} */ + @Override + public double getCpB() { + return CpB; + } + + /** {@inheritDoc} */ + @Override + public void setCpB(double CpB) { + this.CpB = CpB; + } + + /** {@inheritDoc} */ + @Override + public double getCpC() { + return CpC; + } + + /** {@inheritDoc} */ + @Override + public void setCpC(double CpC) { + this.CpC = CpC; + } + + /** {@inheritDoc} */ + @Override + public double getCpD() { + return CpD + 1e-10; + } + + /** {@inheritDoc} */ + @Override + public void setCpD(double CpD) { + this.CpD = CpD; + } + + /** {@inheritDoc} */ + @Override + public String getFormulae() { + return formulae; + } + + /** {@inheritDoc} */ + @Override + public void setFormulae(String formulae) { + this.formulae = formulae; + } + + /** {@inheritDoc} */ + @Override + public String getCASnumber() { + return CASnumber; + } + + /** {@inheritDoc} */ + @Override + public void setCASnumber(String CASnumber) { + this.CASnumber = CASnumber; + } + + /** {@inheritDoc} */ + @Override + public int getOrginalNumberOfAssociationSites() { + return orginalNumberOfAssociationSites; + } + + /** {@inheritDoc} */ + @Override + public double getdrhodN() { + return molarMass; + } + + /** {@inheritDoc} */ + @Override + public double getCpE() { + return CpE; + } + + /** {@inheritDoc} */ + @Override + public void setCpE(double CpE) { + this.CpE = CpE; + } + + /** {@inheritDoc} */ + @Override + public double getRacketZCPA() { + return racketZCPA; + } + + /** {@inheritDoc} */ + @Override + public void setRacketZCPA(double racketZCPA) { + this.racketZCPA = racketZCPA; + } + + /** {@inheritDoc} */ + @Override + public double getVolumeCorrectionT() { + return volumeCorrectionT; + } + + /** + *

+ * getVolumeCorrection. + *

+ * + * @return a double + */ + public double getVolumeCorrection() { + return 0.0; + } + + /** {@inheritDoc} */ + @Override + public void setVolumeCorrectionConst(double getVolumeCorrectionConst) { + this.volumeCorrectionConst = getVolumeCorrectionConst; + } + + /** {@inheritDoc} */ + @Override + public void setVolumeCorrectionT(double volumeCorrectionT) { + this.volumeCorrectionT = volumeCorrectionT; + } + + /** {@inheritDoc} */ + @Override + public double getVolumeCorrectionT_CPA() { + return volumeCorrectionT_CPA; + } + + /** {@inheritDoc} */ + @Override + public void setVolumeCorrectionT_CPA(double volumeCorrectionT_CPA) { + this.volumeCorrectionT_CPA = volumeCorrectionT_CPA; + } + + /** {@inheritDoc} */ + @Override + public void setIdealGasEnthalpyOfFormation(double idealGasEnthalpyOfFormation) { + this.idealGasEnthalpyOfFormation = idealGasEnthalpyOfFormation; + } + + /** {@inheritDoc} */ + @Override + public double getFlowRate(String flowunit) { + if (flowunit.equals("kg/sec")) { + return numberOfMolesInPhase * getMolarMass(); + } else if (flowunit.equals("kg/min")) { + return numberOfMolesInPhase * getMolarMass() * 60.0; + } else if (flowunit.equals("kg/hr")) { + return numberOfMolesInPhase * getMolarMass() * 3600.0; + } else if (flowunit.equals("m3/hr")) { + return getVoli() / 1.0e5 * 3600.0; + } else if (flowunit.equals("m3/min")) { + return getVoli() / 1.0e5 * 60.0; + } else if (flowunit.equals("m3/sec")) { + return getVoli() / 1.0e5; + } else if (flowunit.equals("mole/sec")) { + return numberOfMolesInPhase; + } else if (flowunit.equals("mole/min")) { + return numberOfMolesInPhase * 60.0; + } else if (flowunit.equals("mole/hr")) { + return numberOfMolesInPhase * 3600.0; + } else { + throw new RuntimeException("failed.. unit: " + flowunit + " not supported"); + } + } + + /** {@inheritDoc} */ + @Override + public double getTotalFlowRate(String flowunit) { + if (flowunit.equals("kg/sec")) { + return numberOfMoles * getMolarMass(); + } else if (flowunit.equals("kg/min")) { + return numberOfMoles * getMolarMass() * 60.0; + } else if (flowunit.equals("kg/hr")) { + return numberOfMoles * getMolarMass() * 3600.0; + } else if (flowunit.equals("mole/sec")) { + return numberOfMoles; + } else if (flowunit.equals("mole/min")) { + return numberOfMoles * 60.0; + } else if (flowunit.equals("mole/hr")) { + return numberOfMoles * 3600.0; + } else { + throw new RuntimeException("failed.. unit: " + flowunit + " not supported"); + } + } + + /** + * Indexed getter for property matiascopemanParamsUMRPRU. + * + * @return array of doubles + */ + public final double[] getMatiascopemanParamsUMRPRU() { + return matiascopemanParamsUMRPRU; + } } diff --git a/src/main/java/neqsim/thermo/component/ComponentEos.java b/src/main/java/neqsim/thermo/component/ComponentEos.java index d5f7af0748..19b1b689f0 100644 --- a/src/main/java/neqsim/thermo/component/ComponentEos.java +++ b/src/main/java/neqsim/thermo/component/ComponentEos.java @@ -7,6 +7,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import neqsim.thermo.component.attractiveEosTerm.AtractiveTermMatCopPRUMRNew; import neqsim.thermo.component.attractiveEosTerm.AttractiveTermCPAstatoil; import neqsim.thermo.component.attractiveEosTerm.AttractiveTermGERG; import neqsim.thermo.component.attractiveEosTerm.AttractiveTermInterface; @@ -176,6 +177,9 @@ public void setAttractiveTerm(int i) { } else { setAttractiveParameter(new AttractiveTermSrk(this)); } + } else if (i == 19) { + setAttractiveParameter( + new AtractiveTermMatCopPRUMRNew(this, getMatiascopemanParamsUMRPRU())); } else { logger.error("error selecting an alpha formultaion term"); logger.info("ok setting alpha function"); @@ -225,23 +229,19 @@ public double dFdN(PhaseInterface phase, int numberOfComponents, double temperat /** {@inheritDoc} */ @Override - public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - return (phase.FBT() + phase.FBD() * phase.getAT()) * getBi() + phase.FDT() * getAi() - + phase.FD() * getAiT(); + public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, double pressure) { + return (phase.FBT() + phase.FBD() * phase.getAT()) * getBi() + phase.FDT() * getAi() + phase.FD() * getAiT(); } /** {@inheritDoc} */ @Override - public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { + public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, double pressure) { return phase.FnV() + phase.FBV() * getBi() + phase.FDV() * getAi(); } /** {@inheritDoc} */ @Override - public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { + public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, double pressure) { ComponentEosInterface[] comp_Array = (ComponentEosInterface[]) phase.getcomponentArray(); return phase.FnB() * (getBi() + comp_Array[j].getBi()) + phase.FBD() * (getBi() * comp_Array[j].getAi() + comp_Array[j].getBi() * getAi()) diff --git a/src/main/java/neqsim/thermo/component/ComponentInterface.java b/src/main/java/neqsim/thermo/component/ComponentInterface.java index a706597294..dce07aa243 100644 --- a/src/main/java/neqsim/thermo/component/ComponentInterface.java +++ b/src/main/java/neqsim/thermo/component/ComponentInterface.java @@ -2208,6 +2208,7 @@ static public LinkedHashMap getComponentMap() { c.put("nC7", "n-heptane"); c.put("nC8", "n-octane"); c.put("nC9", "n-nonane"); + c.put("O2", "oxygen"); return c; } } diff --git a/src/main/java/neqsim/thermo/component/ComponentPRvolcor.java b/src/main/java/neqsim/thermo/component/ComponentPRvolcor.java new file mode 100644 index 0000000000..a34e6edddf --- /dev/null +++ b/src/main/java/neqsim/thermo/component/ComponentPRvolcor.java @@ -0,0 +1,191 @@ +/* + * System_SRK_EOS.java + * + * Created on 8. april 2000, 23:14 + */ +package neqsim.thermo.component; + +import neqsim.thermo.phase.PhaseInterface; +import neqsim.thermo.phase.PhasePrEosvolcor; + +/** + * + * @author Even Solbraa + * @version + */ +public class ComponentPRvolcor extends ComponentPR { + + private static final long serialVersionUID = 1000; + private double c; + // private double calcc; + public double[] Cij = new double[MAX_NUMBER_OF_COMPONENTS]; + public double Ci = 0; + public ComponentPRvolcor(int number, double TC, double PC, double M, double a, double moles) { + super(number, TC, PC, M, a, moles); + } + + /// ** {@inheritDoc} */ + // @Override + public double calcc() { + return (0.1154 - 0.4406 * (0.29056 - 0.08775 * getAcentricFactor())) * R * criticalTemperature + / criticalPressure; + } + + // derivative of translation with regards to temperature + public double calccT() { + return 0.; + } + + // second derivative of translation with regards to temperature*temperature + public double calccTT() { + return 0.; + } + + + public ComponentPRvolcor(String component_name, double moles, double molesInPhase, + int compnumber) { + super(component_name, moles, molesInPhase, compnumber); + c = (0.1154 - 0.4406 * (0.29056 - 0.08775 * getAcentricFactor())) * R * criticalTemperature + / criticalPressure; + + } + + /** {@inheritDoc} */ + @Override + public void init(double temp, double pres, double totMoles, double beta, int type) { + super.init(temp, pres, totMoles, beta, type); + c = calcc(); + } + + + /** {@inheritDoc} */ + // @Override + public double getc() { + return c; + } + + public double getcT() { + return 0; + } + + // derivative of C with regards to mole fraction + /** {@inheritDoc} */ + @Override + public void Finit(PhaseInterface phase, double temp, double pres, double totMoles, double beta, + int numberOfComponents, int type) + { + super.Finit(phase, temp, pres, totMoles, beta, numberOfComponents, type); + Ci = ((PhasePrEosvolcor) phase).calcCi(componentNumber, phase, temp, pres, numberOfComponents); + if (type >= 2) { + ((PhasePrEosvolcor) phase).calcCiT(componentNumber, phase, temp, pres, + numberOfComponents); + } + + if (type >= 3) { + for (int j = 0; j < numberOfComponents; j++) { + Cij[j] = ((PhasePrEosvolcor) phase).calcCij(componentNumber, j, phase, temp, pres, + numberOfComponents); + } + } + } + + + public double getCi() { + return Ci; + } + + + public double getCij(int j) { + return Cij[j]; + } + + // depending on the type of the volume translation (T-dependent or not) these sould be properly + // modified + + + // second derivative of C with regards to mole fraction and temperature + public double getCiT() { + return 0; + } + + public double getcTT() { + return 0; + } + + + + /// ** {@inheritDoc} */ do I need this inheritDoc thing? + @Override + public double dFdN(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + return phase.Fn() + phase.FB() * getBi() + phase.FD() * getAi() + + ((PhasePrEosvolcor) phase).FC() * getCi(); + } + + public double getFC(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + return ((PhasePrEosvolcor) phase).FC(); + } + + + /** {@inheritDoc} */ + @Override + public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double loc_CT = ((PhasePrEosvolcor) phase).getCT(); + double loc_FnC = ((PhasePrEosvolcor) phase).FnC(); + double loc_FBC = ((PhasePrEosvolcor) phase).FBC(); + double loc_FCD = ((PhasePrEosvolcor) phase).FCD(); + double loc_FC = ((PhasePrEosvolcor) phase).FC(); + double loc_FCT = ((PhasePrEosvolcor) phase).FTC(); + double loc_FCC = ((PhasePrEosvolcor) phase).FCC(); + + return loc_FnC * loc_CT + + (phase.FBT() + phase.FBD() * phase.getAT() + loc_FBC * loc_CT) * getBi() + + (loc_FCD * loc_CT + phase.FDT()) * getAi() + + (loc_FCT + loc_FCC * loc_CT + loc_FCD * phase.getAT()) * getCi() + phase.FD() * getAiT() + + loc_FC * getCiT(); + } + + /** {@inheritDoc} */ + @Override + public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double loc_FnC = ((PhasePrEosvolcor) phase).FnC(); + double loc_FBC = ((PhasePrEosvolcor) phase).FBC(); + double loc_FCD = ((PhasePrEosvolcor) phase).FCD(); + double loc_FC = ((PhasePrEosvolcor) phase).FC(); + double loc_FCC = ((PhasePrEosvolcor) phase).FCC(); + ComponentEosInterface[] comp_Array = (ComponentEosInterface[]) phase.getcomponentArray(); + // return phase.FnB() * (getBi() + comp_Array[j].getBi()) + // + phase.FBD() * (getBi() * comp_Array[j].getAi() + comp_Array[j].getBi() * getAi()) + // + phase.FB() * getBij(j) + phase.FBB() * getBi() * comp_Array[j].getBi() + // + phase.FD() * getAij(j); + double loc_Cj = ((ComponentPRvolcor) comp_Array[j]).getCi(); + // double loc_Ci= ((ComponentPRvolcor))component.getCi(); + return phase.FnB() * comp_Array[j].getBi() + loc_FnC * loc_Cj + + (phase.FnB() + phase.FBB() * comp_Array[j].getBi() + loc_FBC * loc_Cj + + phase.FBD() * comp_Array[j].getAi()) * getBi() + + phase.FB() * getBij(j) + + (loc_FnC + loc_FCC * loc_Cj + loc_FBC * comp_Array[j].getBi() + + loc_FCD * comp_Array[j].getAi()) * getCi() + + loc_FC * getCij(j) + (loc_FCD * loc_Cj + phase.FBD() * comp_Array[j].getBi()) * getAi() + + phase.FD() * getAij(j); + } + + + /** {@inheritDoc} */ + @Override + public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double loc_FCV = ((PhasePrEosvolcor) phase).FCV(); + return phase.FnV() + phase.FBV() * getBi() + phase.FDV() * getAi() + loc_FCV * getCi(); + } + + + + // Remember this trick above that professor showed to you...you can call whichever new F + // expression + // you need by first specifying the type "PhasePrEosvolcor" + +} diff --git a/src/main/java/neqsim/thermo/component/ComponentSrkCPA.java b/src/main/java/neqsim/thermo/component/ComponentSrkCPA.java index 6581a30c3c..1bc9bbbb4c 100644 --- a/src/main/java/neqsim/thermo/component/ComponentSrkCPA.java +++ b/src/main/java/neqsim/thermo/component/ComponentSrkCPA.java @@ -13,642 +13,652 @@ * @version $Id: $Id */ public class ComponentSrkCPA extends ComponentSrk implements ComponentCPAInterface { - private static final long serialVersionUID = 1000; - - int cpaon = 1; - double[] xsite = new double[0]; - private double[][] xsitedni = new double[0][0]; - double[] xsiteOld = new double[0]; - double[] xsitedV = new double[0]; - double[] xsitedT = new double[0]; - double[] xsitedTdT = new double[0]; - - /** - *

- * Constructor for ComponentSrkCPA. - *

- * - * @param component_name a {@link java.lang.String} object - * @param moles a double - * @param molesInPhase a double - * @param compnumber a int + private static final long serialVersionUID = 1000; + + int cpaon = 1; + double[] xsite = new double[0]; + private double[][] xsitedni = new double[0][0]; + double[] xsiteOld = new double[0]; + double[] xsitedV = new double[0]; + double[] xsitedT = new double[0]; + double[] xsitedTdT = new double[0]; + + /** + *

+ * Constructor for ComponentSrkCPA. + *

+ * + * @param component_name a {@link java.lang.String} object + * @param moles a double + * @param molesInPhase a double + * @param compnumber a int + */ + public ComponentSrkCPA(String component_name, double moles, double molesInPhase, int compnumber) { + super(component_name, moles, molesInPhase, compnumber); + xsite = new double[numberOfAssociationSites]; + xsitedni = new double[numberOfAssociationSites][100]; + xsitedV = new double[numberOfAssociationSites]; + xsitedT = new double[numberOfAssociationSites]; + xsitedTdT = new double[numberOfAssociationSites]; + xsiteOld = new double[numberOfAssociationSites]; + if (numberOfAssociationSites != 0 && cpaon == 1) { + // System.out.println("ass sites: " + numberOfAssociationSites); + // System.out.println("aSRK " + a + " aCPA " + aCPA); + // System.out.println("bSRK " + b + " bCPA " + bCPA); + for (int j = 0; j < getNumberOfAssociationSites(); j++) { + setXsite(j, 1.0); + setXsiteOld(j, 1.0); + setXsitedV(j, 0.0); + setXsitedT(j, 0.0); + } + if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + a = aCPA; + b = bCPA; + } + setAttractiveTerm(0); + } + // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, + // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; + // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; + } + + /** + *

+ * Constructor for ComponentSrkCPA. + *

+ * + * @param number a int + * @param TC a double + * @param PC a double + * @param M a double + * @param a a double + * @param moles a double + */ + public ComponentSrkCPA(int number, double TC, double PC, double M, double a, double moles) { + super(number, TC, PC, M, a, moles); + xsite = new double[numberOfAssociationSites]; + xsitedni = new double[numberOfAssociationSites][100]; + xsitedV = new double[numberOfAssociationSites]; + xsitedT = new double[numberOfAssociationSites]; + xsitedTdT = new double[numberOfAssociationSites]; + xsiteOld = new double[numberOfAssociationSites]; + if (numberOfAssociationSites != 0 && cpaon == 1) { + for (int j = 0; j < getNumberOfAssociationSites(); j++) { + setXsite(j, 1.0); + setXsiteOld(j, 1.0); + setXsitedV(j, 0.0); + setXsitedT(j, 0.0); + } + if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + a = aCPA; + b = bCPA; + } + setAttractiveTerm(0); + } + // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, + // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; + // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; + } + + /** {@inheritDoc} */ + @Override + public ComponentSrkCPA clone() { + ComponentSrkCPA clonedComponent = null; + try { + clonedComponent = (ComponentSrkCPA) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + + clonedComponent.xsite = xsite.clone(); + System.arraycopy(this.xsite, 0, clonedComponent.xsite, 0, xsite.length); + clonedComponent.xsiteOld = xsiteOld.clone(); + System.arraycopy(this.xsiteOld, 0, clonedComponent.xsiteOld, 0, xsiteOld.length); + clonedComponent.xsitedV = xsitedV.clone(); + System.arraycopy(this.xsitedV, 0, clonedComponent.xsitedV, 0, xsitedV.length); + clonedComponent.xsitedT = xsitedT.clone(); + System.arraycopy(this.xsitedT, 0, clonedComponent.xsitedT, 0, xsitedT.length); + clonedComponent.xsitedTdT = xsitedTdT.clone(); + System.arraycopy(this.xsitedTdT, 0, clonedComponent.xsitedTdT, 0, xsitedTdT.length); + clonedComponent.xsitedni = xsitedni.clone(); + System.arraycopy(this.xsitedni, 0, clonedComponent.xsitedni, 0, xsitedni.length); + return clonedComponent; + } + + /** {@inheritDoc} */ + @Override + public double getVolumeCorrection() { + if ((getRacketZCPA() < 1.0e-10) && cpaon == 1) { + return 0.0; + } else { + setVolumeCorrectionT(getVolumeCorrectionT_CPA()); + setRacketZ(getRacketZCPA()); + return super.getVolumeCorrection(); + } + } + + /** {@inheritDoc} */ + @Override + public void init(double temperature, double pressure, double totalNumberOfMoles, double beta, + int type) { + super.init(temperature, pressure, totalNumberOfMoles, beta, type); + } + + /** {@inheritDoc} */ + @Override + public void setAttractiveTerm(int i) { + super.setAttractiveTerm(i); + if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + getAttractiveTerm().setm(mCPA); + } + } + + /** {@inheritDoc} */ + @Override + public void seta(double a) { + aCPA = a; + } + + /** {@inheritDoc} */ + @Override + public void setb(double a) { + bCPA = a; + } + + /** {@inheritDoc} */ + @Override + public double calca() { + if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + return aCPA; + } else { + return super.calca(); + } + } + + /** {@inheritDoc} */ + @Override + public double calcb() { + if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + return bCPA; + } else { + return super.calcb(); + } + } + + /** {@inheritDoc} */ + @Override + public double dFdN(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double Fsup = super.dFdN(phase, numberOfComponents, temperature, pressure); + double Fcpa = 0.0; + // if(phase.getPhaseType()==1) cpaon=0; + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + Fcpa = dFCPAdN(phase, numberOfComponents, temperature, pressure); + } + // System.out.println("Fsup " + Fsup + " fcpa " + Fcpa); + // System.out.println("i " + componentNumber + " dFCPAdn " + Fcpa); + return Fsup + cpaon * Fcpa; + } + + /** {@inheritDoc} */ + @Override + public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdT(phase, numberOfComponents, temperature, pressure) + + dFCPAdNdT(phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdT(phase, numberOfComponents, temperature, pressure); + } + } + + /** {@inheritDoc} */ + @Override + public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + // System.out.println("dQdndV " + dFCPAdNdV(phase, numberOfComponents, + // temperature, pressure) + " dFdndV " + super.dFdNdV(phase, numberOfComponents, + // temperature, pressure)); + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdV(phase, numberOfComponents, temperature, pressure) + + dFCPAdNdV(phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdV(phase, numberOfComponents, temperature, pressure); + } + } + + /** {@inheritDoc} */ + @Override + public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + // System.out.println("ij " + componentNumber + " " + j + " dQCPAdndn " + + // dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure)+ " dQsrkdndn " + // + super.dFdNdN(j, phase, numberOfComponents, temperature, pressure)); + // System.out.println("dFdndn " +(super.dFdNdN(j, phase, numberOfComponents, + // temperature, pressure) + dFCPAdNdN(j, phase, numberOfComponents, temperature, + // pressure))); + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure) + + dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure); + } + } + + /** + *

+ * dFCPAdNdN. + *

+ * + * @param j a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double temp1 = 0; + for (int i = 0; i < numberOfAssociationSites; i++) { + temp1 += 1.0 / getXsite()[i] * getXsitedni(i, j); + } + double tot2 = 0.0; + for (int i = 0; i < phase.getComponent(j).getNumberOfAssociationSites(); i++) { + tot2 += calc_lngi(phase) * (1.0 - ((ComponentSrkCPA) phase.getComponent(j)).getXsite()[i]); + } + double tot1 = 1.0 / 2.0 * tot2; + + double tot4 = 0.0; + tot4 = 0.5 * ((PhaseCPAInterface) phase).getHcpatot() * calc_lngij(j, phase); + double tot10 = 0.0; + for (int kk = 0; kk < phase.getNumberOfComponents(); kk++) { + for (int k = 0; k < phase.getComponent(kk).getNumberOfAssociationSites(); k++) { + tot10 += -phase.getComponent(kk).getNumberOfMolesInPhase() + * ((ComponentSrkCPA) phase.getComponent(kk)).getXsitedni(k, j); + } + } + double tot11 = tot10 / 2.0 * calc_lngi(phase); + + // System.out.println("dFCPAdndn " + (temp1 - tot1 - tot4 - tot11)); + return temp1 - tot1 - tot4 - tot11; + } + + /** + *

+ * dFCPAdN. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdN(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += Math.log(xsite[i]); + } + // System.out.println("dFCPAdn " + ((xi - ((PhaseCPAInterface) + // phase).getHcpatot() / 2.0 * calc_lngi(phase)))+ " " + componentNumber); + return (xi - ((PhaseCPAInterface) phase).getHcpatot() / 2.0 * calc_lngi(phase)); + } + + /** + *

+ * dFCPAdNdV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdV(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += (1.0 / xsite[i]) * xsitedV[i]; + } + + double[] tempar = ((PhaseSrkCPA) phase).getdFdNtemp(); + // double temp = calc_lngi(phase); + // double temp2 = calc_lngidV(phase); + /* + * double tot1 = 0.0, tot2 = 0.0, tot3 = 0.0, tot4 = 0.0, temp, temp2; for (int k = 0; k < + * phase.getNumberOfComponents(); k++) { tot2 = 0.0; tot3 = 0.0; temp = calc_lngi(phase); temp2 + * = calc_lngidV(phase); for (int i = 0; i < + * phase.getComponent(k).getNumberOfAssociationSites(); i++) { tot2 -= temp * ((ComponentSrkCPA) + * phase.getComponent(k)).getXsitedV()[i]; tot3 += (1.0 - ((ComponentSrkCPA) + * phase.getComponent(k)).getXsite()[i]) * temp2; } tot1 += 1.0 / 2.0 * tot2 * + * phase.getComponent(k).getNumberOfMolesInPhase(); tot4 += 0.5 * + * phase.getComponent(k).getNumberOfMolesInPhase() * tot3; } */ - public ComponentSrkCPA(String component_name, double moles, double molesInPhase, - int compnumber) { - super(component_name, moles, molesInPhase, compnumber); - xsite = new double[numberOfAssociationSites]; - xsitedni = new double[numberOfAssociationSites][100]; - xsitedV = new double[numberOfAssociationSites]; - xsitedT = new double[numberOfAssociationSites]; - xsitedTdT = new double[numberOfAssociationSites]; - xsiteOld = new double[numberOfAssociationSites]; - if (numberOfAssociationSites != 0 && cpaon == 1) { - // System.out.println("ass sites: " + numberOfAssociationSites); - // System.out.println("aSRK " + a + " aCPA " + aCPA); - // System.out.println("bSRK " + b + " bCPA " + bCPA); - for (int j = 0; j < getNumberOfAssociationSites(); j++) { - setXsite(j, 1.0); - setXsiteOld(j, 1.0); - setXsitedV(j, 0.0); - setXsitedT(j, 0.0); - } - if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { - a = aCPA; - b = bCPA; - } - setAttractiveTerm(0); - } - // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, - // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; - // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; - } - - /** - *

- * Constructor for ComponentSrkCPA. - *

- * - * @param number a int - * @param TC a double - * @param PC a double - * @param M a double - * @param a a double - * @param moles a double - */ - public ComponentSrkCPA(int number, double TC, double PC, double M, double a, double moles) { - super(number, TC, PC, M, a, moles); - xsite = new double[numberOfAssociationSites]; - xsitedni = new double[numberOfAssociationSites][100]; - xsitedV = new double[numberOfAssociationSites]; - xsitedT = new double[numberOfAssociationSites]; - xsitedTdT = new double[numberOfAssociationSites]; - xsiteOld = new double[numberOfAssociationSites]; - if (numberOfAssociationSites != 0 && cpaon == 1) { - for (int j = 0; j < getNumberOfAssociationSites(); j++) { - setXsite(j, 1.0); - setXsiteOld(j, 1.0); - setXsitedV(j, 0.0); - setXsitedT(j, 0.0); - } - if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { - a = aCPA; - b = bCPA; - } - setAttractiveTerm(0); - } - // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, - // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; - // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; - } - - /** {@inheritDoc} */ - @Override - public ComponentSrkCPA clone() { - ComponentSrkCPA clonedComponent = null; - try { - clonedComponent = (ComponentSrkCPA) super.clone(); - } catch (Exception e) { - logger.error("Cloning failed.", e); - } - - clonedComponent.xsite = xsite.clone(); - System.arraycopy(this.xsite, 0, clonedComponent.xsite, 0, xsite.length); - clonedComponent.xsiteOld = xsiteOld.clone(); - System.arraycopy(this.xsiteOld, 0, clonedComponent.xsiteOld, 0, xsiteOld.length); - clonedComponent.xsitedV = xsitedV.clone(); - System.arraycopy(this.xsitedV, 0, clonedComponent.xsitedV, 0, xsitedV.length); - clonedComponent.xsitedT = xsitedT.clone(); - System.arraycopy(this.xsitedT, 0, clonedComponent.xsitedT, 0, xsitedT.length); - clonedComponent.xsitedTdT = xsitedTdT.clone(); - System.arraycopy(this.xsitedTdT, 0, clonedComponent.xsitedTdT, 0, xsitedTdT.length); - clonedComponent.xsitedni = xsitedni.clone(); - System.arraycopy(this.xsitedni, 0, clonedComponent.xsitedni, 0, xsitedni.length); - return clonedComponent; - } - - /** {@inheritDoc} */ - @Override - public double getVolumeCorrection() { - if ((getRacketZCPA() < 1.0e-10) && cpaon == 1) { - return 0.0; - } else { - setVolumeCorrectionT(getVolumeCorrectionT_CPA()); - setRacketZ(getRacketZCPA()); - return super.getVolumeCorrection(); - } - } - - /** {@inheritDoc} */ - @Override - public void init(double temperature, double pressure, double totalNumberOfMoles, double beta, - int type) { - super.init(temperature, pressure, totalNumberOfMoles, beta, type); - } - - /** {@inheritDoc} */ - @Override - public void setAttractiveTerm(int i) { - super.setAttractiveTerm(i); - if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { - getAttractiveTerm().setm(mCPA); - } - } - - /** {@inheritDoc} */ - @Override - public void seta(double a) { - aCPA = a; - } - - /** {@inheritDoc} */ - @Override - public void setb(double a) { - bCPA = a; - } - - /** {@inheritDoc} */ - @Override - public double calca() { - if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { - return aCPA; - } else { - return super.calca(); - } - } - - /** {@inheritDoc} */ - @Override - public double calcb() { - if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { - return bCPA; - } else { - return super.calcb(); - } - } - - /** {@inheritDoc} */ - @Override - public double dFdN(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - double Fsup = super.dFdN(phase, numberOfComponents, temperature, pressure); - double Fcpa = 0.0; - // if(phase.getPhaseType()==1) cpaon=0; - if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { - Fcpa = dFCPAdN(phase, numberOfComponents, temperature, pressure); - } - // System.out.println("Fsup " + Fsup + " fcpa " + Fcpa); - // System.out.println("i " + componentNumber + " dFCPAdn " + Fcpa); - return Fsup + cpaon * Fcpa; - } - - /** {@inheritDoc} */ - @Override - public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { - return super.dFdNdT(phase, numberOfComponents, temperature, pressure) - + dFCPAdNdT(phase, numberOfComponents, temperature, pressure); - } else { - return super.dFdNdT(phase, numberOfComponents, temperature, pressure); - } - } - - /** {@inheritDoc} */ - @Override - public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - // System.out.println("dQdndV " + dFCPAdNdV(phase, numberOfComponents, - // temperature, pressure) + " dFdndV " + super.dFdNdV(phase, numberOfComponents, - // temperature, pressure)); - if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { - return super.dFdNdV(phase, numberOfComponents, temperature, pressure) - + dFCPAdNdV(phase, numberOfComponents, temperature, pressure); - } else { - return super.dFdNdV(phase, numberOfComponents, temperature, pressure); - } - } - - /** {@inheritDoc} */ - @Override - public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - // System.out.println("ij " + componentNumber + " " + j + " dQCPAdndn " + - // dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure)+ " dQsrkdndn " - // + super.dFdNdN(j, phase, numberOfComponents, temperature, pressure)); - // System.out.println("dFdndn " +(super.dFdNdN(j, phase, numberOfComponents, - // temperature, pressure) + dFCPAdNdN(j, phase, numberOfComponents, temperature, - // pressure))); - if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { - return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure) - + dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure); - } else { - return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure); - } - } - - /** - *

- * dFCPAdNdN. - *

- * - * @param j a int - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @param numberOfComponents a int - * @param temperature a double - * @param pressure a double - * @return a double - */ - public double dFCPAdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - double temp1 = 0; - for (int i = 0; i < numberOfAssociationSites; i++) { - temp1 += 1.0 / getXsite()[i] * getXsitedni(i, j); - } - double tot2 = 0.0; - for (int i = 0; i < phase.getComponent(j).getNumberOfAssociationSites(); i++) { - tot2 += calc_lngi(phase) - * (1.0 - ((ComponentSrkCPA) phase.getComponent(j)).getXsite()[i]); - } - double tot1 = 1.0 / 2.0 * tot2; - - double tot4 = 0.0; - tot4 = 0.5 * ((PhaseCPAInterface) phase).getHcpatot() * calc_lngij(j, phase); - double tot10 = 0.0; - for (int kk = 0; kk < phase.getNumberOfComponents(); kk++) { - for (int k = 0; k < phase.getComponent(kk).getNumberOfAssociationSites(); k++) { - tot10 += -phase.getComponent(kk).getNumberOfMolesInPhase() - * ((ComponentSrkCPA) phase.getComponent(kk)).getXsitedni(k, j); - } - } - double tot11 = tot10 / 2.0 * calc_lngi(phase); - - // System.out.println("dFCPAdndn " + (temp1 - tot1 - tot4 - tot11)); - return temp1 - tot1 - tot4 - tot11; - } - - /** - *

- * dFCPAdN. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @param numberOfComponents a int - * @param temperature a double - * @param pressure a double - * @return a double - */ - public double dFCPAdN(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - double xi = 0.0; - for (int i = 0; i < numberOfAssociationSites; i++) { - xi += Math.log(xsite[i]); - } - // System.out.println("dFCPAdn " + ((xi - ((PhaseCPAInterface) - // phase).getHcpatot() / 2.0 * calc_lngi(phase)))+ " " + componentNumber); - return (xi - ((PhaseCPAInterface) phase).getHcpatot() / 2.0 * calc_lngi(phase)); - } - - /** - *

- * dFCPAdNdV. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @param numberOfComponents a int - * @param temperature a double - * @param pressure a double - * @return a double - */ - public double dFCPAdNdV(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - double xi = 0.0; - for (int i = 0; i < numberOfAssociationSites; i++) { - xi += (1.0 / xsite[i]) * xsitedV[i]; - } - - double[] tempar = ((PhaseSrkCPA) phase).getdFdNtemp(); - // double temp = calc_lngi(phase); - // double temp2 = calc_lngidV(phase); - /* - * double tot1 = 0.0, tot2 = 0.0, tot3 = 0.0, tot4 = 0.0, temp, temp2; for (int k = 0; k < - * phase.getNumberOfComponents(); k++) { tot2 = 0.0; tot3 = 0.0; temp = calc_lngi(phase); - * temp2 = calc_lngidV(phase); for (int i = 0; i < - * phase.getComponent(k).getNumberOfAssociationSites(); i++) { tot2 -= temp * - * ((ComponentSrkCPA) phase.getComponent(k)).getXsitedV()[i]; tot3 += (1.0 - - * ((ComponentSrkCPA) phase.getComponent(k)).getXsite()[i]) * temp2; } tot1 += 1.0 / 2.0 * - * tot2 * phase.getComponent(k).getNumberOfMolesInPhase(); tot4 += 0.5 * - * phase.getComponent(k).getNumberOfMolesInPhase() * tot3; } - */ - // System.out.println("dFCPAdndV " + (xi - tot1 - tot4)); - return xi + tempar[0] * calc_lngi(phase) + tempar[1] * calc_lngidV(phase);// - tot1 - tot4; - } - - /** - *

- * dFCPAdNdT. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @param numberOfComponents a int - * @param temperature a double - * @param pressure a double - * @return a double - */ - public double dFCPAdNdT(PhaseInterface phase, int numberOfComponents, double temperature, - double pressure) { - double xi = 0.0; - for (int i = 0; i < numberOfAssociationSites; i++) { - xi += 1.0 / xsite[i] * xsitedT[i]; - } - - double tot1 = 0.0, tot2 = 0.0; - for (int k = 0; k < phase.getNumberOfComponents(); k++) { - tot2 = 0.0; - for (int i = 0; i < phase.getComponent(k).getNumberOfAssociationSites(); i++) { - tot2 -= ((ComponentSrkCPA) phase.getComponent(k)).getXsitedT()[i]; - } - tot1 += tot2 * phase.getComponent(k).getNumberOfMolesInPhase(); - } - // System.out.println("dFCPAdndT " + (xi - 1.0 / 2.0 * calc_lngi(phase) * - // tot1)); - // System.out.println("dlngdni " + calc_lngi(phase)); - return xi - 1.0 / 2.0 * calc_lngi(phase) * tot1; - } - - /** - *

- * calc_hCPAdn. - *

- * - * @return a double - */ - public double calc_hCPAdn() { - double hdn = 0.0; - for (int i = 0; i < getNumberOfAssociationSites(); i++) { - hdn = 1.0 - getXsite()[i]; - } - return hdn; - } - - /** {@inheritDoc} */ - @Override - public double dFCPAdXi(int site, PhaseInterface phase) { - return getNumberOfMolesInPhase() * (1.0 / xsite[site] - 1.0 / 2.0); - } - - /** - *

- * dFCPAdXidni. - *

- * - * @param site a int - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public double dFCPAdXidni(int site, PhaseInterface phase) { - return (1.0 / xsite[site] - 1.0 / 2.0); - } - - /** {@inheritDoc} */ - @Override - public double dFCPAdXidXj(int sitei, int sitej, int compj, PhaseInterface phase) { - double fact = 0.0; - if (sitei == sitej && compj == componentNumber) { - fact = 1.0; - } - return -getNumberOfMolesInPhase() / Math.pow(xsite[sitei], 2.0) * fact - - getNumberOfMolesInPhase() * phase.getComponent(compj).getNumberOfMolesInPhase() - * ((PhaseCPAInterface) phase).getCpamix().calcDelta(sitei, sitej, - componentNumber, compj, phase, phase.getTemperature(), - phase.getPressure(), phase.getNumberOfComponents()); - } - - /** {@inheritDoc} */ - @Override - public double dFCPAdVdXi(int site, PhaseInterface phase) { - return -1.0 / (2.0 * phase.getTotalVolume()) - * (1.0 - phase.getTotalVolume() * ((PhaseCPAInterface) phase).getGcpav()) - * getNumberOfMolesInPhase(); - } - - /** {@inheritDoc} */ - @Override - public double dFCPAdNdXi(int site, PhaseInterface phase) { - double xi = 1.0 / xsite[site]; - - // return xi - tempp; - return xi + getNumberOfMolesInPhase() / 2.0 * calc_lngi(phase); - } - - /** - *

- * dFCPAdNdXidXdV. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public double dFCPAdNdXidXdV(PhaseInterface phase) { - double temp = 0.0; - for (int i = 0; i < numberOfAssociationSites; i++) { - temp += dFCPAdNdXi(i, phase) * getXsitedV()[i]; - } - return temp; - } - - /** - *

- * calc_lngi. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public double calc_lngi(PhaseInterface phase) { - return 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) - / ((8.0 * phase.getTotalVolume() - phase.getB()) - * (4.0 * phase.getTotalVolume() - phase.getB())); - } - - /** - *

- * calc_lngidV. - *

- * - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public double calc_lngidV(PhaseInterface phase) { - return 2.0 * getBi() * (10.0) - / ((8.0 * phase.getTotalVolume() - phase.getB()) - * (4.0 * phase.getTotalVolume() - phase.getB())) - - 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) - * (2.0 * 32.0 * phase.getTotalVolume() - 12.0 * phase.getB()) - / Math.pow(((8.0 * phase.getTotalVolume() - phase.getB()) - * (4.0 * phase.getTotalVolume() - phase.getB())), 2.0); - } - - /** - *

- * calc_lngij. - *

- * - * @param j a int - * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object - * @return a double - */ - public double calc_lngij(int j, PhaseInterface phase) { - return 2.0 * getBij(j) * (10.0 * phase.getTotalVolume() - phase.getB()) - / ((8.0 * phase.getTotalVolume() - phase.getB()) - * (4.0 * phase.getTotalVolume() - phase.getB())); - } - - /** {@inheritDoc} */ - @Override - public double[] getXsite() { - return this.xsite; - } - - /** - * Setter for property xsite. - * - * @param xsite New value of property xsite. - */ - public void setXsite(double[] xsite) { - this.xsite = xsite; - } - - /** {@inheritDoc} */ - @Override - public void setXsite(int i, double xsite) { - this.xsite[i] = xsite; - } - - /** {@inheritDoc} */ - @Override - public double[] getXsitedV() { - return this.xsitedV; - } - - /** {@inheritDoc} */ - @Override - public void setXsitedV(int i, double xsitedV) { - this.xsitedV[i] = xsitedV; - } - - /** {@inheritDoc} */ - @Override - public double[] getXsitedT() { - return this.xsitedT; - } - - /** {@inheritDoc} */ - @Override - public double[] getXsitedTdT() { - return this.xsitedTdT; - } - - /** {@inheritDoc} */ - @Override - public void setXsitedT(int i, double xsitedT) { - this.xsitedT[i] = xsitedT; - } - - /** {@inheritDoc} */ - @Override - public void setXsitedTdT(int i, double xsitedTdT) { - this.xsitedTdT[i] = xsitedTdT; - } - - /** {@inheritDoc} */ - @Override - public double[] getXsiteOld() { - return this.xsiteOld; - } - - /** - * Setter for property xsite. - * - * @param xsiteOld an array of {@link double} objects - */ - public void setXsiteOld(double[] xsiteOld) { - this.xsiteOld = xsiteOld; - } - - /** {@inheritDoc} */ - @Override - public void setXsiteOld(int i, double xsiteOld) { - this.xsiteOld[i] = xsiteOld; - } - - /** - *

- * Getter for the field xsitedni. - *

- * - * @return the xsitedni - */ - public double[][] getXsitedni() { - return xsitedni; - } - - /** - *

- * Getter for the field xsitedni. - *

- * - * @param xNumb a int - * @param compNumbi a int - * @return a double - */ - public double getXsitedni(int xNumb, int compNumbi) { - return xsitedni[xNumb][compNumbi]; - } - - /** - *

- * Setter for the field xsitedni. - *

- * - * @param xsitedni the xsitedni to set - */ - public void setXsitedni(double[][] xsitedni) { - this.xsitedni = xsitedni; - } - - /** {@inheritDoc} */ - @Override - public void setXsitedni(int xnumb, int compnumb, double val) { - xsitedni[xnumb][compnumb] = val; - } - - /** {@inheritDoc} */ - @Override - public double getSurfaceTenisionInfluenceParameter(double temperature) { - double AA = 0, BB = 0; - if (componentName.equals("water")) { - double TR = 1.0 - temperature / getTC(); - AA = -2.2367E-16; - BB = 2.83732E-16; - // return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); - - double AAW1 = 2.2505E-16; - double AAW2 = -1.3646E-16; - - return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) - * (AAW1 + AAW2 * TR + 0.5113e-16 * TR * TR); - } // old - else if (componentName.equals("water2")) { /// THis is the old method from - double TR = 1.0 - temperature / getTC(); - AA = -2.2367E-16; - BB = 2.83732E-16; - return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); - } else if (componentName.equals("MEG")) { - return 1.04874809905393E-19; - } else if (componentName.equals("TEG")) { - return 7.46824658716429E-19; - } else { - return super.getSurfaceTenisionInfluenceParameter(temperature); - } - } + // System.out.println("dFCPAdndV " + (xi - tot1 - tot4)); + return xi + tempar[0] * calc_lngi(phase) + tempar[1] * calc_lngidV(phase);// - tot1 - tot4; + } + + /** + *

+ * dFCPAdNdT. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdT(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += 1.0 / xsite[i] * xsitedT[i]; + } + + double tot1 = 0.0, tot2 = 0.0; + for (int k = 0; k < phase.getNumberOfComponents(); k++) { + tot2 = 0.0; + for (int i = 0; i < phase.getComponent(k).getNumberOfAssociationSites(); i++) { + tot2 -= ((ComponentSrkCPA) phase.getComponent(k)).getXsitedT()[i]; + } + tot1 += tot2 * phase.getComponent(k).getNumberOfMolesInPhase(); + } + // System.out.println("dFCPAdndT " + (xi - 1.0 / 2.0 * calc_lngi(phase) * + // tot1)); + // System.out.println("dlngdni " + calc_lngi(phase)); + return xi - 1.0 / 2.0 * calc_lngi(phase) * tot1; + } + + /** + *

+ * calc_hCPAdn. + *

+ * + * @return a double + */ + public double calc_hCPAdn() { + double hdn = 0.0; + for (int i = 0; i < getNumberOfAssociationSites(); i++) { + hdn = 1.0 - getXsite()[i]; + } + return hdn; + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdXi(int site, PhaseInterface phase) { + return getNumberOfMolesInPhase() * (1.0 / xsite[site] - 1.0 / 2.0); + } + + /** + *

+ * dFCPAdXidni. + *

+ * + * @param site a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double dFCPAdXidni(int site, PhaseInterface phase) { + return (1.0 / xsite[site] - 1.0 / 2.0); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdXidXj(int sitei, int sitej, int compj, PhaseInterface phase) { + double fact = 0.0; + if (sitei == sitej && compj == componentNumber) { + fact = 1.0; + } + return -getNumberOfMolesInPhase() / Math.pow(xsite[sitei], 2.0) * fact + - getNumberOfMolesInPhase() * phase.getComponent(compj).getNumberOfMolesInPhase() + * ((PhaseCPAInterface) phase).getCpamix().calcDelta(sitei, sitej, componentNumber, + compj, phase, phase.getTemperature(), phase.getPressure(), + phase.getNumberOfComponents()); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdVdXi(int site, PhaseInterface phase) { + return -1.0 / (2.0 * phase.getTotalVolume()) + * (1.0 - phase.getTotalVolume() * ((PhaseCPAInterface) phase).getGcpav()) + * getNumberOfMolesInPhase(); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdNdXi(int site, PhaseInterface phase) { + double xi = 1.0 / xsite[site]; + + // return xi - tempp; + return xi + getNumberOfMolesInPhase() / 2.0 * calc_lngi(phase); + } + + /** + *

+ * dFCPAdNdXidXdV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double dFCPAdNdXidXdV(PhaseInterface phase) { + double temp = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + temp += dFCPAdNdXi(i, phase) * getXsitedV()[i]; + } + return temp; + } + + /** + *

+ * calc_lngi. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngi(PhaseInterface phase) { + return 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())); + } + + /** + *

+ * calc_lngidV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngidV(PhaseInterface phase) { + return 2.0 * getBi() * (10.0) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())) + - 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) + * (2.0 * 32.0 * phase.getTotalVolume() - 12.0 * phase.getB()) + / Math.pow(((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())), 2.0); + } + + /** + *

+ * calc_lngij. + *

+ * + * @param j a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngij(int j, PhaseInterface phase) { + // return 2.0 * getBij(j) * (10.0 * phase.getTotalVolume() - phase.getB()) + // / ((8.0 * phase.getTotalVolume() - phase.getB()) + // * (4.0 * phase.getTotalVolume() - phase.getB())); + + // akis + double temp = (10.0 * phase.getTotalVolume() - phase.getB()) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())); + double temp1 = (8.0 * phase.getTotalVolume() - phase.getB()); + double temp2 = (4.0 * phase.getTotalVolume() - phase.getB()); + double temp3 = (10.0 * phase.getTotalVolume() - phase.getB()); + double tempj = (-((ComponentEosInterface) phase.getComponent(j)).getBi() * temp1 * temp2 + + ((ComponentEosInterface) phase.getComponent(j)).getBi() * temp3 * (temp1 + temp2)) / temp1 + / temp1 / temp2 / temp2; + return 2.0 * (getBij(j) * temp + getBi() * tempj); + + } + + /** {@inheritDoc} */ + @Override + public double[] getXsite() { + return this.xsite; + } + + /** + * Setter for property xsite. + * + * @param xsite New value of property xsite. + */ + public void setXsite(double[] xsite) { + this.xsite = xsite; + } + + /** {@inheritDoc} */ + @Override + public void setXsite(int i, double xsite) { + this.xsite[i] = xsite; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedV() { + return this.xsitedV; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedV(int i, double xsitedV) { + this.xsitedV[i] = xsitedV; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedT() { + return this.xsitedT; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedTdT() { + return this.xsitedTdT; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedT(int i, double xsitedT) { + this.xsitedT[i] = xsitedT; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedTdT(int i, double xsitedTdT) { + this.xsitedTdT[i] = xsitedTdT; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsiteOld() { + return this.xsiteOld; + } + + /** + * Setter for property xsite. + * + * @param xsiteOld an array of {@link double} objects + */ + public void setXsiteOld(double[] xsiteOld) { + this.xsiteOld = xsiteOld; + } + + /** {@inheritDoc} */ + @Override + public void setXsiteOld(int i, double xsiteOld) { + this.xsiteOld[i] = xsiteOld; + } + + /** + *

+ * Getter for the field xsitedni. + *

+ * + * @return the xsitedni + */ + public double[][] getXsitedni() { + return xsitedni; + } + + /** + *

+ * Getter for the field xsitedni. + *

+ * + * @param xNumb a int + * @param compNumbi a int + * @return a double + */ + public double getXsitedni(int xNumb, int compNumbi) { + return xsitedni[xNumb][compNumbi]; + } + + /** + *

+ * Setter for the field xsitedni. + *

+ * + * @param xsitedni the xsitedni to set + */ + public void setXsitedni(double[][] xsitedni) { + this.xsitedni = xsitedni; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedni(int xnumb, int compnumb, double val) { + xsitedni[xnumb][compnumb] = val; + } + + /** {@inheritDoc} */ + @Override + public double getSurfaceTenisionInfluenceParameter(double temperature) { + double AA = 0, BB = 0; + if (componentName.equals("water")) { + double TR = 1.0 - temperature / getTC(); + AA = -2.2367E-16; + BB = 2.83732E-16; + // return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); + + double AAW1 = 2.2505E-16; + double AAW2 = -1.3646E-16; + + return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AAW1 + AAW2 * TR + 0.5113e-16 * TR * TR); + } // old + else if (componentName.equals("water2")) { /// THis is the old method from + double TR = 1.0 - temperature / getTC(); + AA = -2.2367E-16; + BB = 2.83732E-16; + return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); + } else if (componentName.equals("MEG")) { + return 1.04874809905393E-19; + } else if (componentName.equals("TEG")) { + return 7.46824658716429E-19; + } else { + return super.getSurfaceTenisionInfluenceParameter(temperature); + } + } } diff --git a/src/main/java/neqsim/thermo/component/ComponentSrkCPAs.java b/src/main/java/neqsim/thermo/component/ComponentSrkCPAs.java index 8a09a21d94..f54d75ea59 100644 --- a/src/main/java/neqsim/thermo/component/ComponentSrkCPAs.java +++ b/src/main/java/neqsim/thermo/component/ComponentSrkCPAs.java @@ -11,82 +11,88 @@ * @version $Id: $Id */ public class ComponentSrkCPAs extends ComponentSrkCPA { - private static final long serialVersionUID = 1000; + private static final long serialVersionUID = 1000; - /** - *

- * Constructor for ComponentSrkCPAs. - *

- * - * @param component_name a {@link java.lang.String} object - * @param moles a double - * @param molesInPhase a double - * @param compnumber a int - */ - public ComponentSrkCPAs(String component_name, double moles, double molesInPhase, - int compnumber) { - super(component_name, moles, molesInPhase, compnumber); - } + /** + *

+ * Constructor for ComponentSrkCPAs. + *

+ * + * @param component_name a {@link java.lang.String} object + * @param moles a double + * @param molesInPhase a double + * @param compnumber a int + */ + public ComponentSrkCPAs(String component_name, double moles, double molesInPhase, + int compnumber) { + super(component_name, moles, molesInPhase, compnumber); + } + + /** + *

+ * Constructor for ComponentSrkCPAs. + *

+ * + * @param number a int + * @param TC a double + * @param PC a double + * @param M a double + * @param a a double + * @param moles a double + */ + public ComponentSrkCPAs(int number, double TC, double PC, double M, double a, double moles) { + super(number, TC, PC, M, a, moles); + } - /** - *

- * Constructor for ComponentSrkCPAs. - *

- * - * @param number a int - * @param TC a double - * @param PC a double - * @param M a double - * @param a a double - * @param moles a double - */ - public ComponentSrkCPAs(int number, double TC, double PC, double M, double a, double moles) { - super(number, TC, PC, M, a, moles); + /** {@inheritDoc} */ + @Override + public ComponentSrkCPAs clone() { + ComponentSrkCPAs clonedComponent = null; + try { + clonedComponent = (ComponentSrkCPAs) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); } - /** {@inheritDoc} */ - @Override - public ComponentSrkCPAs clone() { - ComponentSrkCPAs clonedComponent = null; - try { - clonedComponent = (ComponentSrkCPAs) super.clone(); - } catch (Exception e) { - logger.error("Cloning failed.", e); - } + return clonedComponent; + } + /* + * public double calc_lngi2(PhaseInterface phase) { return 0.475 / (1.0 - 0.475 * phase.getB() / + * phase.getTotalVolume()) * getBi() / phase.getTotalVolume(); } + */ - return clonedComponent; - } - /* - * public double calc_lngi2(PhaseInterface phase) { return 0.475 / (1.0 - 0.475 * phase.getB() / - * phase.getTotalVolume()) * getBi() / phase.getTotalVolume(); } - */ + /** {@inheritDoc} */ + @Override + public double calc_lngi(PhaseInterface phase) { + return 0.475 * getBi() / (phase.getTotalVolume() - 0.475 * phase.getB()); + } + /* + * public double calc_lngi(PhaseInterface phase) { double nbet = phase.getB() / 4.0 / + * phase.getVolume(); double dlngdb = 1.9 / (1.0 - 1.9 * nbet); double nbeti = nbet / phase.getB() + * * getBi(); return dlngdb * nbeti; } + */ - /** {@inheritDoc} */ - @Override - public double calc_lngi(PhaseInterface phase) { - return 0.475 * getBi() / (phase.getTotalVolume() - 0.475 * phase.getB()); - } - /* - * public double calc_lngi(PhaseInterface phase) { double nbet = phase.getB() / 4.0 / - * phase.getVolume(); double dlngdb = 1.9 / (1.0 - 1.9 * nbet); double nbeti = nbet / - * phase.getB() * getBi(); return dlngdb * nbeti; } - */ + /** {@inheritDoc} */ + @Override + public double calc_lngidV(PhaseInterface phase) { + double temp = phase.getTotalVolume() - 0.475 * phase.getB(); + return -0.475 * getBi() / (temp * temp); + } - /** {@inheritDoc} */ - @Override - public double calc_lngidV(PhaseInterface phase) { - double temp = phase.getTotalVolume() - 0.475 * phase.getB(); - return -0.475 * getBi() / (temp * temp); - } + /** {@inheritDoc} */ + @Override + public double calc_lngij(int j, PhaseInterface phase) { + double temp = phase.getTotalVolume() - 0.475 * phase.getB(); + // System.out.println("B " + phase.getB() + " Bi " + getBi() + " bij " + + // getBij(j)); + // return 0.475 * getBij(j) * 0 / (phase.getTotalVolume() - 0.475 * phase.getB()) + // - 0.475 * getBi() * 1.0 / (temp * temp) + // * (-0.475 * ((ComponentEosInterface) phase.getComponent(j)).getBi()) + // akis + return (0.475 * getBij(j) * temp + + 0.475 * ((ComponentEosInterface) phase.getComponent(j)).getBi() * 0.475 * getBi()) + / (temp * temp); - /** {@inheritDoc} */ - @Override - public double calc_lngij(int j, PhaseInterface phase) { - double temp = phase.getTotalVolume() - 0.475 * phase.getB(); - // System.out.println("B " + phase.getB() + " Bi " + getBi() + " bij " + - // getBij(j)); - return 0.475 * getBij(j) * 0 / (phase.getTotalVolume() - 0.475 * phase.getB()) - - 0.475 * getBi() * 1.0 / (temp * temp) - * (-0.475 * ((ComponentEosInterface) phase.getComponent(j)).getBi()); - } + + } } diff --git a/src/main/java/neqsim/thermo/component/ComponentUMRCPA.java b/src/main/java/neqsim/thermo/component/ComponentUMRCPA.java new file mode 100644 index 0000000000..2528010acb --- /dev/null +++ b/src/main/java/neqsim/thermo/component/ComponentUMRCPA.java @@ -0,0 +1,672 @@ +package neqsim.thermo.component; + +import neqsim.thermo.phase.PhaseCPAInterface; +import neqsim.thermo.phase.PhaseInterface; +import neqsim.thermo.phase.PhaseUMRCPA; + +/** + *

+ * ComponentSrkCPA class. + *

+ * + * @author Even Solbraa + * @version $Id: $Id + */ +public class ComponentUMRCPA extends ComponentPR implements ComponentCPAInterface { + private static final long serialVersionUID = 1000; + + int cpaon = 1; + double[] xsite = new double[0]; + private double[][] xsitedni = new double[0][0]; + double[] xsiteOld = new double[0]; + double[] xsitedV = new double[0]; + double[] xsitedT = new double[0]; + double[] xsitedTdT = new double[0]; + + /** + *

+ * Constructor for ComponentSrkCPA. + *

+ * + * @param component_name a {@link java.lang.String} object + * @param moles a double + * @param molesInPhase a double + * @param compnumber a int + */ + public ComponentUMRCPA(String component_name, double moles, double molesInPhase, + int compnumber) { + super(component_name, moles, molesInPhase, compnumber); + xsite = new double[numberOfAssociationSites]; + xsitedni = new double[numberOfAssociationSites][100]; + xsitedV = new double[numberOfAssociationSites]; + xsitedT = new double[numberOfAssociationSites]; + xsitedTdT = new double[numberOfAssociationSites]; + xsiteOld = new double[numberOfAssociationSites]; + if (numberOfAssociationSites != 0 && cpaon == 1) { + // System.out.println("ass sites: " + numberOfAssociationSites); + // System.out.println("aSRK " + a + " aCPA " + aCPA); + // System.out.println("bSRK " + b + " bCPA " + bCPA); + for (int j = 0; j < getNumberOfAssociationSites(); j++) { + setXsite(j, 1.0); + setXsiteOld(j, 1.0); + setXsitedV(j, 0.0); + setXsitedT(j, 0.0); + } + //if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + // a = aCPA; + // b = bCPA; + //} + setAttractiveTerm(0); + } + // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, + // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; + // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; + } + + /** + *

+ * Constructor for ComponentSrkCPA. + *

+ * + * @param number a int + * @param TC a double + * @param PC a double + * @param M a double + * @param a a double + * @param moles a double + */ + public ComponentUMRCPA(int number, double TC, double PC, double M, double a, double moles) { + super(number, TC, PC, M, a, moles); + xsite = new double[numberOfAssociationSites]; + xsitedni = new double[numberOfAssociationSites][100]; + xsitedV = new double[numberOfAssociationSites]; + xsitedT = new double[numberOfAssociationSites]; + xsitedTdT = new double[numberOfAssociationSites]; + xsiteOld = new double[numberOfAssociationSites]; + if (numberOfAssociationSites != 0 && cpaon == 1) { + for (int j = 0; j < getNumberOfAssociationSites(); j++) { + setXsite(j, 1.0); + setXsiteOld(j, 1.0); + setXsitedV(j, 0.0); + setXsitedT(j, 0.0); + } + //if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + // a = aCPA; + //b = bCPA; + // } + setAttractiveTerm(0); + } + // double[] surfTensInfluenceParamtemp = {-0.0286407191587279700, + // -1.85760887578596, 0.520588, -0.1386439759, 1.1216308727071944}; + // this.surfTensInfluenceParam = surfTensInfluenceParamtemp; + } + + /** {@inheritDoc} */ + @Override + public ComponentUMRCPA clone() { + ComponentUMRCPA clonedComponent = null; + try { + clonedComponent = (ComponentUMRCPA) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + + clonedComponent.xsite = xsite.clone(); + System.arraycopy(this.xsite, 0, clonedComponent.xsite, 0, xsite.length); + clonedComponent.xsiteOld = xsiteOld.clone(); + System.arraycopy(this.xsiteOld, 0, clonedComponent.xsiteOld, 0, xsiteOld.length); + clonedComponent.xsitedV = xsitedV.clone(); + System.arraycopy(this.xsitedV, 0, clonedComponent.xsitedV, 0, xsitedV.length); + clonedComponent.xsitedT = xsitedT.clone(); + System.arraycopy(this.xsitedT, 0, clonedComponent.xsitedT, 0, xsitedT.length); + clonedComponent.xsitedTdT = xsitedTdT.clone(); + System.arraycopy(this.xsitedTdT, 0, clonedComponent.xsitedTdT, 0, xsitedTdT.length); + clonedComponent.xsitedni = xsitedni.clone(); + System.arraycopy(this.xsitedni, 0, clonedComponent.xsitedni, 0, xsitedni.length); + return clonedComponent; + } + + /** {@inheritDoc} */ + @Override + public double getVolumeCorrection() { + if ((getRacketZCPA() < 1.0e-10) && cpaon == 1) { + return 0.0; + } else { + setVolumeCorrectionT(getVolumeCorrectionT_CPA()); + setRacketZ(getRacketZCPA()); + return super.getVolumeCorrection(); + } + } + + @Override + public void createComponent(String component_name, double moles, double molesInPhase, + int compnumber) { + super.createComponent(component_name, moles, molesInPhase, + compnumber); + //criticalTemperature = 305.4; + //criticalPressure = 135.62; + //acentricFactor = 0.1609; + criticalTemperature = 647; + criticalPressure = 220.64; + acentricFactor = 0.3443; + associationEnergy = 15059.15; + associationVolume= 0.109; + + } + + + + /** {@inheritDoc} */ + @Override + public void init(double temperature, double pressure, double totalNumberOfMoles, double beta, + int type) { + super.init(temperature, pressure, totalNumberOfMoles, beta, type); + } + + /** {@inheritDoc} */ + @Override + public void setAttractiveTerm(int i) { + super.setAttractiveTerm(i); + //if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + //getAttractiveTerm().setm(mCPA); + //} + } + + /** {@inheritDoc} */ + @Override + public void seta(double a) { + aCPA = a; + } + + /** {@inheritDoc} */ + @Override + public void setb(double a) { + bCPA = a; + } + + /** {@inheritDoc} */ + @Override + public double calca() { + //if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + //return aCPA; + //} else { + return super.calca(); + //} + } + + /** {@inheritDoc} */ + @Override + public double calcb() { + //if (Math.abs(aCPA) > 1e-6 && cpaon == 1) { + // return bCPA; + //} else { + return super.calcb(); + // } + } + + /** {@inheritDoc} */ + @Override + public double dFdN(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double Fsup = super.dFdN(phase, numberOfComponents, temperature, pressure); + double Fcpa = 0.0; + // if(phase.getPhaseType()==1) cpaon=0; + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + Fcpa = dFCPAdN(phase, numberOfComponents, temperature, pressure); + } + // System.out.println("Fsup " + Fsup + " fcpa " + Fcpa); + // System.out.println("i " + componentNumber + " dFCPAdn " + Fcpa); + return Fsup + cpaon * Fcpa; + } + + /** {@inheritDoc} */ + @Override + public double dFdNdT(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdT(phase, numberOfComponents, temperature, pressure) + + dFCPAdNdT(phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdT(phase, numberOfComponents, temperature, pressure); + } + } + + /** {@inheritDoc} */ + @Override + public double dFdNdV(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + // System.out.println("dQdndV " + dFCPAdNdV(phase, numberOfComponents, + // temperature, pressure) + " dFdndV " + super.dFdNdV(phase, numberOfComponents, + // temperature, pressure)); + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdV(phase, numberOfComponents, temperature, pressure) + + dFCPAdNdV(phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdV(phase, numberOfComponents, temperature, pressure); + } + } + + /** {@inheritDoc} */ + @Override + public double dFdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + // System.out.println("ij " + componentNumber + " " + j + " dQCPAdndn " + + // dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure)+ " dQsrkdndn " + // + super.dFdNdN(j, phase, numberOfComponents, temperature, pressure)); + // System.out.println("dFdndn " +(super.dFdNdN(j, phase, numberOfComponents, + // temperature, pressure) + dFCPAdNdN(j, phase, numberOfComponents, temperature, + // pressure))); + if (((PhaseCPAInterface) phase).getTotalNumberOfAccociationSites() > 0) { + return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure) + + dFCPAdNdN(j, phase, numberOfComponents, temperature, pressure); + } else { + return super.dFdNdN(j, phase, numberOfComponents, temperature, pressure); + } + } + + /** + *

+ * dFCPAdNdN. + *

+ * + * @param j a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdN(int j, PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double temp1 = 0; + for (int i = 0; i < numberOfAssociationSites; i++) { + temp1 += 1.0 / getXsite()[i] * getXsitedni(i, j); + } + double tot2 = 0.0; + for (int i = 0; i < phase.getComponent(j).getNumberOfAssociationSites(); i++) { + tot2 += calc_lngi(phase) + * (1.0 - ((ComponentUMRCPA) phase.getComponent(j)).getXsite()[i]); + } + double tot1 = 1.0 / 2.0 * tot2; + + double tot4 = 0.0; + tot4 = 0.5 * ((PhaseCPAInterface) phase).getHcpatot() * calc_lngij(j, phase); + double tot10 = 0.0; + for (int kk = 0; kk < phase.getNumberOfComponents(); kk++) { + for (int k = 0; k < phase.getComponent(kk).getNumberOfAssociationSites(); k++) { + tot10 += -phase.getComponent(kk).getNumberOfMolesInPhase() + * ((ComponentUMRCPA) phase.getComponent(kk)).getXsitedni(k, j); + } + } + double tot11 = tot10 / 2.0 * calc_lngi(phase); + + // System.out.println("dFCPAdndn " + (temp1 - tot1 - tot4 - tot11)); + return temp1 - tot1 - tot4 - tot11; + } + + /** + *

+ * dFCPAdN. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdN(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += Math.log(xsite[i]); + } + // System.out.println("dFCPAdn " + ((xi - ((PhaseCPAInterface) + // phase).getHcpatot() / 2.0 * calc_lngi(phase)))+ " " + componentNumber); + return (xi - ((PhaseCPAInterface) phase).getHcpatot() / 2.0 * calc_lngi(phase)); + } + + /** + *

+ * dFCPAdNdV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdV(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += (1.0 / xsite[i]) * xsitedV[i]; + } + + double[] tempar = ((PhaseUMRCPA) phase).getdFdNtemp(); + // double temp = calc_lngi(phase); + // double temp2 = calc_lngidV(phase); + /* + * double tot1 = 0.0, tot2 = 0.0, tot3 = 0.0, tot4 = 0.0, temp, temp2; for (int k = 0; k < + * phase.getNumberOfComponents(); k++) { tot2 = 0.0; tot3 = 0.0; temp = calc_lngi(phase); + * temp2 = calc_lngidV(phase); for (int i = 0; i < + * phase.getComponent(k).getNumberOfAssociationSites(); i++) { tot2 -= temp * + * ((ComponentSrkCPA) phase.getComponent(k)).getXsitedV()[i]; tot3 += (1.0 - + * ((ComponentSrkCPA) phase.getComponent(k)).getXsite()[i]) * temp2; } tot1 += 1.0 / 2.0 * + * tot2 * phase.getComponent(k).getNumberOfMolesInPhase(); tot4 += 0.5 * + * phase.getComponent(k).getNumberOfMolesInPhase() * tot3; } + */ + // System.out.println("dFCPAdndV " + (xi - tot1 - tot4)); + return xi + tempar[0] * calc_lngi(phase) + tempar[1] * calc_lngidV(phase);// - tot1 - tot4; + } + + /** + *

+ * dFCPAdNdT. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @param numberOfComponents a int + * @param temperature a double + * @param pressure a double + * @return a double + */ + public double dFCPAdNdT(PhaseInterface phase, int numberOfComponents, double temperature, + double pressure) { + double xi = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + xi += 1.0 / xsite[i] * xsitedT[i]; + } + + double tot1 = 0.0, tot2 = 0.0; + for (int k = 0; k < phase.getNumberOfComponents(); k++) { + tot2 = 0.0; + for (int i = 0; i < phase.getComponent(k).getNumberOfAssociationSites(); i++) { + tot2 -= ((ComponentUMRCPA) phase.getComponent(k)).getXsitedT()[i]; + } + tot1 += tot2 * phase.getComponent(k).getNumberOfMolesInPhase(); + } + // System.out.println("dFCPAdndT " + (xi - 1.0 / 2.0 * calc_lngi(phase) * + // tot1)); + // System.out.println("dlngdni " + calc_lngi(phase)); + return xi - 1.0 / 2.0 * calc_lngi(phase) * tot1; + } + + /** + *

+ * calc_hCPAdn. + *

+ * + * @return a double + */ + public double calc_hCPAdn() { + double hdn = 0.0; + for (int i = 0; i < getNumberOfAssociationSites(); i++) { + hdn = 1.0 - getXsite()[i]; + } + return hdn; + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdXi(int site, PhaseInterface phase) { + return getNumberOfMolesInPhase() * (1.0 / xsite[site] - 1.0 / 2.0); + } + + /** + *

+ * dFCPAdXidni. + *

+ * + * @param site a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double dFCPAdXidni(int site, PhaseInterface phase) { + return (1.0 / xsite[site] - 1.0 / 2.0); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdXidXj(int sitei, int sitej, int compj, PhaseInterface phase) { + double fact = 0.0; + if (sitei == sitej && compj == componentNumber) { + fact = 1.0; + } + return -getNumberOfMolesInPhase() / Math.pow(xsite[sitei], 2.0) * fact + - getNumberOfMolesInPhase() * phase.getComponent(compj).getNumberOfMolesInPhase() + * ((PhaseCPAInterface) phase).getCpamix().calcDelta(sitei, sitej, + componentNumber, compj, phase, phase.getTemperature(), + phase.getPressure(), phase.getNumberOfComponents()); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdVdXi(int site, PhaseInterface phase) { + return -1.0 / (2.0 * phase.getTotalVolume()) + * (1.0 - phase.getTotalVolume() * ((PhaseCPAInterface) phase).getGcpav()) + * getNumberOfMolesInPhase(); + } + + /** {@inheritDoc} */ + @Override + public double dFCPAdNdXi(int site, PhaseInterface phase) { + double xi = 1.0 / xsite[site]; + + // return xi - tempp; + return xi + getNumberOfMolesInPhase() / 2.0 * calc_lngi(phase); + } + + /** + *

+ * dFCPAdNdXidXdV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double dFCPAdNdXidXdV(PhaseInterface phase) { + double temp = 0.0; + for (int i = 0; i < numberOfAssociationSites; i++) { + temp += dFCPAdNdXi(i, phase) * getXsitedV()[i]; + } + return temp; + } + + /** + *

+ * calc_lngi. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngi(PhaseInterface phase) { + return 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())); + } + + /** + *

+ * calc_lngidV. + *

+ * + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngidV(PhaseInterface phase) { + return 2.0 * getBi() * (10.0) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())) + - 2.0 * getBi() * (10.0 * phase.getTotalVolume() - phase.getB()) + * (2.0 * 32.0 * phase.getTotalVolume() - 12.0 * phase.getB()) + / Math.pow(((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())), 2.0); + } + + /** + *

+ * calc_lngij. + *

+ * + * @param j a int + * @param phase a {@link neqsim.thermo.phase.PhaseInterface} object + * @return a double + */ + public double calc_lngij(int j, PhaseInterface phase) { + return 2.0 * getBij(j) * (10.0 * phase.getTotalVolume() - phase.getB()) + / ((8.0 * phase.getTotalVolume() - phase.getB()) + * (4.0 * phase.getTotalVolume() - phase.getB())); + } + + /** {@inheritDoc} */ + @Override + public double[] getXsite() { + return this.xsite; + } + + /** + * Setter for property xsite. + * + * @param xsite New value of property xsite. + */ + public void setXsite(double[] xsite) { + this.xsite = xsite; + } + + /** {@inheritDoc} */ + @Override + public void setXsite(int i, double xsite) { + this.xsite[i] = xsite; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedV() { + return this.xsitedV; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedV(int i, double xsitedV) { + this.xsitedV[i] = xsitedV; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedT() { + return this.xsitedT; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsitedTdT() { + return this.xsitedTdT; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedT(int i, double xsitedT) { + this.xsitedT[i] = xsitedT; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedTdT(int i, double xsitedTdT) { + this.xsitedTdT[i] = xsitedTdT; + } + + /** {@inheritDoc} */ + @Override + public double[] getXsiteOld() { + return this.xsiteOld; + } + + /** + * Setter for property xsite. + * + * @param xsiteOld an array of {@link double} objects + */ + public void setXsiteOld(double[] xsiteOld) { + this.xsiteOld = xsiteOld; + } + + /** {@inheritDoc} */ + @Override + public void setXsiteOld(int i, double xsiteOld) { + this.xsiteOld[i] = xsiteOld; + } + + /** + *

+ * Getter for the field xsitedni. + *

+ * + * @return the xsitedni + */ + public double[][] getXsitedni() { + return xsitedni; + } + + /** + *

+ * Getter for the field xsitedni. + *

+ * + * @param xNumb a int + * @param compNumbi a int + * @return a double + */ + public double getXsitedni(int xNumb, int compNumbi) { + return xsitedni[xNumb][compNumbi]; + } + + /** + *

+ * Setter for the field xsitedni. + *

+ * + * @param xsitedni the xsitedni to set + */ + public void setXsitedni(double[][] xsitedni) { + this.xsitedni = xsitedni; + } + + /** {@inheritDoc} */ + @Override + public void setXsitedni(int xnumb, int compnumb, double val) { + xsitedni[xnumb][compnumb] = val; + } + + /** {@inheritDoc} */ + @Override + public double getSurfaceTenisionInfluenceParameter(double temperature) { + double AA = 0, BB = 0; + if (componentName.equals("water")) { + double TR = 1.0 - temperature / getTC(); + AA = -2.2367E-16; + BB = 2.83732E-16; + // return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); + + double AAW1 = 2.2505E-16; + double AAW2 = -1.3646E-16; + + return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) + * (AAW1 + AAW2 * TR + 0.5113e-16 * TR * TR); + } // old + else if (componentName.equals("water2")) { /// THis is the old method from + double TR = 1.0 - temperature / getTC(); + AA = -2.2367E-16; + BB = 2.83732E-16; + return aT * 1e-5 * Math.pow(b * 1e-5, 2.0 / 3.0) * (AA * TR + BB); + } else if (componentName.equals("MEG")) { + return 1.04874809905393E-19; + } else if (componentName.equals("TEG")) { + return 7.46824658716429E-19; + } else { + return super.getSurfaceTenisionInfluenceParameter(temperature); + } + } +} diff --git a/src/main/java/neqsim/thermo/component/attractiveEosTerm/AtractiveTermMatCopPRUMRNew.java b/src/main/java/neqsim/thermo/component/attractiveEosTerm/AtractiveTermMatCopPRUMRNew.java new file mode 100644 index 0000000000..67cb25d5cd --- /dev/null +++ b/src/main/java/neqsim/thermo/component/attractiveEosTerm/AtractiveTermMatCopPRUMRNew.java @@ -0,0 +1,187 @@ +package neqsim.thermo.component.attractiveEosTerm; + +import neqsim.thermo.component.ComponentEosInterface; + +/** + * + * @author esol + * @version + */ +public class AtractiveTermMatCopPRUMRNew extends AttractiveTermMatCopPRUMR { + + private static final long serialVersionUID = 1000; + double orgpar = 0.0; + boolean useStandardAlphaForSupercritical = false; + + public AtractiveTermMatCopPRUMRNew(ComponentEosInterface component) { + super(component); + m = (0.384401 + 1.52276 * component.getAcentricFactor() + - 0.213808 * component.getAcentricFactor() * component.getAcentricFactor() + + 0.034616 * Math.pow(component.getAcentricFactor(), 3.0) + - 0.001976 * Math.pow(component.getAcentricFactor(), 4.0)); + } + + public AtractiveTermMatCopPRUMRNew(ComponentEosInterface component, double[] params) { + this(component); + parameters = new double[params.length]; + System.arraycopy(params, 0, this.parameters, 0, params.length); + orgpar = parameters[0]; + if (Math.abs(parameters[0]) < 1e-12) { + parameters[0] = m; + } + + // add MC parameters manually + if (component.getName().equals("ethane")) { + parameters[0] = 0.498809; + parameters[1] = 0.115568; + parameters[2] = -0.040775; + parameters[3] = -0.057788; + parameters[4] = 0.017702; + } + //if (component.getName().equals("water")) { + //parameters[0] = 0.91256735118818810000000000; + // parameters[1] = -0.2872243639795234400000000; + //parameters[2] = 0.239526763058374250000000000; + //parameters[3] = 0.0; + //parameters[4] = 0.0; + //} + + if (component.getName().equals("water")) { + parameters[0] = 0.9130000000000; + parameters[1] = -0.2870000000; + parameters[2] = 0.239500000000; + parameters[3] = -4.0; + parameters[4] = 7.0; + } + + if (component.getName().equals("nitrogen")) { + parameters[0] = 0.43635; + parameters[1] = 0; + parameters[2] = 0; + parameters[3] = 0.0; + parameters[4] = 0.0; + } + + if (component.getName().equals("methane")) { + parameters[0] = 0.386575; + parameters[1] = 0.016011; + parameters[2] = -0.017371; + parameters[3] = 0.011761; + parameters[4] = 0.020786; + } + } + + @Override + public AtractiveTermMatCopPRUMRNew clone() { + AtractiveTermMatCopPRUMRNew atractiveTerm = null; + try { + atractiveTerm = (AtractiveTermMatCopPRUMRNew) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + + return atractiveTerm; + } + + @Override + public double alpha(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.alpha(temperature); + } else { + double Tr = temperature / getComponent().getTC(); + return Math.pow(1.0 + parameters[0] * (1.0 - Math.sqrt(Tr)) + + parameters[1] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) + + parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) + + parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) + + parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 5.0), 2.0); + } + } + + @Override + public double aT(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.aT(temperature); + } else { + return getComponent().geta() * alpha(temperature); + } + } + + @Override + public double diffalphaT(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.diffalphaT(temperature); + } + + double Tr = temperature / getComponent().getTC(); + double TC = getComponent().getTC(); + double tcrizatr = TC * Math.sqrt(Tr); + return 2.0 + * (1.0 + parameters[0] * (1.0 - Math.sqrt(Tr)) + + parameters[1] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) + + parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) + + parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) + + parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 5.0)) + * (-1.0 / 2.0 * parameters[0] / tcrizatr - parameters[1] * (1.0 - Math.sqrt(Tr)) / tcrizatr + - 3.0 / 2.0 * parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) / tcrizatr + - 2.0 * parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) / tcrizatr + - 5.0 / 2.0 * parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) / tcrizatr); + + } + + @Override + public double diffdiffalphaT(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.diffdiffalphaT(temperature); + } + + double Tr = temperature / getComponent().getTC(); + double TC = getComponent().getTC(); + double tcrizatr = TC * Math.sqrt(Tr); + double TcT = TC * temperature; + double Tc2Trpower32 = TC * TC * Math.pow(Tr, 1.5); + return 2.0 + * Math.pow(parameters[0] / tcrizatr / 2.0 + parameters[1] * (1.0 - Math.sqrt(Tr)) / tcrizatr + + 3.0 / 2.0 * parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) / tcrizatr + + 2.0 * parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) / tcrizatr + + 5.0 / 2.0 * parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) / tcrizatr, 2.0) + + 2.0 + * (1.0 + parameters[0] * (1.0 - Math.sqrt(Tr)) + + parameters[1] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) + + parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) + + parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) + + parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 5.0)) + * (parameters[0] / Tc2Trpower32 / 4.0 + parameters[1] / TcT / 2.0 + + parameters[1] * (1.0 - Math.sqrt(Tr)) / Tc2Trpower32 / 2.0 + + 3.0 / 2.0 * parameters[2] * (1.0 - Math.sqrt(Tr)) / TcT + + 3.0 / 4.0 * parameters[2] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) / Tc2Trpower32 + + 3 * parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 2.0) / TcT + + parameters[3] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) / Tc2Trpower32 + + 5 * parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 3.0) / TcT + + 5.0 / 4.0 * parameters[4] * Math.pow(1.0 - Math.sqrt(Tr), 4.0) / Tc2Trpower32); + } + + + @Override + public double diffaT(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.diffaT(temperature); + } else { + return getComponent().geta() * diffalphaT(temperature); + } + } + + @Override + public double diffdiffaT(double temperature) { + if (useStandardAlphaForSupercritical && temperature / getComponent().getTC() > 1.0 + || parameters[0] < 1e-20) { + return super.diffdiffaT(temperature); + } else { + return getComponent().geta() * diffdiffalphaT(temperature); + } + } +} diff --git a/src/main/java/neqsim/thermo/phase/PhasePrEosvolcor.java b/src/main/java/neqsim/thermo/phase/PhasePrEosvolcor.java new file mode 100644 index 0000000000..8122b352e7 --- /dev/null +++ b/src/main/java/neqsim/thermo/phase/PhasePrEosvolcor.java @@ -0,0 +1,407 @@ +/* + * PhaseSrkEos.java + * + * Created on 3. juni 2000, 14:38 + */ + +package neqsim.thermo.phase; + +import neqsim.thermo.component.ComponentEosInterface; +import neqsim.thermo.component.ComponentPRvolcor; + +/** + * + * @author Even Solbraa + * @version + */ +public class PhasePrEosvolcor extends PhasePrEos { + + private static final long serialVersionUID = 1000; + double loc_C=0; + private double CT; + public double C; + public double Ctot = 0; + + /** Creates new PhaseSrkEos */ + public PhasePrEosvolcor() { + super(); + thermoPropertyModelName = "PR-EoS-volcorr"; + } + + /** {@inheritDoc} */ + @Override + public void init(double totalNumberOfMoles, int numberOfComponents, int type, int phase, + double beta) { + super.init(totalNumberOfMoles, numberOfComponents, type, phase, beta); + loc_C = calcC(this, temperature, pressure, numberOfComponents); + CT = calcCT(this, temperature, pressure, numberOfComponents); + + } + + + public double getCT() { + return CT; + } + + + public double getCTT() { + return 0; + } + + @Override + public double calcg() { + return Math.log(1.0 - (getb() - getc()) / molarVolume); + } + @Override + public double calcf() { + return (1.0 / (R * getB() * (delta1 - delta2)) + * Math.log((1.0 + (delta1 * getb() + getc()) / molarVolume) + / (1.0 + (delta2 * getb() + getc()) / (molarVolume)))); + } + + @Override + public double dFdV() { + // return super.dFdV(); + return -numberOfMolesInPhase * gV() - getA() / temperature * fv(); + + } + + // note that in future the next thre lines should be modified to handle various mixing rules for + // the translation + + + + public double getcij(ComponentEosInterface compArray, ComponentEosInterface compArray2) { + return ((((ComponentPRvolcor) compArray).getc()) + (((ComponentPRvolcor) compArray2).getc())) + * 0.5; + } + + public double getcijT(ComponentEosInterface compArray, ComponentEosInterface compArray2) { + return (((ComponentPRvolcor) compArray).getcT() + ((ComponentPRvolcor) compArray2).getcT()) + * 0.5; + } + + public double getcijTT(ComponentPRvolcor compi, ComponentPRvolcor compj) { + // return (compi.getcTT() + compj.getcTT()) * 0.5; + return 0; + } + + + // @Override + public double calcCi(int compNumb, PhaseInterface phase, double temperature, double pressure, + int numbcomp) { + double Ci = 0.0; + + ComponentEosInterface[] compArray = (ComponentEosInterface[]) phase.getcomponentArray(); + + for (int j = 0; j < numbcomp; j++) { + Ci += compArray[j].getNumberOfMolesInPhase() * getcij(compArray[compNumb], compArray[j]); + } + + Ci = (2.0 * Ci - getC()) / phase.getNumberOfMolesInPhase(); + return Ci; + } + + + public double calcCij(int compNumb, int compNumbj, PhaseInterface phase, double temperature, + double pressure, int numbcomp) { + double cij = 0.0; + ComponentEosInterface[] compArray = (ComponentEosInterface[]) phase.getcomponentArray(); + + cij = getcij(compArray[compNumb], compArray[compNumbj]); + return (2.0 * cij - ((ComponentPRvolcor) compArray[compNumb]).getCi() + - ((ComponentPRvolcor) compArray[compNumbj]).getCi()) / phase.getNumberOfMolesInPhase(); + } + + + + public double calcCiT(int compNumb, PhaseInterface phase, double temperature, double pressure, + int numbcomp) { + double CiT = 0.0; + + ComponentEosInterface[] compArray = (ComponentEosInterface[]) phase.getcomponentArray(); + + for (int j = 0; j < numbcomp; j++) { + CiT += compArray[j].getNumberOfMolesInPhase() * getcijT(compArray[compNumb], compArray[j]); + } + + CiT = (2.0 * CiT - getCT()) / phase.getNumberOfMolesInPhase(); + return CiT; + } + + + + public double calcCT(PhaseInterface phase, double temperature, double pressure, int numbcomp) { + return 0.0; + } + + public double calcC(PhaseInterface phase, double temperature, double pressure, + int numbcomp) { + C = 0.0; + ComponentEosInterface[] compArray = (ComponentEosInterface[]) phase.getcomponentArray(); + + for (int i = 0; i < numbcomp; i++) { + for (int j = 0; j < numbcomp; j++) { + C += compArray[i].getNumberOfMolesInPhase() + * compArray[j].getNumberOfMolesInPhase() + * getcij(compArray[i], compArray[j]);// (compArray[i].getb()+compArray[j].getb())/2; + } + } + C /= phase.getNumberOfMolesInPhase(); + Ctot = C; + return C; + } + + + + private double loc_C() { + return calcC(this, temperature, pressure, numberOfComponents) ; + } + + public double getc() { + return loc_C() / numberOfMolesInPhase; + } + + public double getC() { + return loc_C(); + } + + + + @Override + public double gV() { + return (getb() - getc()) + / (molarVolume * (numberOfMolesInPhase * molarVolume + loc_C() - getB())); + // molarvolume is m^3/mol/10^5 + // old is-->return getb() / (molarVolume * (numberOfMolesInPhase * molarVolume - loc_B)); + // aks Dr. Soolbra whats the difference between getb and loc_B and + // why the molar volume in the bracket is multiplied by the numberofmolesinphase (is it because + // of the units of molarvolume?) + } + + @Override + public double gVV() { + double val1 = numberOfMolesInPhase * getMolarVolume(); + double val2 = val1 + getC() - getB(); + return -1.0 / (val2 * val2) + 1.0 / (val1 * val1); + + // old is -->double val1 = numberOfMolesInPhase * getMolarVolume(); + // double val2 = val1 + getC - getB(); + // return -1.0 / (val2 * val2) + 1.0 / (val1 * val1); + } + + public double gVVV() { + double val1 = numberOfMolesInPhase * getMolarVolume(); + double val2 = val1 + getC() - getB(); + return 2.0 / (val2 * val2 * val2) - 2.0 / (val1 * val1 * val1); + } + + @Override + public double fv() { + return -1.0 / (R * (numberOfMolesInPhase * molarVolume + delta1 * getB() + loc_C()) + * (numberOfMolesInPhase * molarVolume + delta2 * getB() + loc_C())); + + // OLD IS--> return -1.0 / (R * (numberOfMolesInPhase * molarVolume + delta1 * loc_B) + // * (numberOfMolesInPhase * molarVolume + delta2 * loc_B)); + } + + @Override + public double fVV() { + double val1 = (numberOfMolesInPhase * molarVolume + delta1 * getB() + loc_C()); + double val2 = (numberOfMolesInPhase * molarVolume + delta2 * getB() + loc_C()); + return 1.0 / (R * getB() * (delta1 - delta2)) * (-1.0 / (val1 * val1) + 1.0 / (val2 * val2)); + + // old is-->double val1 = (numberOfMolesInPhase * molarVolume + delta1 * loc_B); + // double val2 = (numberOfMolesInPhase * molarVolume + delta2 * loc_B); + // return 1.0 / (R * loc_B * (delta1 - delta2)) * (-1.0 / (val1 * val1) + 1.0 / (val2 * val2)); + } + + public double fVVV() { + double val1 = numberOfMolesInPhase * molarVolume + getB() * delta1 + getC(); + double val2 = numberOfMolesInPhase * molarVolume + getB() * delta2 + getC(); + return 1.0 / (R * getB() * (delta1 - delta2)) + * (2.0 / (val1 * val1 * val1) - 2.0 / (val2 * val2 * val2)); + + // old is -->double val1 = numberOfMolesInPhase * molarVolume + getB() * delta1; + // double val2 = numberOfMolesInPhase * molarVolume + getB() * delta2; + // return 1.0 / (R * getB() * (delta1 - delta2)) * (2.0 / (val1 * val1 * val1) - 2.0 / (val2 * + // val2 * val2)); + } + + + + // derivative of small g with regards to b + // problem with the loc_b in gb(),gc()-->it says that it is not visible and I think this is + // because loc_B is marked as private + // in PhaseEoS...so for now I switch it to getb and we will see + + @Override + public double gb() { + // return -1.0 / (numberOfMolesInPhase * molarVolume - loc_B + loc_C); + return -1.0 / (numberOfMolesInPhase * molarVolume - getB() + getC()); + } + + //// derivative of small g with regards to c + public double gc() { + // return 1.0 / (numberOfMolesInPhase * molarVolume - loc_B + loc_C); + return 1.0 / (numberOfMolesInPhase * molarVolume - getB() + getC()); + } + + //// derivative of small f with regards to c-->equal to fv + public double fc() { + return -1.0 / (R * (numberOfMolesInPhase * molarVolume + delta1 * getB() + loc_C()) + * (numberOfMolesInPhase * molarVolume + delta2 * getB() + loc_C())); + } + + @Override + public double fb() { + return -(calcf() + (numberOfMolesInPhase * molarVolume + getC())* fv()) / getB(); +} + + //// second derivative of small f with regards to cc-->equal to fvv + public double fcc() { + return fVV(); + } + + //// second derivative of small f with regards to bc-->equal to fvv + public double fbc() { + return fBV(); + } + + //// second derivative of small f with regards to cv-->equal to fvv + public double fcv() { + return fVV(); + } + + //// second derivative of small f with regards to bv--> + @Override + public double fBV() { + return -(2.0 * fv() + (numberOfMolesInPhase * molarVolume + getC()) * fVV()) / getB(); + } + + //// second derivative of small f with regards to bb--> + @Override + public double fBB() { + return -(2.0 * fb() + (numberOfMolesInPhase * molarVolume + getC()) * fBV()) / getB(); + } + + //// second derivative of small g with regards to bv--> + @Override + public double gBV() { + double val = numberOfMolesInPhase * getMolarVolume() - getB() + getC(); + return 1.0 / (val * val); + } + + //// second derivative of small g with regards to bb--> + @Override + public double gBB() { + double val = numberOfMolesInPhase * getMolarVolume() - getB() + getC(); + return -1.0 / (val * val); + } + + //// second derivative of small g with regards to bc--> + public double gBC() { + double val = numberOfMolesInPhase * getMolarVolume() - getB() + getC(); + return 1.0 / (val * val); + } + + //// second derivative of small g with regards to cv--> + public double gCV() { + double val = numberOfMolesInPhase * getMolarVolume() - getB() + getC(); + return -1.0 / (val * val); + } + + //// second derivative of small g with regards to cc--> + public double gCC() { + double val = numberOfMolesInPhase * getMolarVolume() - getB() + getC(); + return -1.0 / (val * val); + } + + + // Below are the partial derivatives of F with regards to model parameters + + @Override + public double F() { + return super.F(); + } + + // derivative of big F with regards to C + // @Override + public double FC() { + return -numberOfMolesInPhase * gc() - getA() / temperature * fc(); + } + + public double FnC() { + return -gc(); + } + + public double FTC() { + return getA() * fc() / temperature / temperature; + } + + public double FBC() { + return -numberOfMolesInPhase * gBC() - getA() * fbc() / temperature; + } + + public double FCV() { + return -numberOfMolesInPhase * gCV() - getA() * fcv() / temperature; + } + + public double FCC() { + return -numberOfMolesInPhase * gCC() - getA() * fcc() / temperature; + } + + public double FCD() { + return -fc() / temperature; + } + + @Override + public double dFdVdV() { + return -numberOfMolesInPhase * gVV() - getA() * fVV() / temperature; + } + + @Override + public double dFdVdVdV() { + return -numberOfMolesInPhase * gVVV() - getA() * fVVV() / temperature; + } + + /** {@inheritDoc} */ + @Override + public double dFdTdV() { + return FTV() + FDV() * getAT() + FCV() * getCT(); + } + + /** {@inheritDoc} */ + @Override + public double dFdT() { + return FT() + FD() * getAT() + FC() * getCT(); + } + + @Override + public double dFdTdT() { + return FTT() + 2.0 * FDT() * getAT() + FD() * getATT() + 2 * FTC() * getCT() + + FCC() * getCT() * getCT() + FC() * getCTT() + 2 * FCD() * getCT() * getAT(); + } + + + @Override + public PhasePrEosvolcor clone() { + PhasePrEosvolcor clonedPhase = null; + try { + clonedPhase = (PhasePrEosvolcor) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + + return clonedPhase; + } + + @Override + public void addcomponent(String componentName, double moles, double molesInPhase, + int compNumber) { + super.addcomponent(molesInPhase); + componentArray[compNumber] = + new ComponentPRvolcor(componentName, moles, molesInPhase, compNumber); + } + +} diff --git a/src/main/java/neqsim/thermo/phase/PhaseSrkCPA.java b/src/main/java/neqsim/thermo/phase/PhaseSrkCPA.java index f066fd8cc5..36eb5fead5 100644 --- a/src/main/java/neqsim/thermo/phase/PhaseSrkCPA.java +++ b/src/main/java/neqsim/thermo/phase/PhaseSrkCPA.java @@ -858,7 +858,7 @@ public double calc_g() { * @return a double */ public double calc_lngV() { - tempTotVol = getMolarVolume(); + tempTotVol = getTotalVolume(); // gv = -2.0 * getB() * (10.0 * getTotalVolume() - getB()) / getTotalVolume() / // ((8.0 * getTotalVolume() - getB()) * (4.0 * getTotalVolume() - getB())); return 1.0 / (2.0 - getB() / (4.0 * tempTotVol)) * getB() / (4.0 * tempTotVol * tempTotVol) @@ -874,7 +874,7 @@ public double calc_lngV() { * @return a double */ public double calc_lngVV() { - tempTotVol = getMolarVolume(); + tempTotVol = getTotalVolume(); return 2.0 * (640.0 * Math.pow(tempTotVol, 3.0) - 216.0 * getB() * tempTotVol * tempTotVol + 24.0 * Math.pow(getB(), 2.0) * tempTotVol - Math.pow(getB(), 3.0)) @@ -890,7 +890,7 @@ public double calc_lngVV() { * @return a double */ public double calc_lngVVV() { - tempTotVol = getMolarVolume(); + tempTotVol = getTotalVolume(); return 4.0 * (Math.pow(getB(), 5.0) + 17664.0 * Math.pow(tempTotVol, 4.0) * getB() - 4192.0 * Math.pow(tempTotVol, 3.0) * Math.pow(getB(), 2.0) diff --git a/src/main/java/neqsim/thermo/phase/PhaseUMRCPA.java b/src/main/java/neqsim/thermo/phase/PhaseUMRCPA.java new file mode 100644 index 0000000000..558effcbf7 --- /dev/null +++ b/src/main/java/neqsim/thermo/phase/PhaseUMRCPA.java @@ -0,0 +1,2120 @@ +package neqsim.thermo.phase; + +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.ejml.data.DMatrixRMaj; +import org.ejml.dense.row.CommonOps_DDRM; +import org.ejml.dense.row.NormOps_DDRM; +import org.ejml.simple.SimpleMatrix; +// import org.ejml.data.DenseMatrix64F; +import neqsim.thermo.component.ComponentCPAInterface; +import neqsim.thermo.component.ComponentUMRCPA; +import neqsim.thermo.mixingRule.CPAMixing; +import neqsim.thermo.mixingRule.CPAMixingInterface; + +/** + *

+ * PhaseSrkCPA class. + *

+ * + * @author Even Solbraa + * @version $Id: $Id + */ +public class PhaseUMRCPA extends PhasePrEos implements PhaseCPAInterface { + /** + *

+ * Getter for the field dFdNtemp. + *

+ * + * @return the dFdNtemp + */ + public double[] getdFdNtemp() { + return dFdNtemp; + } + + private static final long serialVersionUID = 1000; + static Logger logger = LogManager.getLogger(PhaseUMRCPA.class); + + public CPAMixing cpaSelect = new CPAMixing(); + public CPAMixingInterface cpamix; + double gcpavv = 0.0, gcpavvv = 0.0, gcpa = 0.0, hcpatot = 1.0, FCPA = 0.0, dFCPAdTdV, + dFCPAdTdT = 0.0, dFCPAdT = 0, dFCPAdV = 0, dFCPAdVdV = 0.0, dFCPAdVdVdV = 0.0; + double gcpav = 0.0, tempTotVol = 0; + private double[] dFdNtemp = {0, 0}; + int cpaon = 1, oldTotalNumberOfAccociationSites = 0; + int totalNumberOfAccociationSites = 0; + int[][][] selfAccociationScheme = null; + int[][][][] crossAccociationScheme = null; + int[] activeAccosComp = null;// new int[100]; + private double[] lngi; + int[] moleculeNumber = null, assSiteNumber = null; + private double[][] gvector = null, delta = null, deltaNog = null, deltadT = null, + deltadTdT = null; + double[][][] Klkni = null; + private SimpleMatrix KlkTVMatrix = null, KlkTTMatrix = null, KlkTMatrix = null, + udotTimesmMatrix = null, mVector = null, udotMatrix = null, uMatrix = null, + QMatksiksiksi = null, KlkVVVMatrix = null, KlkVVMatrix = null, udotTimesmiMatrix = null, + ksiMatrix = null, KlkMatrix = null, hessianMatrix = null, hessianInvers = null, + KlkVMatrix = null; + private DMatrixRMaj corr2Matrix = null, corr3Matrix = null, corr4Matrix = null;// new + // DenseMatrix64F(getTotalNumberOfAccociationSites(), + // 1); + + /** + *

+ * Constructor for PhaseUMRCPA. + *

+ */ + public PhaseUMRCPA() { + super(); + thermoPropertyModelName = "UMR-CPA-EoS"; + } + + /** {@inheritDoc} */ + @Override + public PhaseUMRCPA clone() { + PhaseUMRCPA clonedPhase = null; + try { + clonedPhase = (PhaseUMRCPA) super.clone(); + } catch (Exception e) { + logger.error("Cloning failed.", e); + } + if (activeAccosComp != null) { + clonedPhase.activeAccosComp = activeAccosComp.clone(); + System.arraycopy(this.activeAccosComp, 0, clonedPhase.activeAccosComp, 0, + activeAccosComp.length); + } + // clonedPhase.cpaSelect = (CPAMixing) cpaSelect.clone(); + // clonedPhase.cpamix = (CPAMixingInterface) cpamix.clone(); + // clonedPhase.cpamix = cpaSelect.getMixingRule(1, this); + + return clonedPhase; + } + + /** {@inheritDoc} */ + @Override + public void init(double totalNumberOfMoles, int numberOfComponents, int type, int phase, + double beta) { + boolean changedAssosiationStatus = false; + + if (type == 0) { + activeAccosComp = new int[numberOfComponents]; + for (int i = 0; i < numberOfComponents; i++) { + if (componentArray[i].getNumberOfmoles() < 1e-50) { + componentArray[i].setNumberOfAssociationSites(0); + if (activeAccosComp[i] == 1) { + activeAccosComp[i] = 0; + changedAssosiationStatus = true; + } + } else { + if (activeAccosComp[i] == 0) { + changedAssosiationStatus = true; + activeAccosComp[i] = 1; + } + } + } + + if (changedAssosiationStatus || lngi == null) { + setTotalNumberOfAccociationSites(0); + selfAccociationScheme = new int[numberOfComponents][0][0]; + crossAccociationScheme = new int[numberOfComponents][numberOfComponents][0][0]; + for (int i = 0; i < numberOfComponents; i++) { + if (componentArray[i].getNumberOfmoles() < 1e-50) { + componentArray[i].setNumberOfAssociationSites(0); + } else { + componentArray[i].setNumberOfAssociationSites( + componentArray[i].getOrginalNumberOfAssociationSites()); + setTotalNumberOfAccociationSites(getTotalNumberOfAccociationSites() + + componentArray[i].getNumberOfAssociationSites()); + selfAccociationScheme[i] = cpaSelect.setAssociationScheme(i, this); + for (int j = 0; j < numberOfComponents; j++) { + crossAccociationScheme[i][j] = + cpaSelect.setCrossAssociationScheme(i, j, this); + } + } + } + } + + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + ((ComponentUMRCPA) componentArray[i]).setXsite(j, 1.0); + ((ComponentUMRCPA) componentArray[i]).setXsitedV(j, 0.0); + ((ComponentUMRCPA) componentArray[i]).setXsitedT(j, 0.0); + } + } + + if (changedAssosiationStatus || lngi == null || mVector == null) { + lngi = new double[numberOfComponents]; + mVector = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + KlkMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVVVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + hessianMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTTMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + corr2Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + corr3Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + corr4Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + Klkni = new double[numberOfComponents][getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + ksiMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + uMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + udotMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + moleculeNumber = new int[getTotalNumberOfAccociationSites()]; + assSiteNumber = new int[getTotalNumberOfAccociationSites()]; + gvector = new double[getTotalNumberOfAccociationSites()][1]; + udotTimesmMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + delta = new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltaNog = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltadT = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltadTdT = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + QMatksiksiksi = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + udotTimesmiMatrix = + new SimpleMatrix(numberOfComponents, getTotalNumberOfAccociationSites()); + + oldTotalNumberOfAccociationSites = getTotalNumberOfAccociationSites(); + + int temp = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + moleculeNumber[temp + j] = i; + assSiteNumber[temp + j] = j; + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + } + } + + if (cpamix == null) { + cpamix = cpaSelect.getMixingRule(1, this); + } + if (type > 0) { + calcDelta(); + } + + super.init(totalNumberOfMoles, numberOfComponents, type, phase, beta); + + if (type > 0 && isConstantPhaseVolume()) { + solveX(); + super.init(totalNumberOfMoles, numberOfComponents, 1, phase, beta); + gcpa = calc_g(); + gcpav = calc_lngV(); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + } + + if (type > 0) { + hcpatot = calc_hCPA(); + } + + if (type > 1) { + initCPAMatrix(type); + super.init(totalNumberOfMoles, numberOfComponents, type, phase, beta); + } + } + + /** + *

+ * initCPAMatrix. + *

+ * + * @param type a int + */ + public void initCPAMatrix(int type) { + if (totalNumberOfAccociationSites == 0) { + FCPA = 0.0; + dFCPAdTdV = 0.0; + dFCPAdTdT = 0.0; + dFCPAdT = 0; + dFCPAdV = 0; + dFCPAdVdV = 0.0; + dFCPAdVdVdV = 0.0; + return; + } + + int temp = 0; + double tempVar1, tempVar2; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + tempVar1 = ksiMatrix.get(temp + j, 0); + tempVar2 = udotMatrix.get(temp + j, 0); + uMatrix.set(temp + j, 0, Math.log(tempVar1) - tempVar1 + 1.0); + gvector[temp + j][0] = mVector.get(temp + j, 0) * tempVar2; + + if (moleculeNumber[temp + j] == i) { + udotTimesmiMatrix.set(i, temp + j, tempVar2); + } else { + udotTimesmiMatrix.set(i, temp + j, 0.0); + } + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + + if (type > 2) { + for (int p = 0; p < numberOfComponents; p++) { + lngi[p] = ((ComponentUMRCPA) componentArray[p]).calc_lngi(this); + } + } + + for (int i = 0; i < totalNumberOfAccociationSites; i++) { + for (int j = i; j < totalNumberOfAccociationSites; j++) { + delta[i][j] = deltaNog[i][j] * gcpa; + delta[j][i] = delta[i][j]; + if (type > 1) { + deltadT[i][j] = cpamix.calcDeltadT(assSiteNumber[i], assSiteNumber[j], + moleculeNumber[i], moleculeNumber[j], this, getTemperature(), + getPressure(), numberOfComponents); + deltadT[j][i] = deltadT[i][j]; + + deltadTdT[i][j] = cpamix.calcDeltadTdT(assSiteNumber[i], assSiteNumber[j], + moleculeNumber[i], moleculeNumber[j], this, getTemperature(), + getPressure(), numberOfComponents); + deltadTdT[j][i] = deltadTdT[i][j]; + } + } + } + + double totalVolume = getTotalVolume(); + double totalVolume2 = totalVolume * totalVolume, totalVolume3 = totalVolume2 * totalVolume; + double gdv1 = getGcpav() - 1.0 / totalVolume; + double gdv2 = gdv1 * gdv1; + double gdv3 = gdv2 * gdv1; + double Klk = 0.0; + double tempVar; + double tempKsiRead = 0.0; + for (int i = 0; i < totalNumberOfAccociationSites; i++) { + for (int j = i; j < totalNumberOfAccociationSites; j++) { + Klk = KlkMatrix.get(i, j); + tempVar = Klk * gdv1; + KlkVMatrix.set(i, j, tempVar); + KlkVMatrix.set(j, i, tempVar); + + tempVar = Klk * gdv2 + Klk * (gcpavv + 1.0 / totalVolume2); + KlkVVMatrix.set(i, j, tempVar); + KlkVVMatrix.set(j, i, tempVar); + + tempVar = Klk * gdv3 + + 3.0 * Klk * (gcpav - 1.0 / totalVolume) * (gcpavv + 1.0 / (totalVolume2)) + + Klk * (gcpavvv - 2.0 / (totalVolume3)); + KlkVVVMatrix.set(i, j, tempVar); + KlkVVVMatrix.set(j, i, tempVar); + + if (type > 1) { + tempVar = deltadT[i][j] / delta[i][j]; + + if (Math.abs(tempVar) > 1e-50) { + double tempVardT = deltadTdT[i][j] / delta[i][j] + - (deltadT[i][j] * deltadT[i][j]) / (delta[i][j] * delta[i][j]); + + tempVar2 = Klk * tempVar; + KlkTMatrix.set(i, j, tempVar2); + KlkTMatrix.set(j, i, tempVar2); + + tempVar2 = Klk * tempVar * (gcpav - 1.0 / totalVolume); + KlkTVMatrix.set(i, j, tempVar2); + KlkTVMatrix.set(j, i, tempVar2); + + tempVar2 = Klk * (tempVar * tempVar + tempVardT); + KlkTTMatrix.set(i, j, tempVar2); + KlkTTMatrix.set(j, i, tempVar2); + } + + if (type > 2) { + for (int p = 0; p < numberOfComponents; p++) { + double t1 = 0.0, t2 = 0.0; + if (moleculeNumber[i] == p) { + t1 = 1.0 / mVector.get(i, 0); + } + if (moleculeNumber[j] == p) { + t2 = 1.0 / mVector.get(j, 0); + } + Klkni[p][i][j] = Klk * (t1 + t2 + lngi[p]);// ((ComponentSrkCPA) + // getComponent(p)).calc_lngi(this)); + Klkni[p][j][i] = Klkni[p][i][j]; + } + } + } + } + tempKsiRead = ksiMatrix.get(i, 0); + QMatksiksiksi.set(i, 0, + 2.0 * mVector.get(i, 0) / (tempKsiRead * tempKsiRead * tempKsiRead)); + } + + SimpleMatrix ksiMatrixTranspose = ksiMatrix.transpose(); + + // dXdV + SimpleMatrix KlkVMatrixksi = KlkVMatrix.mult(ksiMatrix); + SimpleMatrix XV = hessianInvers.mult(KlkVMatrixksi); + SimpleMatrix XVtranspose = XV.transpose(); + + FCPA = mVector.transpose().mult(uMatrix.minus(ksiMatrix.elementMult(udotMatrix).scale(0.5))) + .get(0, 0);// QCPA.get(0, + // 0);//*0.5; + + dFCPAdV = ksiMatrixTranspose.mult(KlkVMatrixksi).get(0, 0) * (-0.5); + SimpleMatrix KlkVVMatrixTImesKsi = KlkVVMatrix.mult(ksiMatrix); + dFCPAdVdV = ksiMatrixTranspose.mult(KlkVVMatrixTImesKsi).scale(-0.5) + .minus(KlkVMatrixksi.transpose().mult(XV)).get(0, 0); + + SimpleMatrix QVVV = ksiMatrixTranspose.mult(KlkVVVMatrix.mult(ksiMatrix));// .scale(-0.5); + SimpleMatrix QVVksi = KlkVVMatrixTImesKsi.scale(-1.0); + SimpleMatrix QksiVksi = KlkVMatrix.scale(-1.0); + + dFCPAdVdVdV = -0.5 * QVVV.get(0, 0) + QVVksi.transpose().mult(XV).get(0, 0) * 3.0 + + XVtranspose.mult(QksiVksi.mult(XV)).get(0, 0) * 3.0 + + XVtranspose.mult(QMatksiksiksi.mult(XVtranspose)).mult(XV).get(0, 0); + + if (type == 1) { + return; + } + + temp = 0; + for (int p = 0; p < numberOfComponents; p++) { + for (int kk = 0; kk < getComponent(p).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(p)).setXsitedV(kk, XV.get(temp + kk, 0)); + } + temp += getComponent(p).getNumberOfAssociationSites(); + } + + // KlkTMatrix = new SimpleMatrix(KlkdT); + SimpleMatrix KlkTMatrixTImesKsi = KlkTMatrix.mult(ksiMatrix); + // dQdT + SimpleMatrix tempMatrix2 = ksiMatrixTranspose.mult(KlkTMatrixTImesKsi);// .scale(-0.5); + dFCPAdT = tempMatrix2.get(0, 0) * (-0.5); + + // SimpleMatrix KlkTVMatrix = new SimpleMatrix(KlkdTdV); + // SimpleMatrix tempMatrixTV = + // ksiMatrixTranspose.mult(KlkTVMatrix.mult(ksiMatrix)).scale(-0.5).minus(KlkTMatrixTImesKsi.transpose().mult(XV)); + // dFCPAdTdV = tempMatrixTV.get(0, 0); + // dXdT + SimpleMatrix XT = hessianInvers.mult(KlkTMatrixTImesKsi); + // dQdTdT + SimpleMatrix tempMatrixTT = ksiMatrixTranspose.mult(KlkTTMatrix.mult(ksiMatrix)).scale(-0.5) + .minus(KlkTMatrixTImesKsi.transpose().mult(XT)); + dFCPAdTdT = tempMatrixTT.get(0, 0); + + SimpleMatrix tempMatrixTV = ksiMatrixTranspose.mult(KlkTVMatrix.mult(ksiMatrix)).scale(-0.5) + .minus(KlkTMatrixTImesKsi.transpose().mult(XV)); + dFCPAdTdV = tempMatrixTV.get(0, 0); + + temp = 0; + for (int p = 0; p < numberOfComponents; p++) { + for (int kk = 0; kk < getComponent(p).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(p)).setXsitedT(kk, XT.get(temp + kk, 0)); + } + temp += getComponent(p).getNumberOfAssociationSites(); + } + + if (type == 2) { + return; + } + + // int assSites = 0; + // if(true) return; + for (int p = 0; p < numberOfComponents; p++) { + SimpleMatrix KiMatrix = new SimpleMatrix(Klkni[p]); + // KiMatrix.print(10,10); + // Matrix dQdniMatrix = + // (ksiMatrix.transpose().times(KiMatrix.times(ksiMatrix)).times(-0.5)); // this + // methods misses one part of .... + // dQdniMatrix.print(10,10); + // KiMatrix.print(10, 10); + // miMatrix.getMatrix(assSites, assSites, 0, totalNumberOfAccociationSites - + // 1).print(10, 10); + // Matrix tempMatrix20 = miMatrix.getMatrix(assSites, assSites, 0, + // totalNumberOfAccociationSites - + // 1).times(uMatrix).minus(ksiMatrix.transpose().times(KiMatrix.times(ksiMatrix)).times(-0.5));// + // ksiMatrix.transpose().times(KlkTMatrix.times(ksiMatrix)).times(-0.5); + // System.out.println("dQdn "); + // tempMatrix20.print(10, 10); + SimpleMatrix tempMatrix4 = KiMatrix.mult(ksiMatrix); + // udotTimesmiMatrix.getMatrix(assSites, assSites, 0, + // totalNumberOfAccociationSites - 1).print(10, 10); + SimpleMatrix tempMatrix5 = + udotTimesmiMatrix.extractVector(true, p).transpose().minus(tempMatrix4); + // tempMki[0] = mki[p]; + // Matrix amatrix = new Matrix(croeneckerProduct(tempMki, + // udotMatrix.getArray())); + // System.out.println("aMatrix "); + // amatrix.transpose().print(10, 10); + // System.out.println("temp4 matrix"); + // tempMatrix4.print(10, 10); + // Matrix tempMatrix5 = amatrix.minus(tempMatrix4); + SimpleMatrix tempMatrix6 = hessianInvers.mult(tempMatrix5);// .scale(-1.0); + // System.out.println("dXdni"); + // tempMatrix4.print(10, 10); + // tempMatrix5.print(10, 10); + // System.out.println("dXdn "); + // tempMatrix6.print(10, 10); + int temp2 = 0; + for (int compp = 0; compp < numberOfComponents; compp++) { + for (int kk = 0; kk < getComponent(compp).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(compp)).setXsitedni(kk, p, + -1.0 * tempMatrix6.get(temp2 + kk, 0)); + } + temp2 += getComponent(compp).getNumberOfAssociationSites(); + } + // assSites += getComponent(p).getNumberOfAssociationSites(); + } + } + + /** {@inheritDoc} */ + @Override + public void setMixingRule(int type) { + super.setMixingRule(type); + cpamix = cpaSelect.getMixingRule(1, this); + } + + /** + *

+ * calcDelta. + *

+ */ + public void calcDelta() { + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + deltaNog[i][j] = cpamix.calcDeltaNog(assSiteNumber[i], assSiteNumber[j], + moleculeNumber[i], moleculeNumber[j], this, getTemperature(), getPressure(), + numberOfComponents); + deltaNog[j][i] = deltaNog[i][j]; + } + } + } + + /** {@inheritDoc} */ + @Override + public void addcomponent(String componentName, double moles, double molesInPhase, + int compNumber) { + super.addcomponent(componentName, moles, molesInPhase, compNumber); + componentArray[compNumber] = + new ComponentUMRCPA(componentName, moles, molesInPhase, compNumber); + } + + /** {@inheritDoc} */ + @Override + public double getF() { + return super.getF() + cpaon * FCPA(); + } + + /** {@inheritDoc} */ + @Override + public double dFdT() { + return super.dFdT() + cpaon * dFCPAdT(); + } + + /** {@inheritDoc} */ + @Override + public double dFdTdV() { + return super.dFdTdV() + cpaon * dFCPAdTdV(); + } + + /** {@inheritDoc} */ + @Override + public double dFdV() { + double dv2 = dFCPAdV(); + return super.dFdV() + cpaon * dv2; + } + + // @Override + /** {@inheritDoc} */ + @Override + public double dFdVdV() { + return super.dFdVdV() + cpaon * dFCPAdVdV(); + } + + /** {@inheritDoc} */ + @Override + public double dFdVdVdV() { + return super.dFdVdVdV() + cpaon * dFCPAdVdVdV(); + } + + /** {@inheritDoc} */ + @Override + public double dFdTdT() { + return super.dFdTdT() + cpaon * dFCPAdTdT(); + } + + /** + *

+ * FCPA. + *

+ * + * @return a double + */ + public double FCPA() { + /* + * double tot = 0.0; double ans = 0.0; for (int i = 0; i < numberOfComponents; i++) { tot = + * 0.0; for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { double + * xai = ((ComponentSrkCPA) componentArray[i]).getXsite()[j]; tot += (Math.log(xai) - 1.0 / + * 2.0 * xai + 1.0 / 2.0); } ans += componentArray[i].getNumberOfMolesInPhase() * tot; } + * return ans; + */ + return FCPA; + } + + /** + *

+ * dFCPAdV. + *

+ * + * @return a double + */ + public double dFCPAdV() { + // return 1.0 / (2.0 * getTotalVolume()) * (1.0 - getTotalVolume() * getGcpav()) + // * hcpatot; + return dFCPAdV; + } + + /** + *

+ * dFCPAdVdV. + *

+ * + * @return a double + */ + public double dFCPAdVdV() { + // double sum1 = -1.0 / 2.0 * gcpavv * hcpatot; + // return -1.0 / getTotalVolume() * dFCPAdV() + sum1; + return dFCPAdVdV; + } + + /** + *

+ * dFCPAdVdVdV. + *

+ * + * @return a double + */ + public double dFCPAdVdVdV() { + return dFCPAdVdVdV; + // return -1.0 / getTotalVolume() * dFCPAdVdV() + 1.0 / + // Math.pow(getTotalVolume(), 2.0) * dFCPAdV() - hcpatot / (2.0 * + // Math.pow(getTotalVolume(), 2.0)) * (-getGcpav() - getTotalVolume() * gcpavv) + // + hcpatot / (2.0 * getTotalVolume()) * (-gcpavv - getTotalVolume() * gcpavvv + // - gcpavv); + } + + /** + *

+ * dFCPAdT. + *

+ * + * @return a double + */ + public double dFCPAdT() { + /* + * double tot = 0.0; double ans = 0.0; for (int i = 0; i < numberOfComponents; i++) { tot = + * 0.0; for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { double + * xai = ((ComponentSrkCPA) componentArray[i]).getXsite()[j]; double xaidT = + * ((ComponentSrkCPA) componentArray[i]).getXsitedT()[j]; tot += 1.0 / xai * xaidT - 0.5 * + * xaidT;// - 1.0 / 2.0 * xai + 1.0 / 2.0); } ans += + * componentArray[i].getNumberOfMolesInPhase() * tot; } System.out.println("dFCPAdT1 " + + * ans + " dfcpa2 " +dFCPAdT); return ans; + */ + return dFCPAdT; + } + + /** + *

+ * dFCPAdTdT. + *

+ * + * @return a double + */ + public double dFCPAdTdT() { + return dFCPAdTdT; + } + + /** + *

+ * dFCPAdTdV. + *

+ * + * @return a double + */ + public double dFCPAdTdV() { + // System.out.println("dFCPAdTdV1 " + dFCPAdTdV + " dFCPAdTdV " +( 1.0 / (2.0 * + // getTotalVolume()) * (1.0 - getTotalVolume() * getGcpav()) * hcpatotdT)); + return dFCPAdTdV; + /* + * if (totalNumberOfAccociationSites > 0) { return 1.0 / (2.0 * getTotalVolume()) * (1.0 - + * getTotalVolume() * getGcpav()) * hcpatotdT; } else { return 0; } + */ + } + + /** {@inheritDoc} */ + @Override + public double molarVolume(double pressure, double temperature, double A, double B, + int phasetype) throws neqsim.util.exception.IsNaNException, + neqsim.util.exception.TooManyIterationsException { + double BonV = phasetype == 0 ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + + if (BonV < 0) { + BonV = 1.0e-8; + } + + if (BonV >= 1.0) { + BonV = 0.9999; + } + double BonVold; + double BonV2; + double h = 0, dh = 0, dhh = 0; + double d1 = 0, d2 = 0; + double Btemp = getB(); + if (Btemp < 0) { + logger.info("b negative in volume calc"); + } + + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + int iterations = 0; + int maxIterations = 300; + do { + iterations++; + gcpa = calc_g(); + if (gcpa < 0) { + setMolarVolume(1.0 / Btemp / numberOfMolesInPhase); + gcpa = calc_g(); + } + + // lngcpa = + // Math.log(gcpa); + gcpav = calc_lngV(); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + + if (totalNumberOfAccociationSites > 0) { + solveX(); + } + + initCPAMatrix(1); + + BonV2 = BonV * BonV; + BonVold = BonV; + h = BonV - Btemp / numberOfMolesInPhase * dFdV() + - pressure * Btemp / (numberOfMolesInPhase * R * temperature); + dh = 1.0 + Btemp / (BonV2) * (Btemp / numberOfMolesInPhase * dFdVdV()); + dhh = -2.0 * Btemp / (BonV2 * BonV) * (Btemp / numberOfMolesInPhase * dFdVdV()) + - (Btemp * Btemp) / (BonV2 * BonV2) + * (Btemp / numberOfMolesInPhase * dFdVdVdV()); + + d1 = -h / dh; + d2 = -dh / dhh; + // System.out.println("h " + h + " iter " + iterations + " " + d1 + " d2 " + d2 + // + " d1 / d2 " + (d1 / d2)); + if (Math.abs(d1 / d2) <= 1.0) { + BonV += d1 * (1.0 + 0.5 * d1 / d2); + } else if (d1 / d2 < -1) { + BonV += 0.5 * d1; + } else if (d1 > d2) { + return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + // BonV += d2; + // double hnew = h + d2 * dh; + // if (Math.abs(hnew) > Math.abs(h)) { + // BonV = phasetype == 1 ? 2.0 / (2.0 + temperature / + // getPseudoCriticalTemperature()) : pressure * getB() / (numberOfMolesInPhase * + // temperature * R); + // } + } else { + BonV += 0.5 * d1; + } + if (Math.abs((BonV - BonVold) / BonV) > 0.1) { + BonV = BonVold + 0.1 * (BonV - BonVold); + } + if (BonV < 0) { + if (iterations < 10) { + // System.out.println(iterations + " BonV " + BonV); + BonV = (BonVold + BonV) / 2.0; + } else { + return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + } + } + + if (BonV >= 1.0) { + if (iterations < 10) { + BonV = (BonVold + BonV) / 2.0; + } else { + return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + } + } + /* + * if (BonV > 0.9999) { if (iterations < 10) { BonV = (BonVold + BonV) / 2.0; } else { + * // BonV = calcRootVolFinder(phasetype); // BonV = molarVolumeChangePhase(pressure, + * temperature, A, B, phasetype); // BonV = 0.9999; // BonV = phasetype == 1 ? 2.0 / + * (2.0 + temperature / getPseudoCriticalTemperature()) : pressure * getB() / + * (numberOfMolesInPhase * temperature * R); } + * + * } else if (BonV < 0) { if (iterations < 10) { BonV = Math.abs(BonVold + BonV) / 2.0; + * } else { // BonV = calcRootVolFinder(phasetype); // return + * molarVolumeChangePhase(pressure, temperature, A, B, phasetype); // BonV = phasetype + * == 1 ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) : pressure * getB() + * / (numberOfMolesInPhase * temperature * R); } } + */ + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + Z = pressure * getMolarVolume() / (R * temperature); + } while ((Math.abs((BonV - BonVold) / BonV) > 1.0e-10 || Math.abs(h) > 1e-12) + && iterations < maxIterations); + + // System.out.println("h failed " + h + " Z" + Z + " iterations " + iterations + + // " BonV " + BonV); + // if (Math.abs(h) > 1e-12) { + // System.out.println("h failed " + h + " Z" + Z + " iterations " + iterations + + // " BonV " + BonV); + // return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + // return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + // } + // System.out.println("Z" + Z + " iterations " + iterations + " BonV " + BonV); + // System.out.println("pressure " + Z*R*temperature/getMolarVolume()); + // System.out.println("volume " + getTotalVolume() + " molar volume " + + // getMolarVolume()); + // if(iterations>=100) throw new util.exception.TooManyIterationsException(); + // System.out.println("error in volume " + + // (-pressure+R*temperature/getMolarVolume()-R*temperature*dFdV()));// + " + // firstterm " + (R*temperature/molarVolume) + " second " + + // R*temperature*dFdV()); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " + // " +dh + " B " + Btemp + " gv" + gV() + " fv " + fv() + " fvv" + fVV()); + if (Double.isNaN(getMolarVolume())) { + throw new neqsim.util.exception.IsNaNException(this, "molarVolume", "Molar volume"); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " + // " +dh + " B " + Btemp + " D " + Dtemp + " gv" + gV() + " fv " + fv() + " fvv" + // + fVV()); + } + dFdNtemp = calcdFdNtemp(); + return getMolarVolume(); + } + + /** + * @return double[] + */ + double[] calcdFdNtemp() { + double tot1 = 0.0, tot2 = 0.0, tot3 = 0.0, tot4 = 0.0; + // double temp, temp2; + for (int k = 0; k < getNumberOfComponents(); k++) { + tot2 = 0.0; + tot3 = 0.0; + // temp = ((ComponentSrkCPA) getComponent(k)).calc_lngi(this); + // temp2 = ((ComponentSrkCPA) getComponent(k)).calc_lngidV(this); + for (int i = 0; i < getComponent(k).getNumberOfAssociationSites(); i++) { + tot2 -= 1.0 * ((ComponentUMRCPA) getComponent(k)).getXsitedV()[i]; + tot3 += (1.0 - ((ComponentUMRCPA) getComponent(k)).getXsite()[i]) * 1.0; + } + tot1 += 1.0 / 2.0 * tot2 * getComponent(k).getNumberOfMolesInPhase(); + tot4 += 0.5 * getComponent(k).getNumberOfMolesInPhase() * tot3; + } + return new double[] {-tot1, -tot4}; + } + + /** + *

+ * calc_hCPA. + *

+ * + * @return a double + */ + public double calc_hCPA() { + double htot = 0.0; + double tot = 0.0; + for (int i = 0; i < numberOfComponents; i++) { + htot = 0.0; + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + htot += (1.0 - ((ComponentUMRCPA) componentArray[i]).getXsite()[j]); + } + tot += componentArray[i].getNumberOfMolesInPhase() * htot; + } + return tot; + } + + /** + *

+ * calc_g. + *

+ * + * @return a double + */ + public double calc_g() { + tempTotVol = getMolarVolume(); + double temp = 1.0 - getb() / 4.0 / tempTotVol; + return (2.0 - getb() / 4.0 / tempTotVol) / (2.0 * temp * temp * temp); + } + + /** + *

+ * calc_lngV. + *

+ * + * @return a double + */ + public double calc_lngV() { + tempTotVol = getMolarVolume(); + // gv = -2.0 * getB() * (10.0 * getTotalVolume() - getB()) / getTotalVolume() / + // ((8.0 * getTotalVolume() - getB()) * (4.0 * getTotalVolume() - getB())); + return 1.0 / (2.0 - getB() / (4.0 * tempTotVol)) * getB() / (4.0 * tempTotVol * tempTotVol) + - 3.0 / (1.0 - getB() / (4.0 * tempTotVol)) * getB() + / (4.0 * tempTotVol * tempTotVol); + } + + /** + *

+ * calc_lngVV. + *

+ * + * @return a double + */ + public double calc_lngVV() { + tempTotVol = getMolarVolume(); + return 2.0 + * (640.0 * Math.pow(tempTotVol, 3.0) - 216.0 * getB() * tempTotVol * tempTotVol + + 24.0 * Math.pow(getB(), 2.0) * tempTotVol - Math.pow(getB(), 3.0)) + * getB() / (tempTotVol * tempTotVol) / Math.pow(8.0 * tempTotVol - getB(), 2.0) + / Math.pow(4.0 * tempTotVol - getB(), 2.0); + } + + /** + *

+ * calc_lngVVV. + *

+ * + * @return a double + */ + public double calc_lngVVV() { + tempTotVol = getMolarVolume(); + return 4.0 + * (Math.pow(getB(), 5.0) + 17664.0 * Math.pow(tempTotVol, 4.0) * getB() + - 4192.0 * Math.pow(tempTotVol, 3.0) * Math.pow(getB(), 2.0) + + 528.0 * Math.pow(getB(), 3.0) * tempTotVol * tempTotVol + - 36.0 * tempTotVol * Math.pow(getB(), 4.0) + - 30720.0 * Math.pow(tempTotVol, 5.0)) + * getB() / (Math.pow(tempTotVol, 3.0)) / Math.pow(-8.0 * tempTotVol + getB(), 3.0) + / Math.pow(-4.0 * tempTotVol + getB(), 3.0); + } + + /** + *

+ * calcXsitedV. + *

+ */ + public void calcXsitedV() { + if (getTotalNumberOfAccociationSites() > 0) { + initCPAMatrix(1); + } + } + + /** + *

+ * solveX. + *

+ * + * @return a boolean + */ + public boolean solveX() { + if (totalNumberOfAccociationSites == 0) { + return true; + } + + boolean solvedX = solveX2(15); + + DMatrixRMaj mVectorMat = mVector.getMatrix(); + DMatrixRMaj ksiMatrixMat = ksiMatrix.getMatrix(); + + // ksiMatrix.print(); + // second order method not working correctly and not used t the moment b ecause of numerical + // stability + int temp = 0, iter = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + mVectorMat.unsafe_set(temp + j, 0, componentArray[i].getNumberOfMolesInPhase()); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + + DMatrixRMaj mat1 = KlkMatrix.getMatrix(); + double Klk = 0.0; + double totvolume = getTotalVolume(); + double tempVari, tempVarj; + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + tempVari = mVectorMat.unsafe_get(i, 0); + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + tempVarj = mVectorMat.unsafe_get(j, 0); + Klk = tempVari * tempVarj / totvolume * delta[i][j]; + mat1.unsafe_set(i, j, Klk); + mat1.unsafe_set(j, i, Klk); + } + } + boolean solved = true; + // SimpleMatrix corrMatrix = null; + do { + solved = true; + iter++; + temp = 0; + double ksi = 0; + + double temp1, temp2; + for (int i = 0; i < numberOfComponents; i++) { + temp1 = componentArray[i].getNumberOfMolesInPhase(); + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + ksi = ((ComponentUMRCPA) componentArray[i]).getXsite()[j]; + ksiMatrixMat.unsafe_set(temp + j, 0, ksi); + // ksiMatrix.getMatrix().unsafe_set(temp + j, 0, + // ksiMatrix.getMatrix().unsafe_get(temp + j, 0)); + tempVari = 1.0 / ksi - 1.0; + udotMatrix.set(temp + j, 0, tempVari); + udotTimesmMatrix.set(temp + j, 0, temp1 * tempVari); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + + int krondelt; + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + temp1 = mVectorMat.unsafe_get(i, 0); + temp2 = ksiMatrix.get(i, 0); + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + krondelt = 0; + if (i == j) { + krondelt = 1; + } + tempVari = -temp1 / (temp2 * temp2) * krondelt - mat1.unsafe_get(i, j); + hessianMatrix.set(i, j, tempVari); + hessianMatrix.set(j, i, tempVari); + } + } + + // ksiMatrix = new SimpleMatrix(ksi); + // SimpleMatrix hessianMatrix = new SimpleMatrix(hessian); + try { + hessianInvers = hessianMatrix.invert(); + } catch (Exception e) { + logger.error("error", e); + return false; + } + if (solvedX) { + // System.out.println("solvedX "); + return true; + } + + DMatrixRMaj mat2 = ksiMatrix.getMatrix(); + CommonOps_DDRM.mult(mat1, mat2, corr2Matrix); + CommonOps_DDRM.subtract(udotTimesmMatrix.getDDRM(), corr2Matrix, corr3Matrix); + CommonOps_DDRM.mult(hessianInvers.getDDRM(), corr3Matrix, corr4Matrix); + // SimpleMatrix gMatrix = udotTimesmMatrix.minus(KlkMatrix.mult(ksiMatrix)); + // corrMatrix = + // hessianInvers.mult(udotTimesmMatrix.minus(KlkMatrix.mult(ksiMatrix)));//.scale(-1.0); + temp = 0; + // System.out.println("print SimpleMatrix ..."); + // corrMatrix.print(10, 10); + // SimpleMatrix simp = new SimpleMatrix(corr4Matrix); + // System.out.println("print CommonOps ..."); + // simp.print(10,10); + double newX; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + newX = ksiMatrix.get(temp + j, 0) - corr4Matrix.unsafe_get((temp + j), 0); + if (newX < 0) { + newX = 1e-10; + solved = false; + } + ((ComponentCPAInterface) componentArray[i]).setXsite(j, newX); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + // System.out.println("corrmatrix error " ); + // System.out.println("error " + NormOps_DDRM.normF(corr4Matrix)); + } while ((NormOps_DDRM.normF(corr4Matrix) > 1e-12 || !solved) && iter < 100); + + // System.out.println("iter " + iter + " error " + + // NormOps_DDRM.normF(corr4Matrix)); // corrMatrix.print(10, 10); + // ksiMatrix.print(10, 10); + return true; + } + + /** + *

+ * solveX2. + *

+ * + * @param maxIter a int + * @return a boolean + */ + public boolean solveX2(int maxIter) { + double err = .0, totalVolume = getTotalVolume(); + int iter = 0; + // if (delta == null) { + // initCPAMatrix(1); + double old = 0.0, neeval = 0.0; + // } + do { + iter++; + err = 0.0; + for (int i = 0; i < totalNumberOfAccociationSites; i++) { + old = ((ComponentUMRCPA) componentArray[moleculeNumber[i]]) + .getXsite()[assSiteNumber[i]]; + neeval = 0.0; + for (int j = 0; j < totalNumberOfAccociationSites; j++) { + neeval += componentArray[moleculeNumber[j]].getNumberOfMolesInPhase() + * delta[i][j] * ((ComponentUMRCPA) componentArray[moleculeNumber[j]]) + .getXsite()[assSiteNumber[j]]; + } + neeval = 1.0 / (1.0 + 1.0 / totalVolume * neeval); + ((ComponentUMRCPA) componentArray[moleculeNumber[i]]).setXsite(assSiteNumber[i], + neeval); + err += Math.abs((old - neeval) / neeval); + } + } while (Math.abs(err) > 1e-12 && iter < maxIter); + // System.out.println("iter " + iter); + if (Math.abs(err) < 1e-12) { + return true; + } else { + // System.out.println("did not solve for Xi in iterations: " + iter); + // System.out.println("error: " + err); + return false; + } + } + + /** {@inheritDoc} */ + @Override + public double getHcpatot() { + return hcpatot; + } + + /** + * Setter for property hcpatot. + * + * @param hcpatot New value of property hcpatot. + */ + public void setHcpatot(double hcpatot) { + this.hcpatot = hcpatot; + } + + /** {@inheritDoc} */ + @Override + public double getGcpa() { + return gcpa; + } + + /** + *

+ * calcRootVolFinder. + *

+ * + * @param phase a int + * @return a double + */ + public double calcRootVolFinder(int phase) { + double solvedBonVHigh = 0.0; + double solvedBonVlow = 1.0; + double oldh = 1; + // double[][] matrix = new double[2][2000]; + double BonV = 1.0 - 1e-10; + try { + // molarVolume(pressure, temperature, A, B, phaseType); + } catch (Exception e) { + logger.error("error", e); + } + double BonVold = BonV; + double Btemp = 0, h = 1; + // double Dtemp = 0, dh = 0, gvvv = 0, fvvv = 0, dhh = 0; + // double d1 = 0, d2 = 0; + Btemp = getB(); + // Dtemp = getA(); + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + for (int i = 0; i < 2000; i++) { + BonVold = BonV; + BonV = 1.0 - (i + 1e-6) * 1.0 / 2000.0; + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + Z = pressure * getMolarVolume() / (R * temperature); + gcpa = calc_g(); + // lngcpa = + // Math.log(gcpa); + setGcpav(calc_lngV()); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + + do { + } while (!solveX()); + + h = BonV - Btemp / numberOfMolesInPhase * dFdV() + - pressure * Btemp / (numberOfMolesInPhase * R * temperature); + + if (Math.signum(h) * Math.signum(oldh) < 0 && i > 2) { + if (solvedBonVlow < 1e-3) { + solvedBonVlow = (BonV + BonVold) / 2.0; + if (phase == 1) { + break; + } + } else { + solvedBonVHigh = (BonV + BonVold) / 2.0; + if (phase == 0) { + break; + } + } + } + solvedBonVHigh = (BonV + BonVold) / 2.0; + oldh = h; + // matrix[0][i] = BonV; + // matrix[1][i] = h; + } + if (solvedBonVlow < 1e-3) { + solvedBonVlow = solvedBonVHigh; + } + // dataPresentation.fileHandeling.createTextFile.TextFile file = new + // dataPresentation.fileHandeling.createTextFile.TextFile(); + // file.setValues(matrix); + // file.setOutputFileName("D:/temp/temp2.txt"); + // file.createFile(); + if (phase == 1) { + return solvedBonVlow; + } else { + return solvedBonVHigh; + } + } + + /** + *

+ * molarVolumeChangePhase. + *

+ * + * @param pressure a double + * @param temperature a double + * @param A a double + * @param B a double + * @param phasetype a int + * @return a double + * @throws neqsim.util.exception.IsNaNException if any. + * @throws neqsim.util.exception.TooManyIterationsException if any. + */ + public double molarVolumeChangePhase(double pressure, double temperature, double A, double B, + int phasetype) throws neqsim.util.exception.IsNaNException, + neqsim.util.exception.TooManyIterationsException { + double BonV = phasetype == 1 ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + // double BonV = calcRootVolFinder(phasetype); + // double BonVInit = BonV; + if (BonV < 0) { + BonV = 1.0e-8; + } + + if (BonV >= 1.0) { + BonV = 0.9999; + } + double BonVold = BonV; + double Btemp = 0, h = 0, dh = 0, dhh = 0; + // double gvvv = 0, fvvv = 0; + double d1 = 0, d2 = 0; + Btemp = getB(); + if (Btemp < 0) { + logger.info("b negative in volume calc"); + } + calcDelta(); + + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + int iterations = 0; + + do { + iterations++; + gcpa = calc_g(); + if (gcpa < 0) { + setMolarVolume(1.0 / Btemp / numberOfMolesInPhase); + gcpa = calc_g(); + } + + // lngcpa = + // Math.log(gcpa); + setGcpav(calc_lngV()); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + + solveX(); + + initCPAMatrix(1); + double BonV2 = BonV * BonV; + BonVold = BonV; + h = BonV - Btemp / numberOfMolesInPhase * dFdV() + - pressure * Btemp / (numberOfMolesInPhase * R * temperature); + dh = 1.0 + Btemp / (BonV2) * (Btemp / numberOfMolesInPhase * dFdVdV()); + dhh = -2.0 * Btemp / (BonV2 * BonV) * (Btemp / numberOfMolesInPhase * dFdVdV()) + - (Btemp * Btemp) / (BonV2 * BonV2) + * (Btemp / numberOfMolesInPhase * dFdVdVdV()); + + d1 = -h / dh; + d2 = -dh / dhh; + // System.out.println("d1" + d1 + " d2 " + d2 + " d1 / d2 " + (d1 / d2)); + if (Math.abs(d1 / d2) <= 1.0) { + BonV += d1 * (1.0 + 0.5 * d1 / d2); + } else if (d1 / d2 < -1) { + BonV += 0.5 * d1; + } else if (d1 > d2) { + BonV += d2; + double hnew = h + d2 * dh; + if (Math.abs(hnew) > Math.abs(h)) { + BonV = phasetype == 1 + ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + } + } else { + BonV += 0.5 * d1; + } + if (Math.abs((BonV - BonVold) / BonVold) > 0.1) { + BonV = BonVold + 0.1 * (BonV - BonVold); + } + + if (BonV > 1.1) { + if (iterations < 3) { + BonV = (BonVold + BonV) / 2.0; + } else { + BonV = phasetype == 1 + ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + } + } + + if (BonV < 0) { + if (iterations < 3) { + BonV = Math.abs(BonVold + BonV) / 2.0; + } else { + BonV = phasetype == 1 + ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + } + } + + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + Z = pressure * getMolarVolume() / (R * temperature); + + // System.out.println("Z " + Z + "h " + h + " BONV " + (Math.abs((BonV - + // BonVold) / BonV))); + } while ((Math.abs((BonV - BonVold) / BonV) > 1.0e-10) && iterations < 100); + + /* + * if (Math.abs(h) > 1e-8) { if (phasetype == 0) { molarVolume(pressure, temperature, A, B, + * 1); } else { molarVolume(pressure, temperature, A, B, 0); } return getMolarVolume(); } + */ + // System.out.println("Z" + Z + " iterations " + iterations + " BonV " + BonV); + // System.out.println("pressure " + Z*R*temperature/getMolarVolume()); + // System.out.println("volume " + getTotalVolume() + " molar volume " + + // getMolarVolume()); + // if(iterations>=100) throw new util.exception.TooManyIterationsException(); + // System.out.println("error in volume " + + // (-pressure+R*temperature/getMolarVolume()-R*temperature*dFdV()));// + " + // firstterm " + (R*temperature/molarVolume) + " second " + + // R*temperature*dFdV()); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " " +dh + " B + // " + Btemp + " gv" + gV() + " fv " + fv() + " fvv" + fVV()); + if (Double.isNaN(getMolarVolume())) { + throw new neqsim.util.exception.IsNaNException(this, "molarVolumeChangePhase", + "Molar volume"); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " + // " +dh + " B " + Btemp + " D " + Dtemp + " gv" + gV() + " fv " + fv() + " fvv" + // + fVV()); + } + + return getMolarVolume(); + } + + /** {@inheritDoc} */ + @Override + public double getGcpav() { + return gcpav; + } + + /** + *

+ * Setter for the field gcpav. + *

+ * + * @param gcpav a double + */ + public void setGcpav(double gcpav) { + this.gcpav = gcpav; + } + + /** {@inheritDoc} */ + @Override + public CPAMixingInterface getCpamix() { + return cpamix; + } + + /** {@inheritDoc} */ + @Override + public double calcPressure() { + gcpa = calc_g(); + // lngcpa = + // Math.log(gcpa); + setGcpav(calc_lngV()); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + solveX(); + hcpatot = calc_hCPA(); + + initCPAMatrix(1); + return super.calcPressure(); + } + + /** {@inheritDoc} */ + @Override + public int getCrossAssosiationScheme(int comp1, int comp2, int site1, int site2) { + if (comp1 == comp2) { + return selfAccociationScheme[comp1][site1][site2]; + } else { + return crossAccociationScheme[comp1][comp2][site1][site2]; + } + } + + /** + *

+ * croeneckerProduct. + *

+ * + * @param a an array of {@link double} objects + * @param b an array of {@link double} objects + * @return an array of {@link double} objects + */ + public double[][] croeneckerProduct(double[][] a, double[][] b) { + int aLength = a.length; + int aCols = a[0].length; + int bLength = b.length; + int bCols = b[0].length; + double[][] result = new double[aLength * bLength][(aCols) * (bCols)]; + for (int z = 0; z < aLength; z++) { + for (int i = 0; i < aCols; i++) { + for (int j = 0; j < bLength; j++) { + for (int k = 0; k < bCols; k++) { + result[j + (z * bLength)][k + (i * bCols)] = a[z][i] * b[j][k]; + } + } + } + } + return result; + } + + /** {@inheritDoc} */ + @Override + public int getTotalNumberOfAccociationSites() { + return totalNumberOfAccociationSites; + } + + /** {@inheritDoc} */ + @Override + public void setTotalNumberOfAccociationSites(int totalNumberOfAccociationSites) { + this.totalNumberOfAccociationSites = totalNumberOfAccociationSites; + } + + /** + *

+ * initOld2. + *

+ * + * @param totalNumberOfMoles a double + * @param numberOfComponents a int + * @param type a int + * @param phase a int + * @param beta a double + */ + public void initOld2(double totalNumberOfMoles, int numberOfComponents, int type, int phase, + double beta) { // type + // = 0 + // start + // init + // type + // =1 gi + // nye + // betingelser + if (type == 0) { + setTotalNumberOfAccociationSites(0); + selfAccociationScheme = new int[numberOfComponents][0][0]; + crossAccociationScheme = new int[numberOfComponents][numberOfComponents][0][0]; + for (int i = 0; i < numberOfComponents; i++) { + if (componentArray[i].getNumberOfmoles() < 1e-50) { + componentArray[i].setNumberOfAssociationSites(0); + } else { + componentArray[i].setNumberOfAssociationSites( + componentArray[i].getOrginalNumberOfAssociationSites()); + setTotalNumberOfAccociationSites(getTotalNumberOfAccociationSites() + + componentArray[i].getNumberOfAssociationSites()); + selfAccociationScheme[i] = cpaSelect.setAssociationScheme(i, this); + for (int j = 0; j < numberOfComponents; j++) { + crossAccociationScheme[i][j] = + cpaSelect.setCrossAssociationScheme(i, j, this); + } + } + } + + // had to remove if below - dont understand why.. Even + // if (getTotalNumberOfAccociationSites() != oldTotalNumberOfAccociationSites) { + mVector = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + KlkMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkVVVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + hessianMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTTMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + KlkTVMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), + getTotalNumberOfAccociationSites()); + corr2Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + corr3Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + corr4Matrix = new DMatrixRMaj(getTotalNumberOfAccociationSites(), 1); + Klkni = new double[numberOfComponents][getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + ksiMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + uMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + udotMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + moleculeNumber = new int[getTotalNumberOfAccociationSites()]; + assSiteNumber = new int[getTotalNumberOfAccociationSites()]; + gvector = new double[getTotalNumberOfAccociationSites()][1]; + udotTimesmMatrix = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + delta = new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltaNog = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltadT = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + deltadTdT = + new double[getTotalNumberOfAccociationSites()][getTotalNumberOfAccociationSites()]; + QMatksiksiksi = new SimpleMatrix(getTotalNumberOfAccociationSites(), 1); + // } + udotTimesmiMatrix = + new SimpleMatrix(getNumberOfComponents(), getTotalNumberOfAccociationSites()); + + oldTotalNumberOfAccociationSites = getTotalNumberOfAccociationSites(); + + int temp = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + moleculeNumber[temp + j] = i; + assSiteNumber[temp + j] = j; + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + } + if (cpamix == null) { + cpamix = cpaSelect.getMixingRule(1, this); + } + + super.init(totalNumberOfMoles, numberOfComponents, type, phase, beta); + if (type > 0 && isConstantPhaseVolume()) { + calcDelta(); + solveX(); + super.init(totalNumberOfMoles, numberOfComponents, 1, phase, beta); + gcpa = calc_g(); + // lngcpa = Math.log(gcpa); + setGcpav(calc_lngV()); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + } + + if (type > 0) { + hcpatot = calc_hCPA(); + } + + if (type > 1) { + initCPAMatrix(type); + // hcpatotdT = calc_hCPAdT(); + // super.init(totalNumberOfMoles, numberOfComponents, type, phase, beta); + } + } + + /** {@inheritDoc} */ + @Override + public double molarVolume2(double pressure, double temperature, double A, double B, int phase) + throws neqsim.util.exception.IsNaNException, + neqsim.util.exception.TooManyIterationsException { + Z = phase == 0 ? 1.0 : 1.0e-5; + setMolarVolume(Z * R * temperature / pressure); + // super.molarVolume(pressure,temperature, A, B, phase); + int iterations = 0; + double err = 0.0, dErrdV = 0.0; + double deltaV = 0; + + do { + A = calcA(this, temperature, pressure, numberOfComponents); + B = calcB(this, temperature, pressure, numberOfComponents); + + double dFdV = dFdV(), dFdVdV = dFdVdV(); + // double dFdVdVdV = dFdVdVdV(); + // double factor1 = 1.0e0, factor2 = 1.0e0; + err = -R * temperature * dFdV + R * temperature / getMolarVolume() - pressure; + + // System.out.println("pressure " + -R * temperature * dFdV + " " + R * + // temperature / getMolarVolume()); + // -pressure; + dErrdV = -R * temperature * dFdVdV + - R * temperature * numberOfMolesInPhase / Math.pow(getVolume(), 2.0); + + // System.out.println("errdV " + dErrdV); + // System.out.println("err " + err); + deltaV = -err / dErrdV; + + setMolarVolume(getMolarVolume() + deltaV / numberOfMolesInPhase); + + Z = pressure * getMolarVolume() / (R * temperature); + if (Z < 0) { + Z = 1e-6; + setMolarVolume(Z * R * temperature / pressure); + } + + // System.out.println("Z " + Z); + } while (Math.abs(err) > 1.0e-8 || iterations < 100); + // System.out.println("Z " + Z); + return getMolarVolume(); + } + + /** + *

+ * initCPAMatrixOld. + *

+ * + * @param type a int + */ + public void initCPAMatrixOld(int type) { + if (getTotalNumberOfAccociationSites() == 0) { + FCPA = 0.0; + dFCPAdTdV = 0.0; + dFCPAdTdT = 0.0; + dFCPAdT = 0; + dFCPAdV = 0; + dFCPAdVdV = 0.0; + dFCPAdVdVdV = 0.0; + + return; + } + + int temp = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + uMatrix.set(temp + j, 0, + Math.log(ksiMatrix.get(temp + j, 0)) - ksiMatrix.get(temp + j, 0) + 1.0); + gvector[temp + j][0] = mVector.get(temp + j, 0) * udotMatrix.get(temp + j, 0); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + for (int i = 0; i < getNumberOfComponents(); i++) { + for (int j = 0; j < getTotalNumberOfAccociationSites(); j++) { + if (moleculeNumber[j] == i) { + udotTimesmiMatrix.set(i, j, udotMatrix.get(j, 0)); + } else { + udotTimesmiMatrix.set(i, j, 0.0); + } + } + } + + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + delta[i][j] = deltaNog[i][j] * getGcpa(); + delta[j][i] = delta[i][j]; + if (type > 1) { + deltadT[i][j] = cpamix.calcDeltadT(assSiteNumber[i], assSiteNumber[j], + moleculeNumber[i], moleculeNumber[j], this, getTemperature(), + getPressure(), numberOfComponents); + deltadT[j][i] = deltadT[i][j]; + + deltadTdT[i][j] = cpamix.calcDeltadTdT(assSiteNumber[i], assSiteNumber[j], + moleculeNumber[i], moleculeNumber[j], this, getTemperature(), + getPressure(), numberOfComponents); + deltadTdT[j][i] = deltadTdT[i][j]; + } + } + } + + double totalVolume = getTotalVolume(); + double totalVolume2 = totalVolume * totalVolume, totalVolume3 = totalVolume2 * totalVolume; + double gdv1 = getGcpav() - 1.0 / totalVolume; + double gdv2 = gdv1 * gdv1; + double gdv3 = gdv2 * gdv1; + // double Klk = 0.0; + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + KlkVMatrix.set(i, j, KlkMatrix.get(i, j) * gdv1); + KlkVMatrix.set(j, i, KlkVMatrix.get(i, j)); + + KlkVVMatrix.set(i, j, KlkMatrix.get(i, j) * gdv2 + + KlkMatrix.get(i, j) * (gcpavv + 1.0 / totalVolume / totalVolume)); + KlkVVMatrix.set(j, i, KlkVVMatrix.get(i, j)); + + KlkVVVMatrix.set(i, j, + KlkMatrix.get(i, j) * gdv3 + + 3.0 * KlkMatrix.get(i, j) * (getGcpav() - 1.0 / totalVolume) + * (gcpavv + 1.0 / (totalVolume2)) + + KlkMatrix.get(i, j) * (gcpavvv - 2.0 / (totalVolume3))); + KlkVVVMatrix.set(j, i, KlkVVVMatrix.get(i, j)); + + if (type > 1) { + double tempVar = deltadT[i][j] / delta[i][j]; + double tempVardT = deltadTdT[i][j] / delta[i][j] + - (deltadT[i][j] * deltadT[i][j]) / (delta[i][j] * delta[i][j]); + + if (!Double.isNaN(tempVar)) { + // KlkdT[i][j] = KlkMatrix.getMatrix().unsafe_get(i, j) * tempVar; + // KlkdT[j][i] = KlkdT[i][j]; + + KlkTMatrix.set(i, j, KlkMatrix.get(i, j) * tempVar); + KlkTMatrix.set(j, i, KlkTMatrix.get(i, j)); + + KlkTVMatrix.set(i, j, + KlkMatrix.get(i, j) * tempVar * (gcpav - 1.0 / totalVolume)); + KlkTVMatrix.set(j, i, KlkTVMatrix.get(i, j)); + + KlkTTMatrix.set(i, j, + KlkMatrix.get(i, j) * (tempVar * tempVar + tempVardT)); + KlkTTMatrix.set(j, i, KlkTTMatrix.get(i, j)); + } + + if (type > 2) { + for (int p = 0; p < numberOfComponents; p++) { + double t1 = 0.0, t2 = 0.0; + if (moleculeNumber[i] == p) { + t1 = 1.0 / mVector.get(i, 0); + } + if (moleculeNumber[j] == p) { + t2 = 1.0 / mVector.get(j, 0); + } + Klkni[p][i][j] = KlkMatrix.get(i, j) * (t1 + t2 + + ((ComponentUMRCPA) getComponent(p)).calc_lngi(this)); + Klkni[p][j][i] = Klkni[p][i][j]; + } + } + } + } + QMatksiksiksi.set(i, 0, 2.0 * mVector.get(i, 0) + / (ksiMatrix.get(i, 0) * ksiMatrix.get(i, 0) * ksiMatrix.get(i, 0))); + } + + SimpleMatrix ksiMatrixTranspose = ksiMatrix.transpose(); + + // dXdV + SimpleMatrix KlkVMatrixksi = KlkVMatrix.mult(ksiMatrix); + SimpleMatrix XV = hessianInvers.mult(KlkVMatrixksi); + SimpleMatrix XVtranspose = XV.transpose(); + + SimpleMatrix QCPA = mVector.transpose() + .mult(uMatrix.minus(ksiMatrix.elementMult(udotMatrix).scale(0.5))); + FCPA = QCPA.get(0, 0); + + SimpleMatrix tempMatrix = ksiMatrixTranspose.mult(KlkVMatrixksi).scale(-0.5); + dFCPAdV = tempMatrix.get(0, 0); + SimpleMatrix KlkVVMatrixTImesKsi = KlkVVMatrix.mult(ksiMatrix); + SimpleMatrix tempMatrixVV = ksiMatrixTranspose.mult(KlkVVMatrixTImesKsi).scale(-0.5) + .minus(KlkVMatrixksi.transpose().mult(XV)); + dFCPAdVdV = tempMatrixVV.get(0, 0); + + SimpleMatrix QVVV = ksiMatrixTranspose.mult(KlkVVVMatrix.mult(ksiMatrix)).scale(-0.5); + SimpleMatrix QVVksi = KlkVVMatrixTImesKsi.scale(-1.0); + SimpleMatrix QksiVksi = KlkVMatrix.scale(-1.0); + + SimpleMatrix mat1 = QVVksi.transpose().mult(XV).scale(3.0); + SimpleMatrix mat2 = XVtranspose.mult(QksiVksi.mult(XV)).scale(3.0); + SimpleMatrix mat4 = XVtranspose.mult(QMatksiksiksi.mult(XVtranspose)).mult(XV); + + SimpleMatrix dFCPAdVdVdVMatrix = QVVV.plus(mat1).plus(mat2).plus(mat2).plus(mat4); + dFCPAdVdVdV = dFCPAdVdVdVMatrix.get(0, 0); + temp = 0; + + if (type == 1) { + return; + } + for (int p = 0; p < numberOfComponents; p++) { + for (int kk = 0; kk < getComponent(p).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(p)).setXsitedV(kk, XV.get(temp + kk, 0)); + } + temp += getComponent(p).getNumberOfAssociationSites(); + } + + // KlkTMatrix = new SimpleMatrix(KlkdT); + SimpleMatrix KlkTMatrixTImesKsi = KlkTMatrix.mult(ksiMatrix); + // dQdT + SimpleMatrix tempMatrix2 = ksiMatrixTranspose.mult(KlkTMatrixTImesKsi).scale(-0.5); + dFCPAdT = tempMatrix2.get(0, 0); + + // SimpleMatrix KlkTVMatrix = new SimpleMatrix(KlkdTdV); + // SimpleMatrix tempMatrixTV = + // ksiMatrixTranspose.mult(KlkTVMatrix.mult(ksiMatrix)).scale(-0.5).minus(KlkTMatrixTImesKsi.transpose().mult(XV)); + // dFCPAdTdV = tempMatrixTV.get(0, 0); + // dXdT + SimpleMatrix XT = hessianInvers.mult(KlkTMatrixTImesKsi); + // dQdTdT + SimpleMatrix tempMatrixTT = ksiMatrixTranspose.mult(KlkTTMatrix.mult(ksiMatrix)).scale(-0.5) + .minus(KlkTMatrixTImesKsi.transpose().mult(XT)); + dFCPAdTdT = tempMatrixTT.get(0, 0); + + SimpleMatrix tempMatrixTV = ksiMatrixTranspose.mult(KlkTVMatrix.mult(ksiMatrix)).scale(-0.5) + .minus(KlkTMatrixTImesKsi.transpose().mult(XV)); + dFCPAdTdV = tempMatrixTV.get(0, 0); + + temp = 0; + for (int p = 0; p < numberOfComponents; p++) { + for (int kk = 0; kk < getComponent(p).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(p)).setXsitedT(kk, XT.get(temp + kk, 0)); + } + temp += getComponent(p).getNumberOfAssociationSites(); + } + + if (type == 2) { + return; + } + + // int assSites = 0; + // if(true) return; + for (int p = 0; p < numberOfComponents; p++) { + SimpleMatrix KiMatrix = new SimpleMatrix(Klkni[p]); + // KiMatrix.print(10,10); + // Matrix dQdniMatrix = + // (ksiMatrix.transpose().times(KiMatrix.times(ksiMatrix)).times(-0.5)); // this + // methods misses one part of .... + // dQdniMatrix.print(10,10); + // KiMatrix.print(10, 10); + // miMatrix.getMatrix(assSites, assSites, 0, totalNumberOfAccociationSites - + // 1).print(10, 10); + // Matrix tempMatrix20 = miMatrix.getMatrix(assSites, assSites, 0, + // totalNumberOfAccociationSites - + // 1).times(uMatrix).minus(ksiMatrix.transpose().times(KiMatrix.times(ksiMatrix)).times(-0.5));// + // ksiMatrix.transpose().times(KlkTMatrix.times(ksiMatrix)).times(-0.5); + // System.out.println("dQdn "); + // tempMatrix20.print(10, 10); + SimpleMatrix tempMatrix4 = KiMatrix.mult(ksiMatrix); + // udotTimesmiMatrix.getMatrix(assSites, assSites, 0, + // totalNumberOfAccociationSites - 1).print(10, 10); + SimpleMatrix tempMatrix5 = + udotTimesmiMatrix.extractVector(true, p).transpose().minus(tempMatrix4); + // tempMki[0] = mki[p]; + // Matrix amatrix = new Matrix(croeneckerProduct(tempMki, + // udotMatrix.getArray())); + // System.out.println("aMatrix "); + // amatrix.transpose().print(10, 10); + // System.out.println("temp4 matrix"); + // tempMatrix4.print(10, 10); + // Matrix tempMatrix5 = amatrix.minus(tempMatrix4); + SimpleMatrix tempMatrix6 = hessianInvers.mult(tempMatrix5);// .scale(-1.0); + // System.out.println("dXdni"); + // tempMatrix4.print(10, 10); + // tempMatrix5.print(10, 10); + // System.out.println("dXdn "); + // tempMatrix6.print(10, 10); + int temp2 = 0; + for (int compp = 0; compp < numberOfComponents; compp++) { + for (int kk = 0; kk < getComponent(compp).getNumberOfAssociationSites(); kk++) { + ((ComponentCPAInterface) getComponent(compp)).setXsitedni(kk, p, + -1.0 * tempMatrix6.get(temp2 + kk, 0)); + } + temp2 += getComponent(compp).getNumberOfAssociationSites(); + } + // assSites += getComponent(p).getNumberOfAssociationSites(); + } + } + + /** + *

+ * solveXOld. + *

+ * + * @return a boolean + */ + public boolean solveXOld() { + if (getTotalNumberOfAccociationSites() == 0) { + return true; + } + + boolean solvedX = solveX2(5); + if (solvedX) { + // return true; + } + + DMatrixRMaj mat1 = KlkMatrix.getMatrix(); + DMatrixRMaj mat2 = ksiMatrix.getMatrix(); + // second order method not working correctly and not used t the moment b ecause of numerical + // stability + int temp = 0, iter = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + mVector.set(temp + j, 0, componentArray[i].getNumberOfMolesInPhase()); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + double Klk = 0.0; + double totalVolume = getTotalVolume(); + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + Klk = mVector.get(i, 0) * mVector.get(j, 0) / totalVolume * delta[i][j]; + KlkMatrix.set(i, j, Klk); + KlkMatrix.set(j, i, Klk); + } + } + boolean solved = true; + // SimpleMatrix corrMatrix = null; + do { + solved = true; + iter++; + temp = 0; + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + ksiMatrix.set(temp + j, 0, ((ComponentUMRCPA) componentArray[i]).getXsite()[j]); + // ksiMatrix.getMatrix().unsafe_set(temp + j, 0, + // ksiMatrix.getMatrix().unsafe_get(temp + j, 0)); + udotMatrix.set(temp + j, 0, 1.0 / ksiMatrix.get(temp + j, 0) - 1.0); + udotTimesmMatrix.set(temp + j, 0, + mVector.get(temp + j, 0) * udotMatrix.get(temp + j, 0)); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + for (int j = i; j < getTotalNumberOfAccociationSites(); j++) { + int krondelt = 0; + if (i == j) { + krondelt = 1; + } + hessianMatrix.set(i, j, + -mVector.get(i, 0) / (ksiMatrix.get(i, 0) * ksiMatrix.get(i, 0)) + * krondelt - KlkMatrix.get(i, j)); + hessianMatrix.set(j, i, hessianMatrix.get(i, j)); + } + } + + // ksiMatrix = new SimpleMatrix(ksi); + // SimpleMatrix hessianMatrix = new SimpleMatrix(hessian); + try { + hessianInvers = hessianMatrix.invert(); + } catch (Exception e) { + logger.error("error", e); + return false; + } + + CommonOps_DDRM.mult(mat1, mat2, corr2Matrix); + CommonOps_DDRM.subtract(udotTimesmMatrix.getDDRM(), corr2Matrix, corr3Matrix); + CommonOps_DDRM.mult(hessianInvers.getDDRM(), corr3Matrix, corr4Matrix); + // SimpleMatrix gMatrix = udotTimesmMatrix.minus(KlkMatrix.mult(ksiMatrix)); + // corrMatrix = + // hessianInvers.mult(udotTimesmMatrix.minus(KlkMatrix.mult(ksiMatrix)));//.scale(-1.0); + temp = 0; + // System.out.println("print SimpleMatrix ..."); + // corrMatrix.print(10, 10); + // SimpleMatrix simp = new SimpleMatrix(corr4Matrix); + // System.out.println("print CommonOps ..."); + // simp.print(10,10); + for (int i = 0; i < numberOfComponents; i++) { + for (int j = 0; j < componentArray[i].getNumberOfAssociationSites(); j++) { + double newX = + ksiMatrix.get(temp + j, 0) - corr4Matrix.unsafe_get((temp + j), 0); + if (newX < 0) { + newX = 1e-10; + solved = false; + } + ((ComponentCPAInterface) componentArray[i]).setXsite(j, newX); + } + temp += componentArray[i].getNumberOfAssociationSites(); + } + // System.out.println("corrmatrix error " ); + // System.out.println("error " + corrMatrix.norm1()); + } while ((NormOps_DDRM.normF(corr4Matrix) > 1e-12 || !solved) && iter < 100); + + // System.out.println("iter " + iter + " error " + NormOps.normF(corr4Matrix)); + // // corrMatrix.print(10, 10); + // ksiMatrix.print(10, 10); + return true; + } + + /** + *

+ * solveX2Old. + *

+ * + * @param maxIter a int + * @return a boolean + */ + public boolean solveX2Old(int maxIter) { + double err = .0; + int iter = 0; + // if (delta == null) { + // initCPAMatrix(1); + double old = 0.0, neeval = 0.0, totalVolume = getTotalVolume(); + // } + do { + iter++; + err = 0.0; + for (int i = 0; i < getTotalNumberOfAccociationSites(); i++) { + old = ((ComponentUMRCPA) getComponent(moleculeNumber[i])) + .getXsite()[assSiteNumber[i]]; + neeval = 0; + for (int j = 0; j < getTotalNumberOfAccociationSites(); j++) { + neeval += getComponent(moleculeNumber[j]).getNumberOfMolesInPhase() + * delta[i][j] * ((ComponentUMRCPA) getComponent(moleculeNumber[j])) + .getXsite()[assSiteNumber[j]]; + } + neeval = 1.0 / (1.0 + 1.0 / totalVolume * neeval); + ((ComponentCPAInterface) getComponent(moleculeNumber[i])).setXsite(assSiteNumber[i], + neeval); + err += Math.abs((old - neeval) / neeval); + } + } while (Math.abs(err) > 1e-10 && iter < maxIter); + // System.out.println("iter " + iter); + // if (Math.abs(err) + // < 1e-12) { + // return true; + // } else { + // System.out.println("did not solve for Xi in iterations: " + iter); + // System.out.println("error: " + err); + return false; + } + + /** + *

+ * molarVolumeOld. + *

+ * + * @param pressure a double + * @param temperature a double + * @param A a double + * @param B a double + * @param phasetype a int + * @return a double + * @throws neqsim.util.exception.IsNaNException if any. + * @throws neqsim.util.exception.TooManyIterationsException if any. + */ + public double molarVolumeOld(double pressure, double temperature, double A, double B, + int phasetype) throws neqsim.util.exception.IsNaNException, + neqsim.util.exception.TooManyIterationsException { + double BonV = phasetype == 0 ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + // if (pressure > 1000) { + // BonV = 0.9999; + // } + + // double calcRooBonVtVolFinder = calcRootVolFinder(phasetype); + // BonV = calcRooBonVtVolFinder; + // double BonVInit = BonV; + if (BonV < 0) { + BonV = 1.0e-8; + } + + if (BonV >= 1.0) { + BonV = 0.9999; + } + double BonVold; + double h = 0, dh = 0, dhh = 0; + double d1 = 0, d2 = 0; + double Btemp = getB(); + if (Btemp < 0) { + logger.info("b negative in volume calc"); + } + calcDelta(); + + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + int iterations = 0; + + do { + iterations++; + gcpa = calc_g(); + if (gcpa < 0) { + setMolarVolume(1.0 / Btemp / numberOfMolesInPhase); + gcpa = calc_g(); + } + + // lngcpa = + // Math.log(gcpa); + setGcpav(calc_lngV()); + gcpavv = calc_lngVV(); + gcpavvv = calc_lngVVV(); + + if (getTotalNumberOfAccociationSites() > 0) { + solveX(); + } + + initCPAMatrix(1); + double BonV2 = BonV * BonV; + BonVold = BonV; + h = BonV - Btemp / numberOfMolesInPhase * dFdV() + - pressure * Btemp / (numberOfMolesInPhase * R * temperature); + dh = 1.0 + Btemp / (BonV2) * (Btemp / numberOfMolesInPhase * dFdVdV()); + dhh = -2.0 * Btemp / (BonV2 * BonV) * (Btemp / numberOfMolesInPhase * dFdVdV()) + - (Btemp * Btemp) / (BonV2 * BonV2) + * (Btemp / numberOfMolesInPhase * dFdVdVdV()); + + d1 = -h / dh; + d2 = -dh / dhh; + // System.out.println("h " + h + " iter " + iterations + " " + d1 + " d2 " + d2 + // + " d1 / d2 " + (d1 / d2)); + if (Math.abs(d1 / d2) <= 1.0) { + BonV += d1 * (1.0 + 0.5 * d1 / d2); + } else if (d1 / d2 < -1) { + BonV += 0.5 * d1; + } else if (d1 > d2) { + BonV += d2; + double hnew = h + d2 * dh; + if (Math.abs(hnew) > Math.abs(h)) { + BonV = phasetype == 1 + ? 2.0 / (2.0 + temperature / getPseudoCriticalTemperature()) + : pressure * getB() / (numberOfMolesInPhase * temperature * R); + } + } else { + BonV += 0.5 * d1; + } + if (Math.abs((BonV - BonVold) / BonVold) > 0.1) { + BonV = BonVold + 0.1 * (BonV - BonVold); + } + + if (BonV > 0.9999) { + if (iterations < 3) { + BonV = (BonVold + BonV) / 2.0; + } else { + // return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + // BonV = 0.9999; + // BonV = phasetype == 1 ? 2.0 / (2.0 + temperature / + // getPseudoCriticalTemperature()) : pressure * getB() / (numberOfMolesInPhase * + // temperature * R); + } + } else if (BonV < 0) { + if (iterations < 3) { + BonV = Math.abs(BonVold + BonV) / 2.0; + } else { + // return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + // BonV = phasetype == 1 ? 2.0 / (2.0 + temperature / + // getPseudoCriticalTemperature()) : pressure * getB() / (numberOfMolesInPhase * + // temperature * R); + } + } + setMolarVolume(1.0 / BonV * Btemp / numberOfMolesInPhase); + Z = pressure * getMolarVolume() / (R * temperature); + } while ((Math.abs((BonV - BonVold) / BonV) > 1.0e-10 || Math.abs(h) > 1e-12) + && iterations < 100); + + if (Math.abs(h) > 1e-12) { + // System.out.println("h failed " + "Z" + Z + " iterations " + iterations + " + // BonV " + BonV); + // return molarVolumeChangePhase(pressure, temperature, A, B, phasetype); + } + // System.out.println("Z" + Z + " iterations " + iterations + " BonV " + BonV); + // System.out.println("pressure " + Z*R*temperature/getMolarVolume()); + // System.out.println("volume " + totalVolume + " molar volume " + + // getMolarVolume()); + // if(iterations>=100) throw new util.exception.TooManyIterationsException(); + // System.out.println("error in volume " + + // (-pressure+R*temperature/getMolarVolume()-R*temperature*dFdV()));// + " + // firstterm " + (R*temperature/molarVolume) + " second " + + // R*temperature*dFdV()); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " " +dh + " B + // " + Btemp + " gv" + gV() + " fv " + fv() + " fvv" + fVV()); + + if (Double.isNaN(getMolarVolume())) { + throw new neqsim.util.exception.IsNaNException(this, "molarVolumeOld", "Molar volume"); + // System.out.println("BonV: " + BonV + " "+" itert: " + iterations +" " +h + " + // " +dh + " B " + Btemp + " D " + Dtemp + " gv" + gV() + " fv " + fv() + " fvv" + // + fVV()); + } + return getMolarVolume(); + } +} diff --git a/src/main/java/neqsim/thermo/system/SystemUMRCPAEoS.java b/src/main/java/neqsim/thermo/system/SystemUMRCPAEoS.java new file mode 100644 index 0000000000..5edae7f13c --- /dev/null +++ b/src/main/java/neqsim/thermo/system/SystemUMRCPAEoS.java @@ -0,0 +1,48 @@ +/* + * System_SRK_EOS.java + * + * Created on 8. april 2000, 23:05 + */ + +package neqsim.thermo.system; +/** + * + * @author Even Solbraa + * @version + */ + +import neqsim.thermo.phase.PhaseUMRCPA; + +/** + * This class defines a thermodynamic system using the UMR-PRU with MC paramters equation of state + */ +public class SystemUMRCPAEoS extends SystemPrEos { + + + public SystemUMRCPAEoS() { + super(); + modelName = "UMR-CPA"; + attractiveTermNumber = 19; + useVolumeCorrection(false); + for (int i = 0; i < numberOfPhases; i++) { + phaseArray[i] = new PhaseUMRCPA(); + phaseArray[i].setTemperature(298.15); + phaseArray[i].setPressure(1.0); + phaseArray[i].useVolumeCorrection(false); + } + } + + public SystemUMRCPAEoS(double T, double P) { + super(T, P); + modelName = "UMR-CPA"; + attractiveTermNumber = 19; + useVolumeCorrection(false); + for (int i = 0; i < numberOfPhases; i++) { + phaseArray[i] = new PhaseUMRCPA(); + phaseArray[i].setTemperature(T); + phaseArray[i].setPressure(P); + phaseArray[i].useVolumeCorrection(false); + } + } + +} diff --git a/src/main/java/neqsim/thermo/system/SystemUMRPRUMCEosNew.java b/src/main/java/neqsim/thermo/system/SystemUMRPRUMCEosNew.java index f2a70444bc..0bc0565666 100644 --- a/src/main/java/neqsim/thermo/system/SystemUMRPRUMCEosNew.java +++ b/src/main/java/neqsim/thermo/system/SystemUMRPRUMCEosNew.java @@ -1,61 +1,48 @@ +/* + * System_SRK_EOS.java + * + * Created on 8. april 2000, 23:05 + */ + package neqsim.thermo.system; +/** + * + * @author Even Solbraa + * @version + */ + +import neqsim.thermo.phase.PhasePrEosvolcor; /** * This class defines a thermodynamic system using the UMR-PRU with MC paramters equation of state - * - * @author Even Solbraa */ public class SystemUMRPRUMCEosNew extends SystemUMRPRUMCEos { - private static final long serialVersionUID = 1000; - /** - *

- * Constructor for SystemUMRPRUMCEosNew. - *

- */ - public SystemUMRPRUMCEosNew() { - super(); - setBmixType(1); - modelName = "UMR-PRU-MC-EoS-New"; - } - /** - *

- * Constructor for SystemUMRPRUMCEosNew. - *

- * - * @param T a double - * @param P a double - */ - public SystemUMRPRUMCEosNew(double T, double P) { - super(T, P); - modelName = "UMR-PRU-MC-EoS_new"; - attractiveTermNumber = 13; + public SystemUMRPRUMCEosNew() { + super(); + modelName = "UMR-PRU-MC-EoS-New"; + attractiveTermNumber = 19; + useVolumeCorrection(false); + for (int i = 0; i < numberOfPhases; i++) { + phaseArray[i] = new PhasePrEosvolcor(); + phaseArray[i].setTemperature(298.15); + phaseArray[i].setPressure(1.0); + phaseArray[i].useVolumeCorrection(false); } + } - /** - *

- * Constructor for SystemUMRPRUMCEosNew. - *

- * - * @param T a double - * @param P a double - * @param solidCheck a boolean - */ - public SystemUMRPRUMCEosNew(double T, double P, boolean solidCheck) { - super(T, P, solidCheck); + public SystemUMRPRUMCEosNew(double T, double P) { + super(T, P); + modelName = "UMR-PRU-MC-EoS-New"; + attractiveTermNumber = 19; + useVolumeCorrection(false); + for (int i = 0; i < numberOfPhases; i++) { + phaseArray[i] = new PhasePrEosvolcor(); + phaseArray[i].setTemperature(T); + phaseArray[i].setPressure(P); + phaseArray[i].useVolumeCorrection(false); } + } - /** {@inheritDoc} */ - @Override - public SystemUMRPRUMCEos clone() { - SystemUMRPRUMCEos clonedSystem = null; - try { - clonedSystem = (SystemUMRPRUMCEosNew) super.clone(); - } catch (Exception e) { - logger.error("Cloning failed.", e); - } - - return clonedSystem; - } } diff --git a/src/test/java/neqsim/fluidMechanics/flowSystem/onePhaseFlowSystem/pipeFlowSystem/PipeFlowSystemTest.java b/src/test/java/neqsim/fluidMechanics/flowSystem/onePhaseFlowSystem/pipeFlowSystem/PipeFlowSystemTest.java index 068fd46536..3fff720421 100644 --- a/src/test/java/neqsim/fluidMechanics/flowSystem/onePhaseFlowSystem/pipeFlowSystem/PipeFlowSystemTest.java +++ b/src/test/java/neqsim/fluidMechanics/flowSystem/onePhaseFlowSystem/pipeFlowSystem/PipeFlowSystemTest.java @@ -82,6 +82,7 @@ void testSolveSteadyState() { for (int i = 0; i < pipe.getFlowNodes().length; i++) { //System.out.println("wall friction " + pipe.getNode(i).getWallFrictionFactor(0)); } + // System.out.println("pressure out calc friction " // + pipe.getNode(pipe.getFlowNodes().length - 1).getBulkSystem().getPressure() + " bara"); diff --git a/src/test/java/neqsim/thermo/system/ModelBaseTest.java b/src/test/java/neqsim/thermo/system/ModelBaseTest.java index f6a98cd8dd..a9ae048a96 100644 --- a/src/test/java/neqsim/thermo/system/ModelBaseTest.java +++ b/src/test/java/neqsim/thermo/system/ModelBaseTest.java @@ -13,135 +13,135 @@ * @version $Id: $Id * @since 2.2.3 */ -public abstract class ModelBaseTest extends neqsim.NeqSimTest{ - static SystemInterface thermoSystem = null; - neqsim.thermo.ThermodynamicModelTest fugTest; +public abstract class ModelBaseTest extends neqsim.NeqSimTest { + public static SystemInterface thermoSystem = null; + neqsim.thermo.ThermodynamicModelTest fugTest; - /** - *

- * testInit0. - *

- */ - @Test - public void testInit0() { - try { - thermoSystem.init(0); - } catch (Exception success) { - fail("Error running init0"); - } + /** + *

+ * testInit0. + *

+ */ + @Test + public void testInit0() { + try { + thermoSystem.init(0); + } catch (Exception success) { + fail("Error running init0"); } + } - /** - *

- * testInit1. - *

- */ - @Test - public void testInit1() { - try { - thermoSystem.init(1); - } catch (Exception success) { - fail("Error running init1"); - } + /** + *

+ * testInit1. + *

+ */ + @Test + public void testInit1() { + try { + thermoSystem.init(1); + } catch (Exception success) { + fail("Error running init1"); } + } - /** - *

- * testActivity. - *

- */ - @Test - public void testActivity() { - thermoSystem.init(0); - thermoSystem.init(1); - double activ1 = thermoSystem.getPhase(1).getActivityCoefficient(0); - thermoSystem.init(0); - thermoSystem.init(1); - double activ2 = thermoSystem.getPhase(1).getActivityCoefficient(0); - assertTrue(Math.abs((activ1 - activ2)) < 1e-6); - } + /** + *

+ * testActivity. + *

+ */ + @Test + public void testActivity() { + thermoSystem.init(0); + thermoSystem.init(1); + double activ1 = thermoSystem.getPhase(1).getActivityCoefficient(0); + thermoSystem.init(0); + thermoSystem.init(1); + double activ2 = thermoSystem.getPhase(1).getActivityCoefficient(0); + assertTrue(Math.abs((activ1 - activ2)) < 1e-6); + } - /** - *

- * testVolume. - *

- */ - @Test - public void testVolume() { - thermoSystem.init(0); - thermoSystem.init(1); - double dens1 = thermoSystem.getPhase(0).getDensity(); - thermoSystem.init(0); - thermoSystem.init(1); - double dens2 = thermoSystem.getPhase(1).getDensity(); - assertTrue(dens2 > dens1); - } + /** + *

+ * testVolume. + *

+ */ + @Test + public void testVolume() { + thermoSystem.init(0); + thermoSystem.init(1); + double dens1 = thermoSystem.getPhase(0).getDensity(); + thermoSystem.init(0); + thermoSystem.init(1); + double dens2 = thermoSystem.getPhase(1).getDensity(); + assertTrue(dens2 > dens1); + } - /** - *

- * testGibbs. - *

- */ - @Test - public void testGibbs() { - thermoSystem.init(0); - thermoSystem.init(1); - double gibbs1 = thermoSystem.getPhase(0).getGibbsEnergy(); - thermoSystem.init(0); - thermoSystem.init(1); - double gibbs2 = thermoSystem.getPhase(1).getGibbsEnergy(); - assertTrue(gibbs2 < gibbs1); - } + /** + *

+ * testGibbs. + *

+ */ + @Test + public void testGibbs() { + thermoSystem.init(0); + thermoSystem.init(1); + double gibbs1 = thermoSystem.getPhase(0).getGibbsEnergy(); + thermoSystem.init(0); + thermoSystem.init(1); + double gibbs2 = thermoSystem.getPhase(1).getGibbsEnergy(); + assertTrue(gibbs2 < gibbs1); + } - /** - *

- * testFugasities. - *

- */ - @Test - public void testFugasities() { - thermoSystem.init(0); - thermoSystem.init(1); - fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); - assertTrue(fugTest.checkFugacityCoefficients()); - } + /** + *

+ * testFugasities. + *

+ */ + @Test + public void testFugasities() { + thermoSystem.init(0); + thermoSystem.init(1); + fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); + assertTrue(fugTest.checkFugacityCoefficients()); + } - /** - *

- * testFugasitiesdT. - *

- */ - @Test - public void testFugasitiesdT() { - thermoSystem.init(0); - thermoSystem.init(3); - fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); - assertTrue(fugTest.checkFugacityCoefficientsDT()); - } + /** + *

+ * testFugasitiesdT. + *

+ */ + @Test + public void testFugasitiesdT() { + thermoSystem.init(0); + thermoSystem.init(3); + fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); + assertTrue(fugTest.checkFugacityCoefficientsDT()); + } - /** - *

- * testFugasitiesdP. - *

- */ - @Test - public void testFugasitiesdP() { - thermoSystem.init(0); - thermoSystem.init(3); - fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); - assertTrue(fugTest.checkFugacityCoefficientsDP()); - } + /** + *

+ * testFugasitiesdP. + *

+ */ + @Test + public void testFugasitiesdP() { + thermoSystem.init(0); + thermoSystem.init(3); + fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); + assertTrue(fugTest.checkFugacityCoefficientsDP()); + } - /** - *

- * testFugasitiesdn. - *

- */ - @Test - public void testFugasitiesdn() { - thermoSystem.init(0); - thermoSystem.init(3); - fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); - assertTrue(fugTest.checkFugacityCoefficientsDn()); - } + /** + *

+ * testFugasitiesdn. + *

+ */ + @Test + public void testFugasitiesdn() { + thermoSystem.init(0); + thermoSystem.init(3); + fugTest = new neqsim.thermo.ThermodynamicModelTest(thermoSystem); + assertTrue(fugTest.checkFugacityCoefficientsDn()); + } } diff --git a/src/test/java/neqsim/thermo/system/SystemUMRCPAEoStest.java b/src/test/java/neqsim/thermo/system/SystemUMRCPAEoStest.java new file mode 100644 index 0000000000..4a43afb9ff --- /dev/null +++ b/src/test/java/neqsim/thermo/system/SystemUMRCPAEoStest.java @@ -0,0 +1,233 @@ +package neqsim.thermo.system; + +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; +import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; +import neqsim.thermodynamicOperations.ThermodynamicOperations; + +class SystemUMRCPAEoStest extends neqsim.NeqSimTest { + static neqsim.thermo.system.SystemInterface testSystem = null; + static neqsim.thermo.ThermodynamicModelTest testModel = null; + neqsim.thermo.ThermodynamicModelTest fugTest; + + /** + *

+ * setUp. + *

+ */ + @BeforeAll + public static void setUp() { + // testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + //testSystem = new neqsim.thermo.system.SystemSrkCPA(400.0, 500.0); + //testSystem = new neqsim.thermo.system.SystemSrkCPA(400.0, 500.0); + testSystem = new neqsim.thermo.system.SystemUMRCPAEoS(800, 110); + // testSystem = new neqsim.thermo.system.SystemSrkEos(298.0, 10.0); + //testSystem.addComponent("nitrogen", 1); + testSystem.addComponent("water", 1); + //testSystem.addComponent("CO2", 0.01); + //testSystem.addComponent("methane", 0.68); + //testSystem.addComponent("ethane", 0.1); + // testSystem.addComponent("n-heptane", 0.2); + // testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); + //testSystem.setMixingRule(1); + testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + // testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + testSystem.init(0); + testOps.TPflash(); + testSystem.init(3); + //testSystem.initProperties(); + // testSystem.i + } + + + + /** + *

+ * testFugasities. + *

+ */ + //@Test + public void testFugasities() { + testSystem.init(0); + testSystem.init(1); + fugTest = new neqsim.thermo.ThermodynamicModelTest(testSystem); + assertTrue(fugTest.checkFugacityCoefficients()); + + double fucoef = testSystem.getComponent(0).getLogFugacityCoefficient(); + + assertEquals(-0.002884922, fucoef, 1e-6); + + + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + testOps.TPflash(); + testSystem.initProperties(); + double molvol = testSystem.getMolarVolume(); + + assertEquals(247.09909107115, molvol, 1e-2); + } + + /** + *

+ * testCompressibility. + *

+ */ + @Test + @DisplayName("test compressibility of gas phase") + public void testCompressibility() { + // testSystem = new neqsim.thermo.system.SystemPr(298.0, 10.0); + // testSystem = new SystemSrkEos(298.0, 10.0); + // testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + //testSystem = new neqsim.thermo.system.SystemSrkCPA(400, 500); + testSystem = new neqsim.thermo.system.SystemUMRCPAEoS(800, 110); + testSystem.addComponent("water", 1); + // testSystem.addComponent("CO2", 0.01); + //testSystem.addComponent("methane", 0.68); + //testSystem.addComponent("ethane", 0.1); + // testSystem.addComponent("n-heptane", 0.2); + //testSystem.setMixingRule(1); + testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + // testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + testSystem.init(0); + testOps.TPflash(); + testSystem.init(3); + testSystem.init(3); + System.out.println("molar volume gas+oil is " + testSystem.getMolarVolume()); + System.out.println("molar volume gas is " + testSystem.getPhase(0).getMolarVolume()); + System.out.println("fugacity of gas phase " + testSystem.getPhase(0).getFugacity(0)); + System.out.println("residual enthalpy of gas phase is " + testSystem.getPhase(0).getHresTP()); + System.out.println("isochoric heat capacity of gas phase is " + testSystem.getPhase(0).getCv("J/mol")); + System.out.println("isobaric heat capacity of gas phase is " + testSystem.getPhase(0).getCp("J/mol")); + System.out.println("internal energy of gas phase is " + testSystem.getPhase(0).getInternalEnergy()); + System.out.println("molar volume liquid is " + testSystem.getPhase(1).getMolarVolume()); + System.out.println("fugacity of gas phase " + testSystem.getPhase(1).getFugacity(0)); + System.out.println("enthalpy of gas phase is " + testSystem.getPhase(1).getEnthalpy("J/mol")); + System.out.println("isochoric heat capacity of gas phase is " + testSystem.getPhase(1).getCv("J/mol")); + //ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + //testOps.TPflash(); + + // testSystem.initProperties(); + // assertEquals(0.9711401538454589, testSystem.getPhase(0).getZ(), 0.001); + } + + /** + *

+ * testTPflash2. + *

+ */ + @Disabled + @Test + @DisplayName("test a TPflash2") + public void testTPflash2() { + assertEquals(2, testSystem.getNumberOfPhases()); + } + + /** + *

+ * testTPflash. + *

+ */ + @Disabled + @Test + @DisplayName("test a TPflash of the fluid (should return two phases)") + public void testTPflash() { + assertEquals(2, testSystem.getNumberOfPhases()); + } + + /** + *

+ * testFugacityCoefficients. + *

+ */ + @Test + @DisplayName("test the fugacity coefficients calculated") + public void testFugacityCoefficients() { + assertTrue(testModel.checkFugacityCoefficients()); + + // System.out.println("molar volume liquid is " + testSystem.((PhasePrEosvolcor) + // phase).getFC()); + } + + /** + *

+ * checkFugacityCoefficientsDP. + *

+ */ + @Test + @DisplayName("test derivative of fugacity coefficients with respect to pressure") + public void checkFugacityCoefficientsDP() { + //testSystem.init(0); + //testSystem.init(3); + assertTrue(testModel.checkFugacityCoefficientsDP()); + } + + /** + *

+ * checkFugacityCoefficientsDT. + *

+ */ + + @Test + @DisplayName("test derivative of fugacity coefficients with respect to temperature") + public void checkFugacityCoefficientsDT() { + assertTrue(testModel.checkFugacityCoefficientsDT()); + } + + /** + *

+ * checkFugacityCoefficientsDn. + *

+ */ + //@Test + @DisplayName("test derivative of fugacity coefficients with respect to composition") + public void checkFugacityCoefficientsDn() { + assertTrue(testModel.checkFugacityCoefficientsDn()); + } + + /** + *

+ * checkFugacityCoefficientsDn2. + *

+ */ + //@Test + @DisplayName("test derivative of fugacity coefficients with respect to composition (2nd method)") + public void checkFugacityCoefficientsDn2() { + assertTrue(testModel.checkFugacityCoefficientsDn2()); + } + + + /** + *

+ * checkPhaseEnvelope. + *

+ * + * @throws Exception + */ + // @Test + @DisplayName("calculate phase envelope using UMR") + public void checkPhaseEnvelope() throws Exception { + testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + testSystem.addComponent("methane", 0.9); + testSystem.addComponent("ethane", 0.1); + testSystem.addComponent("propane", 0.1); + testSystem.addComponent("i-butane", 0.1); + testSystem.addComponent("n-butane", 0.1); + testSystem.addComponent("n-pentane", 0.1); + testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); + testSystem.init(0); + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + try { + testOps.calcPTphaseEnvelope(); + System.out.println("Cricondenbar " + (testOps.get("cricondenbar")[0] - 273.15) + " " + + testOps.get("cricondenbar")[1]); + } catch (Exception e) { + assertTrue(false); + throw new Exception(e); + } + assertEquals(testOps.get("cricondenbar")[1], 130.686140727503, 0.02); + } +} diff --git a/src/test/java/neqsim/thermo/system/SystemUMRPRUMCEosNewTest.java b/src/test/java/neqsim/thermo/system/SystemUMRPRUMCEosNewTest.java index 4e58707d7f..07c42ca571 100644 --- a/src/test/java/neqsim/thermo/system/SystemUMRPRUMCEosNewTest.java +++ b/src/test/java/neqsim/thermo/system/SystemUMRPRUMCEosNewTest.java @@ -3,160 +3,216 @@ import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import neqsim.thermodynamicOperations.ThermodynamicOperations; -class SystemUMRPRUMCEosNewTest extends neqsim.NeqSimTest{ - static neqsim.thermo.system.SystemInterface testSystem = null; - static neqsim.thermo.ThermodynamicModelTest testModel = null; - - /** - *

- * setUp. - *

- */ - @BeforeAll - public static void setUp() { - testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); - testSystem.addComponent("nitrogen", 0.01); - testSystem.addComponent("CO2", 0.01); - testSystem.addComponent("methane", 0.68); - testSystem.addComponent("ethane", 0.1); - testSystem.addComponent("n-heptane", 0.2); - testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); - testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); - ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); - testOps.TPflash(); - testSystem.initProperties(); - } +class SystemUMRPRUMCEosNewTest extends neqsim.NeqSimTest { + static neqsim.thermo.system.SystemInterface testSystem = null; + static neqsim.thermo.ThermodynamicModelTest testModel = null; + neqsim.thermo.ThermodynamicModelTest fugTest; - /** - *

- * testCompressibility. - *

- */ - @Test - @DisplayName("test compressibility of gas phase") - public void testCompressibility() { - testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); - testSystem.addComponent("nitrogen", 0.01); - testSystem.addComponent("CO2", 0.01); - testSystem.addComponent("methane", 0.68); - testSystem.addComponent("ethane", 0.1); - testSystem.addComponent("n-heptane", 0.2); - testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); - ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); - testOps.TPflash(); - testSystem.initProperties(); - assertEquals(testSystem.getPhase(0).getZ(), 0.9711401538454589, 0.001); - } + /** + *

+ * setUp. + *

+ */ + @BeforeAll + public static void setUp() { + // testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + testSystem = new neqsim.thermo.system.SystemUMRPRUMCEosNew(298.0, 10.0); + //testSystem = new neqsim.thermo.system.SystemSrkEos(298.0, 10.0); + testSystem.addComponent("nitrogen", 0.7); + //testSystem.addComponent("CO2", 0.01); + //testSystem.addComponent("methane", 0.68); + testSystem.addComponent("ethane", 0.3); + // testSystem.addComponent("n-heptane", 0.2); + // testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); + // testSystem.setMixingRule(1); + testSystem.setMixingRule(1); + testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + // testModel = new neqsim.thermo.ThermodynamicModelTest(testSystem); + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + testOps.TPflash(); + testSystem.init(0); + testSystem.init(3); + //testSystem.initProperties(); + // testSystem.i + } - /** - *

- * testTPflash2. - *

- */ - @Test - @DisplayName("test a TPflash2") - public void testTPflash2() { - assertEquals(2, testSystem.getNumberOfPhases()); - } - /** - *

- * testTPflash. - *

- */ - @Test - @DisplayName("test a TPflash of the fluid (should return two phases)") - public void testTPflash() { - assertEquals(2, testSystem.getNumberOfPhases()); - } - /** - *

- * testFugacityCoefficients. - *

- */ - @Test - @DisplayName("test the fugacity coefficients calculated") - public void testFugacityCoefficients() { - assertTrue(testModel.checkFugacityCoefficients()); - } + /** + *

+ * testFugasities. + *

+ */ + // @Test + public void testFugasities() { + testSystem.init(0); + testSystem.init(1); + fugTest = new neqsim.thermo.ThermodynamicModelTest(testSystem); + assertTrue(fugTest.checkFugacityCoefficients()); - /** - *

- * checkFugacityCoefficientsDP. - *

- */ - @Test - @DisplayName("test derivative of fugacity coefficients with respect to pressure") - public void checkFugacityCoefficientsDP() { - assertTrue(testModel.checkFugacityCoefficientsDP()); - } + double fucoef = testSystem.getComponent(0).getLogFugacityCoefficient(); - /** - *

- * checkFugacityCoefficientsDT. - *

- */ - @Test - @DisplayName("test derivative of fugacity coefficients with respect to temperature") - public void checkFugacityCoefficientsDT() { - assertTrue(testModel.checkFugacityCoefficientsDT()); - } + assertEquals(-0.002884922, fucoef, 1e-6); - /** - *

- * checkFugacityCoefficientsDn. - *

- */ - @Test - @DisplayName("test derivative of fugacity coefficients with respect to composition") - public void checkFugacityCoefficientsDn() { - assertTrue(testModel.checkFugacityCoefficientsDn()); - } - /** - *

- * checkFugacityCoefficientsDn2. - *

- */ - @Test - @DisplayName("test derivative of fugacity coefficients with respect to composition (2nd method)") - public void checkFugacityCoefficientsDn2() { - assertTrue(testModel.checkFugacityCoefficientsDn2()); - } + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + testOps.TPflash(); + testSystem.initProperties(); + double molvol = testSystem.getMolarVolume(); + + assertEquals(247.09909107115, molvol, 1e-2); + } + + /** + *

+ * testCompressibility. + *

+ */ + @Test + @DisplayName("test compressibility of gas phase") + public void testCompressibility() { + // testSystem = new neqsim.thermo.system.SystemPr(298.0, 10.0); + // testSystem = new SystemSrkEos(298.0, 10.0); + // testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + testSystem = new neqsim.thermo.system.SystemUMRPRUMCEosNew(298, 10); + testSystem.addComponent("nitrogen", 0.7); + // testSystem.addComponent("CO2", 0.01); + //testSystem.addComponent("methane", 0.68); + testSystem.addComponent("ethane", 0.3); + // testSystem.addComponent("n-heptane", 0.2); + //testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); + testSystem.setMixingRule(0); + testSystem.init(0); + // testSystem.init(1); + testSystem.init(3); + System.out.println("molar volume gas+oil is " + testSystem.getMolarVolume()); + System.out.println("molar volume gas is " + testSystem.getPhase(0).getMolarVolume()); + System.out.println("molar volume liquid is " + testSystem.getPhase(1).getMolarVolume()); + // ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + // testOps.TPflash(); + + // testSystem.initProperties(); + // assertEquals(0.9711401538454589, testSystem.getPhase(0).getZ(), 0.001); + } + + /** + *

+ * testTPflash2. + *

+ */ + @Disabled + @Test + @DisplayName("test a TPflash2") + public void testTPflash2() { + assertEquals(2, testSystem.getNumberOfPhases()); + } + + /** + *

+ * testTPflash. + *

+ */ + @Disabled + @Test + @DisplayName("test a TPflash of the fluid (should return two phases)") + public void testTPflash() { + assertEquals(2, testSystem.getNumberOfPhases()); + } + + /** + *

+ * testFugacityCoefficients. + *

+ */ + @Test + @DisplayName("test the fugacity coefficients calculated") + public void testFugacityCoefficients() { + assertTrue(testModel.checkFugacityCoefficients()); + + // System.out.println("molar volume liquid is " + testSystem.((PhasePrEosvolcor) + // phase).getFC()); + } + + /** + *

+ * checkFugacityCoefficientsDP. + *

+ */ + @Test + @DisplayName("test derivative of fugacity coefficients with respect to pressure") + public void checkFugacityCoefficientsDP() { + + assertTrue(testModel.checkFugacityCoefficientsDP()); + } + + /** + *

+ * checkFugacityCoefficientsDT. + *

+ */ + + @Test + @DisplayName("test derivative of fugacity coefficients with respect to temperature") + public void checkFugacityCoefficientsDT() { + assertTrue(testModel.checkFugacityCoefficientsDT()); + } + + /** + *

+ * checkFugacityCoefficientsDn. + *

+ */ + @Test + @DisplayName("test derivative of fugacity coefficients with respect to composition") + public void checkFugacityCoefficientsDn() { + assertTrue(testModel.checkFugacityCoefficientsDn()); + } + + /** + *

+ * checkFugacityCoefficientsDn2. + *

+ */ + @Test + @DisplayName("test derivative of fugacity coefficients with respect to composition (2nd method)") + public void checkFugacityCoefficientsDn2() { + assertTrue(testModel.checkFugacityCoefficientsDn2()); + } + - /** - *

- * checkPhaseEnvelope. - *

- * - * @throws Exception - */ - @Test - @DisplayName("calculate phase envelope using UMR") - public void checkPhaseEnvelope() throws Exception { - testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); - testSystem.addComponent("methane", 0.9); - testSystem.addComponent("ethane", 0.1); - testSystem.addComponent("propane", 0.1); - testSystem.addComponent("i-butane", 0.1); - testSystem.addComponent("n-butane", 0.1); - testSystem.addComponent("n-pentane", 0.1); - testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); - testSystem.init(0); - ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); - try { - testOps.calcPTphaseEnvelope(); - System.out.println("Cricondenbar " + (testOps.get("cricondenbar")[0] - 273.15) + " " - + testOps.get("cricondenbar")[1]); - } catch (Exception e) { - assertTrue(false); - throw new Exception(e); - } - assertEquals(testOps.get("cricondenbar")[1], 130.686140727503, 0.02); + /** + *

+ * checkPhaseEnvelope. + *

+ * + * @throws Exception + */ + @Test + @DisplayName("calculate phase envelope using UMR") + public void checkPhaseEnvelope() throws Exception { + testSystem = new neqsim.thermo.system.SystemUMRPRUMCEos(298.0, 10.0); + testSystem.addComponent("methane", 0.9); + testSystem.addComponent("ethane", 0.1); + testSystem.addComponent("propane", 0.1); + testSystem.addComponent("i-butane", 0.1); + testSystem.addComponent("n-butane", 0.1); + testSystem.addComponent("n-pentane", 0.1); + testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); + testSystem.init(0); + ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); + try { + testOps.calcPTphaseEnvelope(); + System.out.println("Cricondenbar " + (testOps.get("cricondenbar")[0] - 273.15) + " " + + testOps.get("cricondenbar")[1]); + } catch (Exception e) { + assertTrue(false); + throw new Exception(e); } + assertEquals(testOps.get("cricondenbar")[1], 130.686140727503, 0.02); + } } diff --git a/src/test/java/neqsim/thermo/util/example/ModelTest.java b/src/test/java/neqsim/thermo/util/example/ModelTest.java index 79d2272272..01c0cec9e5 100644 --- a/src/test/java/neqsim/thermo/util/example/ModelTest.java +++ b/src/test/java/neqsim/thermo/util/example/ModelTest.java @@ -3,7 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import neqsim.thermo.system.SystemInterface; -import neqsim.thermo.system.SystemSrkCPAstatoil; +import neqsim.thermo.system.SystemSrkCPA; import neqsim.thermodynamicOperations.ThermodynamicOperations; /** @@ -24,8 +24,10 @@ public class ModelTest { public static void main(String args[]) { // SystemInterface testSystem = new SystemFurstElectrolyteEos(280.15,10.00); - // SystemInterface testSystem = new SystemSrkEos(298.15, 10.01325); - SystemInterface testSystem = new SystemSrkCPAstatoil(273.14 + 92, 42.0); + //SystemInterface testSystem = new SystemSrkEos(500, 1.0); + //SystemInterface testSystem = new SystemSrkCPAstatoil(273+150, 1.0); + SystemInterface testSystem = new SystemSrkCPA(273+150, 70); + //SystemInterface testSystem = new SystemSrkCPAs(273+150, 1.0); // SystemInterface testSystem = new SystemElectrolyteCPAstatoil(273.14 + 12, // 61.0); // SystemInterface testSystem = new SystemFurstElectrolyteEos(273.14 + 12, @@ -34,25 +36,25 @@ public static void main(String args[]) { // SystemInterface testSystem = new SystemSrkEos(298.15, 1.01325); ThermodynamicOperations testOps = new ThermodynamicOperations(testSystem); - testSystem.addComponent("methane", 100); - testSystem.addComponent("n-heptane", 1); - // testSystem.addComponent("water", 100); - // testSystem.addComponent("methane", 1); - // testSystem.addComponent("ethane", 1); - // testSystem.addComponent("TEG", 9); - // testSystem.addComponent("MEG", 3.1); + //testSystem.addComponent("methane", 100); + //testSystem.addComponent("n-heptane", 1); + testSystem.addComponent("water", 50); + //testSystem.addComponent("methane", 10); + //testSystem.addComponent("ethane", 15); + testSystem.addComponent("TEG", 9); + testSystem.addComponent("MEG", 50); // testSystem.addComponent("n-octane", 3.1); // testSystem.addComponent("Na+", 0.1); // testSystem.addComponent("Cl-", 0.1); // testSystem.addComponent("MEG", 2.1); - // testSystem.addComponent("methanol", 5.3); + testSystem.addComponent("methanol", 20); /// testSystem.addComponent("MEG", 5.3); // testSystem.addComponent("MEG", 10.0); // testSystem.addTBPfraction("C8", 10.1, 90.0 / 1000.0, 0.8); - testSystem.addComponent("MEG", 10.5); + //testSystem.addComponent("MEG", 10.5); // testSystem.createDatabase(true); // testSystem.useVolumeCorrection(true); - testSystem.setMixingRule(2); + testSystem.setMixingRule(10); // testSystem.setMixingRule("HV", "NRTL"); // testSystem.setMixingRule("HV", "UNIFAC_UMRPRU"); // testSystem.setMixingRule(9);