Skip to content

Commit

Permalink
Add AbstractState_get_mol_fractions and `AbstractState_get_mol_frac…
Browse files Browse the repository at this point in the history
…tions_satState` (CoolProp#1)

* successfully add get_mol_fraction functions

* add docstrings and edit spacing
  • Loading branch information
chris-hampel-CA authored and barche committed Sep 24, 2023
1 parent 2d02991 commit e7b06dc
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 4 deletions.
71 changes: 68 additions & 3 deletions src/CoolProp.jl
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ using CoolProp_jll

errcode = Ref{Clong}(0)
const message_buffer = Array{UInt8}(undef, 32768) #2^15

const maxN = 100 #max number of species per model
const inputs_to_get_global_param_string = ["version", "gitrevision", "errstring", "warnstring", "FluidsList", "incompressible_list_pure", "incompressible_list_solution", "mixture_binary_pairs_list", "parameter_list", "predefined_mixtures", "HOME", "cubic_fluids_schema"]

# ---------------------------------
Expand Down Expand Up @@ -111,7 +111,7 @@ function _get_unit(param::AbstractString)
end
# Otherwise use the normal parameter info
unit_str = "-"
try
try
unit_str = get_parameter_information_string(param, "units")
catch
end
Expand Down Expand Up @@ -822,6 +822,71 @@ function AbstractState_set_fractions(handle::Clong, fractions::Array{Float64})
return nothing
end

"""
AbstractState_get_mole_fractions(handle::Clong, fractions::Array{Float64})
Get the molar fractions for the AbstractState.
# Arguments
* `handle`: The integer handle for the state class stored in memory
* `fractions`: The array of fractions
# Example
```julia
julia> handle = AbstractState_factory("HEOS", "Water&Ethanol");
julia> pq_inputs = get_input_pair_index("PQ_INPUTS");
julia> t = get_param_index("T");
julia> AbstractState_set_fractions(handle, [0.4, 0.6]);
julia> AbstractState_update(handle, pq_inputs, 101325, 0);
julia> mole_frac = [0.0, 0.0]
julia> AbstractState_get_mole_fractions(handle, mole_frac)
julia> @show mole_frac
mole_frac = [0.4, 0.6]
julia> AbstractState_free(handle);
```
"""
function AbstractState_get_mole_fractions(handle::Clong, fractions::Array{Float64})
ccall( (:AbstractState_get_mole_fractions, libcoolprop), Nothing, (Clong, Ptr{Cdouble}, Clong, Ref{Clong}, Ref{Clong}, Ptr{UInt8}, Clong), handle, fractions, maxN, length(fractions), errcode, message_buffer::Array{UInt8, 1}, buffer_length)
raise(errcode, message_buffer)
return nothing
end

"""
AbstractState_get_mole_fractions_satState(handle::Clong, saturated_state::AbstractString,
fractions::Array{Float64})
Get the molar fractions for the AbstractState and the desired saturated State.
# Arguments
* `handle`: The integer handle for the state class stored in memory
* `saturated_state`: The string specifying the state (liquid or gas)
* `fractions`: The array of fractions
# Example
```julia
julia> handle = AbstractState_factory("HEOS", "Water&Ethanol");
julia> pq_inputs = get_input_pair_index("PQ_INPUTS");
julia> t = get_param_index("T");
julia> AbstractState_set_fractions(handle, [0.4, 0.6]);
julia> AbstractState_update(handle, pq_inputs, 101325, 0);
julia> gas_frac = [0.0, 0.0]
julia> AbstractState_get_mole_fractions_satState(handle, "gas", gas_frac)
julia> @show gas_frac
gas_frac = [0.30304421184833846, 0.6969557881516616]
julia> liq_frac = [0.0, 0.0]
julia> AbstractState_get_mole_fractions_satState(handle, "liquid", liq_frac)
julia> @show liq_frac
liq_frac = [0.4, 0.6]
julia> AbstractState_free(handle);
```
"""
function AbstractState_get_mole_fractions_satState(handle::Clong, saturated_state::AbstractString,
fractions::Array{Float64})
ccall( (:AbstractState_get_mole_fractions_satState, libcoolprop), Nothing, (Clong, Cstring, Ptr{Cdouble}, Clong, Ref{Clong}, Ref{Clong}, Ptr{UInt8}, Clong), handle, saturated_state, fractions, maxN, length(fractions), errcode, message_buffer::Array{UInt8, 1}, buffer_length)
raise(errcode, message_buffer)
return nothing
end

"""
AbstractState_update(handle::Clong, input_pair::Clong, value1::Real, value2::Real)
AbstractState_update(handle::Clong, input_pair::AbstractString, value1::Real, value2::Real)
Expand Down Expand Up @@ -1368,7 +1433,7 @@ function AbstractState_all_critical_points(handle::Clong, length::Integer)
return AbstractState_all_critical_points(handle, length, T, p, rhomolar, stable)
end

for symorigin = [:PropsSI, :PhaseSI, :K2F, :F2K, :HAPropsSI, :AbstractState_factory, :AbstractState_free, :AbstractState_set_fractions, :AbstractState_update, :AbstractState_keyed_output, :AbstractState_output, :AbstractState_specify_phase, :AbstractState_unspecify_phase, :AbstractState_update_and_common_out, :AbstractState_update_and_1_out, :AbstractState_update_and_5_out, :AbstractState_set_binary_interaction_double, :AbstractState_set_cubic_alpha_C, :AbstractState_set_fluid_parameter_double, :AbstractState_first_saturation_deriv, :AbstractState_first_partial_deriv, :AbstractState_build_phase_envelope, :AbstractState_build_spinodal, :AbstractState_all_critical_points, :AbstractState_get_phase_envelope_data, :AbstractState_get_spinodal_data]
for symorigin = [:PropsSI, :PhaseSI, :K2F, :F2K, :HAPropsSI, :AbstractState_factory, :AbstractState_free, :AbstractState_set_fractions, :AbstractState_get_mole_fractions, :AbstractState_get_mole_fractions_satState, :AbstractState_update, :AbstractState_keyed_output, :AbstractState_output, :AbstractState_specify_phase, :AbstractState_unspecify_phase, :AbstractState_update_and_common_out, :AbstractState_update_and_1_out, :AbstractState_update_and_5_out, :AbstractState_set_binary_interaction_double, :AbstractState_set_cubic_alpha_C, :AbstractState_set_fluid_parameter_double, :AbstractState_first_saturation_deriv, :AbstractState_first_partial_deriv, :AbstractState_build_phase_envelope, :AbstractState_build_spinodal, :AbstractState_all_critical_points, :AbstractState_get_phase_envelope_data, :AbstractState_get_spinodal_data]
sym = Symbol(lowercase(string(symorigin)))
@eval const $sym = $symorigin
@eval export $sym, $symorigin
Expand Down
11 changes: 10 additions & 1 deletion test/testLow.jl
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
using CoolProp
using Test

#low
@info "********* Low Level Api *********"
const HEOS_BACKEND_FAMILY = "HEOS"
Expand Down Expand Up @@ -65,6 +68,12 @@ pq_inputs = get_input_pair_index("PQ_INPUTS")
t = get_param_index("T")
AbstractState_set_fractions(handle, [0.4, 0.6])
AbstractState_update(handle,pq_inputs,101325, 0)
mole_frac = [0.0, 0.0]
AbstractState_get_mole_fractions(handle, mole_frac)
gas_frac = [0.0, 0.0]
AbstractState_get_mole_fractions_satState(handle, "gas", gas_frac)
liq_frac = [0.0, 0.0]
AbstractState_get_mole_fractions_satState(handle, "liquid", liq_frac)
if (haskey(ENV, "includelocalwrapper") && ENV["includelocalwrapper"]=="on")
T, p, rhomolar, hmolar, smolar = AbstractState_update_and_common_out(handle, pq_inputs, [101325.0], [0.0], 1)
temp_, p, rhomolar, hmolar, smolar = AbstractState_update_and_common_out(handle, "PQ_INPUTS", [101325.0], [0.0], 1)
Expand All @@ -81,7 +90,7 @@ else
out1=[0.0]; out2=[0.0]; out3=[0.0]; out4=[0.0]; out5=[0.0]; out1_=[0.0]
AbstractState_update_and_5_out(handle, pq_inputs, [101325.0], [0.0],1, [t, t, t, t, t], out1, out2, out3, out4, out5)
AbstractState_update_and_5_out(handle, "PQ_INPUTS", [101325.0], [0.0],1, ["T", "T", "T", "T", "T"], out1_, out2, out3, out4, out5)
end
end
if Sys.isapple()
@test AbstractState_keyed_output(handle,t) 352.3522212978604
@test AbstractState_output(handle,"T") 352.3522212978604
Expand Down

0 comments on commit e7b06dc

Please sign in to comment.