Skip to main content

PyMemSim is a Python package for modelling of membrane-based separation systems.

Project description

🧪 PyMemSim

PyMemSim

PyPI Downloads PyPI Python Version License

PyMemSim is a Python package for membrane-process simulation, with a current focus on hollow-fiber membrane (HFM) models.

⚙️ Package Functionalities

Current capabilities include:

  • Hollow-fiber membrane simulation through the HFM interface and create_hfm_module(...) factory.
  • Gas-phase and liquid-phase HFM modeling.
  • physical and scale modeling modes.
  • Isothermal and non-isothermal simulation setup.
  • Dual-side inlet specification (feed/permeate flows, temperatures, pressures).
  • Constant-pressure operation for feed and permeate sides.
  • Component-wise transport coefficients for gas and liquid systems.
  • Solver-based simulation (scipy.integrate.solve_ivp for IVP and scipy.integrate.solve_bvp via solver_bvp for BVP) with configurable solver options.

📦 Installation

Install from PyPI:

pip install PyMemSim

Quick version check:

import pymemsim as pms
print(pms.__version__)

🚀 Usage Examples

For a complete end-to-end setup (thermo source, options, model inputs, module creation, and simulation), see:

  • examples/hfm/gas-hfm-exp-1.py
  • examples/hfm/gas-hfm-exp-2.py

You can also review:

  • examples/hfm/liquid-hfm-exp-1.py

🔄 Co-current vs Counter-current (Gas HFM)

The gas HFM examples show how to switch the membrane flow arrangement through:

  • HollowFiberMembraneOptions(..., flow_pattern="co-current")
  • HollowFiberMembraneOptions(..., flow_pattern="counter-current")

Reference examples:

  • examples/hfm/gas-hfm-exp-1.py: co-current case (flow_pattern_to_run = "co-current"), solved with IVP-style solver options (Radau, rtol, atol).
  • examples/hfm/gas-hfm-exp-2.py: counter-current case (flow_pattern_to_run = "counter-current"), solved with solver_bvp and BVP-style options (mesh_points, tol, bc_tol, max_nodes).

You can run either arrangement in both files by changing flow_pattern_to_run to "co-current" or "counter-current".

🛠️ Development Status

PyMemSim is under active development. APIs, model options, and behaviors may change in future releases.

📄 License

This project is licensed under the Apache-2.0 License. You are free to use, modify, and distribute this software in your own applications or projects. However, if you choose to use this app in another app or software, please ensure that my name, Sina Gilassi, remains credited as the original author. This includes retaining any references to the original repository or documentation where applicable. By doing so, you help acknowledge the effort and time invested in creating this project.

❓ FAQ

For any question, contact me on LinkedIn

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pymemsim-0.3.1.tar.gz (74.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pymemsim-0.3.1-py3-none-any.whl (83.5 kB view details)

Uploaded Python 3

File details

Details for the file pymemsim-0.3.1.tar.gz.

File metadata

  • Download URL: pymemsim-0.3.1.tar.gz
  • Upload date:
  • Size: 74.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.8

File hashes

Hashes for pymemsim-0.3.1.tar.gz
Algorithm Hash digest
SHA256 685d0ba7646741cfb63aca6a2893d5e8e06366ba8216f2f55de1ec78da92c75f
MD5 473ba0676fa7f9edcdf4fd8b1a3d55a8
BLAKE2b-256 e6d49fd17bc877d0ae47a74ecafff0d342af663c3c293762b9a7538e9d14097d

See more details on using hashes here.

File details

Details for the file pymemsim-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: pymemsim-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 83.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.8

File hashes

Hashes for pymemsim-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bd246f961625091da34efe57649bc3412b34fb72eda65a8e2bd3241f99c7dfd7
MD5 f6b53813499d56ebd601694775dd2fee
BLAKE2b-256 5f88e58128f2fd49f7b012d4e19156f14704f590a0853087e2d860a6ccc4120a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page