Skip to main content

A Python Package for EIT

Project description

pyeit

Note, the upstream of pyeit goes here: eitcom/pyeit.

pyEIT is a python-based, open-source framework for Electrical Impedance Tomography (EIT). The design priciples of pyEIT are modularity, minimalism, extensibility and OOP.

1. Installation

pyEIT is purely python based, it can be installed and run without any difficulty.

1.1 Install using pip or conda-forge (recommended)

pyEIT is now availbale on pypi and conda-forge. It is purely python, which can be installed via

$ pip install pyeit

or

$ conda install -c conda-forge pyeit

1.2 Install from source code

You can track the git version of pyEIT, and use it locally by setting the PYTHONPATH variable.

export PYTHONPATH=/path/to/pyEIT

If you are using spyder, or pyCharm, you can also set PYTHONPATH per project in the IDE, which is more convenient.

Alternatively, but not recommended, you can compile and install from source code,

$ python setup.py build
$ python setup.py install

2. Run the examples

From the example folder, pick one demo and run!

Note: the following images may be outdated due to that the parameters of a EIT algorithm may be changed in different versions of pyEIT. And it is there in the code, so just run the demo.

2.1 (2D) forward and inverse computing

Using examples/eit_dynamic_bp.py

demo_bp

Using examples/eit_dynamic_greit.py

demo_greit

Using examples/eit_dynamic_jac.py

demo_greit

Using examples/eit_static_jac.py

demo_static

2.2 (3D) forward and inverse computing

Using examples/demo_forward3d.py

Using examples/demo_dynamic_jac3d.py

Limitations:

  1. 3D visualization plotted using vispy can be adjusted using mouse wheels interactively. Seeking a perfect visualization mode, transparency or opaque, is in fact an individual taste. User can also try mayavi and vtk for the visualization purpose using the unified 3D meshing structure.
  2. Solving the inverse problem of 3D EIT, requires the electrodes to be placed at multiple altitude (z-axis) in order to have a (better) z-resolution. This should be done carefully, as adding extra z-belt introduces more stimulation patterns, which in turn adds to the computational loads.

3. Contribute to pyEIT

Give pyEIT a star, fork this project and commit a pull request (PR) !

3.1 Feature lists

  • 2D forward and inverse computing of EIT
  • Reconstruction algorithms : Gauss-Newton solver (JAC), Back-projection (BP), 2D GREIT
  • 2D/3D visualization!
  • Add support for 3D forward and inverse computing
  • 3D mesh generation and visualization
  • Generate 2D/3D meshes from CT/MRI (based on iso2mesh https://github.com/fangq/iso2mesh)
  • Complete electrode model (CEM) support
  • Implementing the dbar algorithm for 2D difference EIT imaging

3.2 Package dependencies

Packages Optional Note
numpy tested with numpy-1.19.1
scipy tested with scipy-1.5.0
matplotlib tested with matplotlib-3.3.2
trimesh for loading external meshes
pandas Optional tested with pandas-1.1.3
vispy Optional failed with vispy in python 3.8
distmesh Optional a build-in module is provided in pyEIT
shapely Optional for thorax mesh implementation

Q1, Why you choose vispy for 3D visualization?

pyEIT uses vispy for visualizing 3D meshes (tetrahedron), and this module is not required if you are using 2D EIT only. vispy has minimal system dependencies and it is purely python. All you need is a decent graphical card with OpenGL support. It supports fast rendering, which I think is more superior to vtk or mayavi and it also has decent support for python 3. Please go to the website vispy.org or github repository vispy.github for more details. Installation of vispy is simple by typing python setup.py install. We are also considering mayavi for a future version of pyEIT.

Q2, When to use Shapely?

pyEIT uses Shapely to build the thorax mesh and reconstruct EIT thoracic images. The thorax mesh shape is considered as a polygon and it is built based on real geometric measures given from a thorax figure simulated by EIDORS EIT MATLAB library. The figure in turns is based on a real thorax CT (Computed Tomography) scan.

To visualize thorax simulations, you should install Shapely. To do so, you should simply type pip install Shapely or conda install shapely. You can visit Shapely official documentation website shapely.readthedocs.io for more details or the dependency description at Shapely.pypi.

4. Cite our work

pyEIT was published at the 17th International Conference on Electrical Impedance Tomography, 2016. It is now officially published at softwareX, vol (7), 2018.

If you find pyEIT useful, please cite our work!

@article{liu2018pyeit,
  title={pyEIT: A python based framework for Electrical Impedance Tomography},
  author={Liu, Benyuan and Yang, Bin and Xu, Canhua and Xia, Junying and Dai, Meng and Ji, Zhenyu and You, Fusheng and Dong, Xiuzhen and Shi, Xuetao and Fu, Feng},
  journal={SoftwareX},
  volume={7},
  pages={304--308},
  year={2018},
  publisher={Elsevier}
}

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

pyeit-1.2.4.tar.gz (77.6 kB view details)

Uploaded Source

File details

Details for the file pyeit-1.2.4.tar.gz.

File metadata

  • Download URL: pyeit-1.2.4.tar.gz
  • Upload date:
  • Size: 77.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for pyeit-1.2.4.tar.gz
Algorithm Hash digest
SHA256 d218160a1b9cc0486431240118b443ae3123789afbfaeb1e52a1aa76c1efbed8
MD5 5c7597ec290f73c658c0b039281844b3
BLAKE2b-256 b8f47b8e4868eab62a9b3c8598edf0fac0df828edf35fcb9e35bad898e68c690

See more details on using hashes here.

Supported by

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