Classic liquid-vapor UNIFAC model derived type
This type holds the needed parameters for using a UNIFAC model mainly group areas, volumes and what temperature dependence function to use.
It also holds the individual molecules of a particular system and the set of all groups in the system as a “stew” of groups instead of being them included in particular molecules.
! UNIFAC model with ethanol-formic acid mix and calculate gammas
use yaeos, only: pr, Groups, setup_unifac, UNIFAC
type(UNIFAC) :: model
type(Groups) :: molecules(2)
real(pr) :: ln_gammas(2)
! Ethanol definition [CH3, CH2, OH]
molecules(1)%groups_ids = [1, 2, 14] ! Subgroups ids
molecules(1)%number_of_groups = [1, 1, 1] ! Subgroups occurrences
! formic acid definition [HCOOH]
molecules(2)%groups_ids = [43]
molecules(2)%number_of_groups = [1]
! Model setup
model = setup_unifac(molecules)
! Calculate ln_gammas
call model%ln_activity_coefficient([0.5_pr, 0.5_pr], 298.0_pr, ln_gammas)
print *, ln_gammas ! result: 0.10505475697637946 0.28073129552766890
Type | Visibility | Attributes | Name | Initial | |||
---|---|---|---|---|---|---|---|
type(Substances), | public | :: | components |
Substances contained in the module |
|||
real(kind=pr), | public, | allocatable | :: | group_area(:) |
Group areas |
||
real(kind=pr), | public, | allocatable | :: | group_volume(:) |
Group volumes |
||
type(Groups), | public | :: | groups_stew |
All the groups present in the system |
|||
type(Groups), | public, | allocatable | :: | molecules(:) |
Substances present in the system |
||
integer, | public | :: | ngroups |
Total number of individual groups in the mixture |
|||
integer, | public | :: | nmolecules |
Total number of molecules in the mixture |
|||
class(PsiFunction), | public, | allocatable | :: | psi_function |
Temperature dependance function of the model |
||
real(kind=pr), | public, | allocatable | :: | qk(:) |
Area of each group k |
||
real(kind=pr), | public, | allocatable | :: | thetas_ij(:,:) |
Area fractions of the groups j on molecules i |
||
real(kind=pr), | public, | allocatable | :: | vij(:,:) |
Ocurrences of each group j on each molecule i |
||
real(kind=pr), | public | :: | z | = | 10 |
Model constant |
Calculate the UNIFAC combinatorial term of Gibbs excess energy
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(UNIFAC) | :: | self | ||||
real(kind=pr), | intent(in) | :: | n(self%nmolecules) |
Moles vector [mol] |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | Ge |
Combinatorial Gibbs excess energy |
|
real(kind=pr), | intent(out), | optional | :: | dGe_dn(self%nmolecules) |
|
|
real(kind=pr), | intent(out), | optional | :: | dGe_dn2(self%nmolecules,self%nmolecules) |
|
Evaluate the UNIFAC residual term
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(UNIFAC) | :: | self | ||||
real(kind=pr), | intent(in) | :: | n(self%nmolecules) |
Moles vector |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | Ge |
Residual Gibbs excess energy |
|
real(kind=pr), | intent(out), | optional | :: | dGe_dn(self%nmolecules) |
|
|
real(kind=pr), | intent(out), | optional | :: | dGe_dn2(self%nmolecules,self%nmolecules) |
|
|
real(kind=pr), | intent(out), | optional | :: | dGe_dT |
|
|
real(kind=pr), | intent(out), | optional | :: | dGe_dT2 |
|
|
real(kind=pr), | intent(out), | optional | :: | dGe_dTn(self%nmolecules) |
|
Calculate Excess enthalpy and its derivatives.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(GeModel), | intent(in) | :: | self |
Model |
||
real(kind=pr), | intent(in) | :: | n(:) |
Moles vector |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | He |
Excess enthalpy |
|
real(kind=pr), | intent(out), | optional | :: | HeT |
|
|
real(kind=pr), | intent(out), | optional | :: | Hen(:) |
|
Calculate Excess entropy and its derivatives.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(GeModel), | intent(in) | :: | self |
Model |
||
real(kind=pr), | intent(in) | :: | n(:) |
Moles vector |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | Se |
Excess entropy |
|
real(kind=pr), | intent(out), | optional | :: | SeT |
|
|
real(kind=pr), | intent(out), | optional | :: | Sen(:) |
|
Calculate the Gibbs excess energy of the UNIFAC model
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(UNIFAC), | intent(in) | :: | self |
UNIFAC model |
||
real(kind=pr), | intent(in) | :: | n(:) |
Moles vector [mol] |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | Ge |
Excess Gibbs energy |
|
real(kind=pr), | intent(out), | optional | :: | GeT |
|
|
real(kind=pr), | intent(out), | optional | :: | GeT2 |
|
|
real(kind=pr), | intent(out), | optional | :: | Gen(size(n)) |
|
|
real(kind=pr), | intent(out), | optional | :: | GeTn(size(n)) |
|
|
real(kind=pr), | intent(out), | optional | :: | Gen2(size(n),size(n)) |
|
Calculate natural logarithm of activity coefficients.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(GeModel), | intent(in) | :: | self |
Model |
||
real(kind=pr), | intent(in) | :: | n(:) |
Moles vector |
||
real(kind=pr), | intent(in) | :: | T |
Temperature [K] |
||
real(kind=pr), | intent(out), | optional | :: | lngamma(:) |
Natural logarithm of activity coefficients |
|
real(kind=pr), | intent(out), | optional | :: | dlngammadT(size(n)) |
|
|
real(kind=pr), | intent(out), | optional | :: | dlngammadn(size(n),size(n)) |
|