Note: A new Rust version offers a major upgrade with ~2× speedup, 36 properties (vs 30), and multi-ecosystem package support. See RustSEUIF97.
This is the C implementation of the high-speed IAPWS-IF97 package SEUIF97. It is suitable for computation-intensive calculations, such as the simulation of non-stationary processes, on-line process monitoring and optimizations.
Through the high-speed library, IAPWS-IF97 results are generated with high accuracy and at speeds significantly faster than the repeated squaring method or the standard C library's math.pow()
- Shortest Addition Chain Algorithm: Used for the rapid computation of integer powers via optimal multiplication sequences.
- Power Caching Strategy: Precomputes only distinct powers to avoid redundant calculations, directly retrieving them to speed up polynomial evaluation.
- Shared-Power Scaling: By leveraging the mathematical relationship between polynomials and their derivatives, we compute shared power terms only once. Subsequent results are derived through exponent scaling, thereby eliminating redundant calculations and significantly improving computational efficiency.
Please refer to The acceleration methods for more details on the algorithm.
SEUIF97 achieves 1.9 - 3.2x speedups over CoolProp IF97 in Region 1, 2, and 3. See Performance Comparison: SEUIF97 vs CoolProp IF97 for detailed benchmark results.
You can build the library using either make or cmake:
Pre-compiled dynamic link libraries for Windows, Linux and macOS are available in GitHub Releases.
Legacy pre-compiled libraries libseuif97.dll built with MinGW-GCC/GCC are also provided in the ./shared_lib/ directory.
The SEUIF97 library provides comprehensive functions for calculating water and steam properties, as well as the thermodynamic processes of steam turbines.
Water and Steam Properties
SEUIF97 supports 12 distinct input state pairs for calculating 36 thermodynamic, transport, and derived properties (see Properties).
Note: Only linearly related thermodynamic properties are calculable in the wet steam region.
Input Pairs:
$(p,t), (p,h), (p,s), (p,v)$ $(t,h),(t,s), (t,v)$ $(p,x), (t,x),(h,x),(s,x)$ $(h,s)$
??(in1,in2,o_id)- the first, second input parameters: the input property pairs
- the third input parameters: the ID of the calculated property - o_id
- the return: the calculated property value of
o_id
Thermodynamic Process of Steam Turbine
-
Isentropic Enthalpy Drop:ishd(pi,ti,pe)
pi - inlet pressure(MPa); ti -inlet temperature(°C) pe - outlet pressure(MPa)
-
Isentropic Efficiency(0~100): ief(pi,ti,pe,te) (superheated steam zone)
pi - inlet pressure(MPa); ti - inlet temperature(°C) pe - outlet pressure(MPa); te - outlet temperature(°C)
The Function Prototype in C
// Functions of Properties
double pt(double p, double t, int o_id);
double ph(double p, double h, int o_id);
double ps(double p, double s, int o_id);
double pv(double p, double v, int o_id);
double th(double t, double h, int o_id);
double ts(double t, double s, int o_id);
double tv(double t, double v, int o_id);
double hs(double h, double s, int o_id);
double px(double p, double x, int o_id);
double tx(double t, double x, int o_id);
double hx(double h, double x, int o_id);
double sx(double s, double x, int o_id);
//The Functions for Thermodynamic Process of Steam Turbine
double ishd(double pi, double ti, double pe);
double ief(double pi, double ti, double pe, double te);To use the shared library in your preferred programming language, follow these steps:
-
Put the shared library in the default path of OS or the programming language
-
Windows(x86/64)
- copy
libseuif97.dllin the Windows/x86 or Windows/x64 folder to a default path of Windows32/64's DLL,for example:C:\Windows\System
- copy
-
Linux(x64)
- copy
libseuif97.soin the Linux/x64 folder to a default path of Linux shared lib:/usr/lib
- copy
-
-
Add the specific API file for your programming language to its corresponding
APIpath.- Note: API paths vary by language. Please refer to the specific Examples provided for your programming language to locate the correct path and setup instructions.
Interfaces and examples are provided in the /demo/ directory, supporting a wide range of languages and environments
- C/C++, Python, C#, Java, Excel VBA, MATLAB, Rust, Fortran, Pascal, Golang, Modelica
You can modify the provided interfaces to match your own API needs.
The Selected Examples
Python
C++
| Property | Unit | Symbol | o_id |
|---|---|---|---|
| Pressure | MPa | p | 0 |
| Temperature | °C | t | 1 |
| Density | kg/m^3 | ρ | 2 |
| Specific Volume | m^3/kg | v | 3 |
| Specific enthalpy | kJ/kg | h | 4 |
| Specific entropy | kJ/(kg·K) | s | 5 |
| Specific exergy | kJ/kg | e | 6 |
| Specific internal energy | kJ/kg | u | 7 |
| Specific isobaric heat capacity | kJ/(kg·K) | cp | 8 |
| Specific isochoric heat capacity | kJ/(kg·K) | cv | 9 |
| Speed of sound | m/s | w | 10 |
| Isentropic exponent | k | 11 | |
| Specific Helmholtz free energy | kJ/kg | f | 12 |
| Specific Gibbs free energy | kJ/kg | g | 13 |
| Compressibility factor | z | 14 | |
| Steam quality | x | 15 | |
| Region | r | 16 | |
| Isobaric cubic expansion coefficient | 1/K | αv | 17 |
| Isothermal compressibility | 1/MPa | kT | 18 |
| Partial derivative (∂V/∂T)p | m^3/(kg·K) | (∂V/∂T)p | 19 |
| Partial derivative (∂V/∂P)T | m^3/(kg·MPa) | (∂V/∂P)T | 20 |
| Partial derivative (∂p/∂t)v | MPa/K | (∂p/∂t)v | 21 |
| Isothermal throttling coefficient | kJ/(kg·MPa) | δt | 22 |
| Joule-Thomson coefficient | K/MPa | μ | 23 |
| Dynamic viscosity | kg/(m·s) | η | 24 |
| Kinematic viscosity | m²/s | ν | 25 |
| Thermal conductivity | W/(m·K) | λ | 26 |
| Thermal diffusivity | µm²/s | a | 27 |
| Prandtl number | Pr | 28 | |
| Surface tension | N/m | σ | 29 |