Skip to main content

Elastica is a software to simulate the dynamics of filaments that, at every cross-section, can undergo all six possible modes of deformation, allowing the filament to bend, twist, stretch and shear, while interacting with complex environments via muscular activity, surface contact, friction and hydrodynamics.

Project description

PyElastica

Build_status CI Documentation Status codecov Downloads DOI Binder Gitter

PyElastica is the python implementation of Elastica: an open-source project for simulating assemblies of slender, one-dimensional structures using Cosserat Rod theory.

gallery

Visit www.cosseratrods.org for more information and learn about Elastica and Cosserat rod theory.

How to Start

PyPI version Documentation Status

PyElastica is compatible with Python 3.8 - 3.11.

$ pip install pyelastica

With this you get a minimal version with very little dependencies.

All options:

  • examples: installs dependencies to run example cases, found under the folder examples.
  • docs: packages to build documentation

Options can be combined e.g.

$ pip install "pyelastica[examples,docs]"

For plotting videos, ffmpeg has to be installed:

$ conda install -c conda-forge ffmpeg

Documentation of PyElastica is available here.

If you want to simulate magnetic Cosserat rods interacting with external magnetic environments you can install the derived package using

$ pip install magneto_pyelastica

Details can be found here.

Citation

We ask that any publications which use Elastica cite as following:

@software{arman_tekinalp_2024_10883271,
  author       = {Arman Tekinalp and
                  Seung Hyun Kim and
                  Yashraj Bhosale and
                  Tejaswin Parthasarathy and
                  Noel Naughton and
                  Ali Albazroun and
                  Rahul Joon and
                  Songyuan Cui and
                  Ilia Nasiriziba and
                  Maximilian Stölzle and
                  Chia-Hsien (Cathy) Shih and
                  Mattia Gazzola},
  title        = {GazzolaLab/PyElastica: v0.3.2},
  month        = mar,
  year         = 2024,
  publisher    = {Zenodo},
  version      = {v0.3.2},
  doi          = {10.5281/zenodo.10883271},
  url          = {https://doi.org/10.5281/zenodo.10883271}
}

References

  • Gazzola, Dudte, McCormick, Mahadevan, Forward and inverse problems in the mechanics of soft filaments, Royal Society Open Science, 2018. doi: 10.1098/rsos.171628
  • Zhang, Chan, Parthasarathy, Gazzola, Modeling and simulation of complex dynamic musculoskeletal architectures, Nature Communications, 2019. doi: 10.1038/s41467-019-12759-5

List of publications and submissions

Tutorials

Binder

We have created several Jupyter notebooks and Python scripts to help users get started with PyElastica. The Jupyter notebooks are available on Binder, allowing you to try out some of the tutorials without having to install PyElastica.

We have also included an example script for visualizing PyElastica simulations using POVray. This script is located in the examples folder (examples/Visualization).

Contribution

If you would like to participate, please read our contribution guideline

PyElastica is developed by the Gazzola Lab at the University of Illinois Urbana-Champaign.

Senior Developers ✨

Names arranged alphabetically

  • Ali Albazroun
  • Arman Tekinalp
  • Chia-Hsien Shih (Cathy)
  • Fan Kiat Chan
  • Ilia Nasiriziba
  • Noel Naughton
  • Seung Hyun Kim
  • Songyuan Cui
  • Tejaswin Parthasarathy (Teja)
  • Yashraj Bhosale

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

pyelastica-0.3.2.tar.gz (119.2 kB view details)

Uploaded Source

Built Distribution

pyelastica-0.3.2-py3-none-any.whl (143.1 kB view details)

Uploaded Python 3

File details

Details for the file pyelastica-0.3.2.tar.gz.

File metadata

  • Download URL: pyelastica-0.3.2.tar.gz
  • Upload date:
  • Size: 119.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.0

File hashes

Hashes for pyelastica-0.3.2.tar.gz
Algorithm Hash digest
SHA256 b9b4c17884474c92ff6b541cd0771278399b6140651823e720ea22252ba89960
MD5 1514d9003c8159aae04d1ea51fc6599d
BLAKE2b-256 eabf39c05c56ebccbd0a448b1b873b551ba9227d8563390655336a9ba6d2abb4

See more details on using hashes here.

File details

Details for the file pyelastica-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: pyelastica-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 143.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.0

File hashes

Hashes for pyelastica-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 35e753f6fa2c346b00149ed7108e796028a726a53edad6d83e73fda681adb646
MD5 72e6b62d64a2780fc29872bddc3e13d7
BLAKE2b-256 931f8f9836511b445f05bbb85877894968b0a0bbf6d2699a7521c1e2aa4dfef0

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