Skip to content

Latest commit

 

History

History
70 lines (52 loc) · 3.16 KB

README.md

File metadata and controls

70 lines (52 loc) · 3.16 KB

Nonlinear dynamics of coupled phase oscillators

Lattice.png

carpet is a python package to study systems of coupled phase oscillators, such as

  • Kuramoto model with local coupling on a two-dimensional lattice
  • cilia carpet model (see references [1, 2]; this example from biological physics gave this repository its name)

Using the package, you can define oscillator coupling and solve the corresponding equation of motion for the oscillator network (see examples).

Features:

  • Supports both regular lattices and general networks.
  • Supports custom coupling functions.
  • Includes code for parallel computation (various.parallel_with_threads, various.logging).
  • Includes scripts for analyzing simulation results:
    • visualization of oscillator phases
    • find fixed points, linear stability analysis, basins of attractions, etc.

How to use

See examples folder. General idea:

  1. Import lattice type & physics/coupling
import carpet.lattice.<LATTICE_TYPE> as lattice
import physics/coupling as `import carpet.coupling.<COUPLING_TYPE> as coupling
  1. Define specific geometry and physics, define the right_side_of_ODE.
  2. Then use define_solve_cycle to integrate the differential equation.

Installation

Run in terminal python setup.py develop.

  • After that package is ready to be imported.
  • Any changes to the code will be applied immediately.
  • Package numba is optional, but highly recommended as it speeds up some computations (e.g., carpet.physics.friction_pairwise, carpet.physics.kuramoto_numpy).

Structure

  • carpet - import it to get access to several modules, e.g.
    • dynamics
      • Functions to solve ODE
    • various:
      • logging for simulations
      • math functions
  • Geometry-specific files (topology: chain, lattice, network?) are contained in packages inside lattice folder. Files contain functions to build a list of positions and connetions depending on the geometry of choice.
  • Physics-specific files (how are oscillators coupled?): in physics folder.
    • Recommended use import carpet.physics.kuramoto as physics

Other modules should be imported separately, e.g., import carpet.visualize as vis.

  • visualize - functions for visualization

  • parallel_with_threads.py - code to run a function in parallel on a list of inputs.

  • classes.py - implementation of oscillator classes; assume symmetry classes and reduce dimensionality of the ODE system.

  • Many reusable functions reside outside the main package - these are located in folder scripts

Authors

You found this package useful, please cite [2].