yaeos__equilibria_rachford_rice Module



Subroutines

public subroutine betalimits(z, K, bmin, bmax)

Define beta limits to avoid overshooting when solving the Rachford-Rice equation.

Read more…

Arguments

Type IntentOptional Attributes Name
real(kind=pr), intent(in) :: z(:)

Molar fractions vector

real(kind=pr), intent(in) :: K(:)

K-factors

real(kind=pr), intent(out) :: bmin

Minimum beta value

real(kind=pr), intent(out) :: bmax

Maximum beta value

public subroutine betato01(z, K)

Modify K-factor values to assure that lies between (0,1)

Read more…

Arguments

Type IntentOptional Attributes Name
real(kind=pr), intent(in) :: z(:)

Molar fractions of the system

real(kind=pr) :: K(:)

K factors

public subroutine rachford_rice(z, K, beta, rr, drrdb)

Rachford-Rice equation for a two phase system. This equation is used to calculate the value that satisfies the mass balance between two phases.

Read more…

Arguments

Type IntentOptional Attributes Name
real(kind=pr), intent(in) :: z(:)

Mole fractions vector

real(kind=pr), intent(in) :: K(:)

K-factors

real(kind=pr), intent(in) :: beta

value

real(kind=pr), intent(out) :: rr

Rachford-Rice function value

real(kind=pr), intent(out) :: drrdb

Derivative of the Rachford-Rice function

public subroutine solve_rr(z, K, beta, beta_min, beta_max)

Solve the Rachford-Rice Equation using the Newton method.

Read more…

Arguments

Type IntentOptional Attributes Name
real(kind=pr), intent(in) :: z(:)

Mole fractions vector

real(kind=pr), intent(in) :: K(:)

K-factors

real(kind=pr), intent(out) :: beta

value

real(kind=pr), intent(out) :: beta_min

Lower limit for

real(kind=pr), intent(out) :: beta_max

Upper limit for