Skip to content

Create a shared library from the Fortran sources provided by Refprop from NIST. This project provides an alternative to the refprop.dll that comes with the software.

Notifications You must be signed in to change notification settings

tonkiplis/librefprop.so

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

99 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#Welcome to librefprop.so! These files allow you to compile the REFPROP fluid property database as a shared library for Linux and MacOS systems. This enables you to use the Fortran sources developed by NIST providing an alternative to the REFPROP.dll for Windows.

Installation Instructions

For installation on a Linux or OSX machine, please follow the steps described below. By default, the library and the header file are placed in system directories. Please change the paths if you do not have write access to this part of your file system.

  1. Make sure that you have gcc and gfortran, for OSX use either HPC or Homebrew and install the OSX command line tools. On a Linux machine, something like apt-get install gcc might do the job.
  2. Get a copy of this repository, either by downloading the latest release or the current development version as zip file or simply clone the repository with git.
  3. Change the paths in the Makefile, if needed.
  4. Copy the REFPROP Fortran code to the fortran directory.
  5. Put the fluids and mixtures folders from REFPROP into the files folder.
  6. Call make to prepare the files.
  7. Use make install (as root user) to copy the files to the destination directories.

You can remove the files again by calling make uninstall (as root user).

Testing the Installation

There is a simple Fortran file to test the library. You can call make fortest and run the executable with ./bin/ex_mix_for to display some R410 two-phase properties:

Temperature Pressure Density, liquid Density, vapour
300.0000 1740.5894 14.4550 0.9628
300.0000 1735.1589 14.2345 0.9603

Python Integration

There is a basic python package based on the examples from NIST in the pyrp folder.

Please note that there is a much more mature Python interface available at https://github.com/BenThelen/python-refprop. Thank you Ben for sharing it!

Matlab Integration

There is a Matlab prototype file available from NIST. Unfortunately, you have to change a few things in order to use the library on MacOS and GNU/Linux.

There is a makefile section and a shell script that help you with this. After installing the library as described above, you can run make matlab in order to use REFPROP with Matlab. Then run `make matlab-install’ as root user for a system-wide installation.

The test.m is a simple code you can use to check if the intergration works.

Summary for the impatient:

  • Go to the directory with the downloaded files and open a command prompt.
  • Run make and then sudo make install to install the shared library.
  • Run make matlab to download files and edit them as written in the terminal.
  • Run sudo make matlab-install to copy the matlab file to /opt/refprop.

MATLAB 64 bit Integration

This part was contributed partly by nkampy and speredenn and is still experimental. Please open new issues if you encounter any problems. Problems are likely to be encountered in setting up matlab with gcc, needed to use the builtin MEX functionality, which is required for the load library command in the thunk.m file. We hope that the user community and nkampy's comments, left at the mathworks website (here and here), will help figuring out a good solution.

No root user access

It is possible to use the shared libraries without root access. However, you need to make sure that the libraries get found and it is recommended to add something like export LD_LIBRARY_PATH=/home/USERNAME/lib:/home/USERNAME/refprop:$LD_LIBRARY_PATH to the calls to executables that need REFPROP. The makefile will print more instructions when running make install as a non-root user.

Known Problems

  • Older compilers might not work properly with the OpenMP directives used in the original Fortran code. If you experience any problems related to OpenMP, try removing OpenMP support by setting USEOPENMP :=FALSE in line 51 of the Makefile.

General Remarks

Please note that you need a working and licensed copy of REFPROP in order to use the software provided here. This is not a replacement for REFPROP. You can purchase REFPROP at http://www.nist.gov/srd/nist23.cfm

If you are interested in fluid property modelling, you might also be interested in CoolProp, an open-source thermodynamic fluid property package with over 100 compressible and over 50 incompressible fluids.

About

Create a shared library from the Fortran sources provided by Refprop from NIST. This project provides an alternative to the refprop.dll that comes with the software.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 41.2%
  • C 24.7%
  • C++ 22.7%
  • Prolog 5.4%
  • Shell 4.1%
  • Smarty 1.1%
  • Other 0.8%