From f320541433a2f19ea91bf9459f4e94aaa61f32dc Mon Sep 17 00:00:00 2001
From: Arman Tekinalp <53585636+armantekinalp@users.noreply.github.com>
Date: Mon, 20 Feb 2023 14:16:04 -0600
Subject: [PATCH 1/8] Update: README.md include cite information via Zenodo
---
README.md | 27 ++++++++++++++++++++-------
1 file changed, 20 insertions(+), 7 deletions(-)
diff --git a/README.md b/README.md
index 90f2ab82..56c09c12 100644
--- a/README.md
+++ b/README.md
@@ -1,7 +1,7 @@
PyElastica
-[![Build_status][badge-travis]][link-travis] [![CI][badge-CI]][link-CI] [![Documentation Status][badge-docs-status]][link-docs-status] [![codecov][badge-codecov]][link-codecov] [![Downloads][badge-pepy-download-count]][link-pepy-download-count] [![Binder][badge-binder]][link-binder] [![Gitter][badge-gitter]][link-gitter]
+[![Build_status][badge-travis]][link-travis] [![CI][badge-CI]][link-CI] [![Documentation Status][badge-docs-status]][link-docs-status] [![codecov][badge-codecov]][link-codecov] [![Downloads][badge-pepy-download-count]][link-pepy-download-count] [![DOI][badge-doi]][link-doi] [![Binder][badge-binder]][link-binder] [![Gitter][badge-gitter]][link-gitter]
PyElastica is the python implementation of **Elastica**: an *open-source* project for simulating assemblies of slender, one-dimensional structures using Cosserat Rod theory.
@@ -26,12 +26,23 @@ Documentation of PyElastica is available [here][link-docs-website].
We ask that any publications which use Elastica cite as following:
```
-@misc{tekinalp2022pyelastica,
- title={PyElastica: A computational framework for Cosserat rod assemblies},
- author={Tekinalp, Arman and Kim, Seung Hyun and Parthasarathy, Tejaswin and Bhosale, Yashraj},
- journal={https://github.com/GazzolaLab/PyElastica},
- year={2022},
- publisher={GitHub}
+@software{arman_tekinalp_2023_7658872,
+ author = {Arman Tekinalp and
+ Seung Hyun Kim and
+ Yashraj Bhosale and
+ Tejaswin Parthasarathy and
+ Noel Naughton and
+ Maximilian Stölzle and
+ Zhi Dou and
+ Chia-Hsien (Cathy) Shih and
+ Mattia Gazzola},
+ title = {PyElastica},
+ month = feb,
+ year = 2023,
+ publisher = {Zenodo},
+ version = {v0.3.0.post1},
+ doi = {10.5281/zenodo.7658872},
+ url = {https://doi.org/10.5281/zenodo.7658872}
}
```
@@ -91,6 +102,7 @@ _Names arranged alphabetically_
[badge-pepy-download-count]: https://pepy.tech/badge/pyelastica
[badge-codecov]: https://codecov.io/gh/GazzolaLab/PyElastica/branch/master/graph/badge.svg
[badge-gitter]: https://badges.gitter.im/PyElastica/community.svg
+[badge-doi]: https://zenodo.org/badge/254172891.svg
[link-pypi]: https://badge.fury.io/py/pyelastica
[link-travis]: https://travis-ci.com/github/GazzolaLab/PyElastica
[link-CI]: https://github.com/GazzolaLab/PyElastica/actions
@@ -101,3 +113,4 @@ _Names arranged alphabetically_
[badge-binder-tutorial]: https://img.shields.io/badge/Launch-PyElastica%20Tutorials-579ACA.svg?logo=
[link-binder]: https://mybinder.org/v2/gh/GazzolaLab/PyElastica/master?filepath=examples%2FBinder%2F0_PyElastica_Tutorials_Overview.ipynb
[link-gitter]: https://gitter.im/PyElastica/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
+[link-doi]: https://zenodo.org/badge/latestdoi/254172891
From 7b3fe2d0204a175c9e5e64265c70b9577b4ca8c9 Mon Sep 17 00:00:00 2001
From: Arman Tekinalp <53585636+armantekinalp@users.noreply.github.com>
Date: Wed, 22 Feb 2023 17:11:53 -0600
Subject: [PATCH 2/8] Update Readme citation title
---
README.md | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/README.md b/README.md
index 56c09c12..5e52b6ad 100644
--- a/README.md
+++ b/README.md
@@ -36,7 +36,9 @@ We ask that any publications which use Elastica cite as following:
Zhi Dou and
Chia-Hsien (Cathy) Shih and
Mattia Gazzola},
- title = {PyElastica},
+ title = {{PyElastica: Open-source software for the
+ simulation of assemblies of slender, one-
+ dimensional structures using Cosserat Rod theory}},
month = feb,
year = 2023,
publisher = {Zenodo},
From 2b7f59628fce36ac44acdd20a463708dd253f744 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Mon, 27 Mar 2023 23:13:17 +0530
Subject: [PATCH 3/8] Wildcard imports removed
---
.../AxialStretchingCase/axial_stretching.py | 22 +++++-----
.../general_constraint_allow_yaw.py | 28 ++++++++-----
examples/ButterflyCase/butterfly.py | 16 ++++----
.../continuum_flagella.py | 24 ++++++-----
.../ContinuumSnakeCase/continuum_snake.py | 26 ++++++------
.../generic_system_type_fixed_joint.py | 39 ++++++++++--------
.../generic_system_type_spherical_joint.py | 39 ++++++++++--------
.../parallel_connection_example.py | 35 +++++++++-------
.../flexible_swinging_pendulum.py | 21 +++++-----
.../FrictionValidationCases/axial_friction.py | 18 ++++----
.../rolling_friction_initial_velocity.py | 18 ++++----
.../rolling_friction_on_inclined_plane.py | 16 ++++----
.../rolling_friction_torque.py | 20 +++++----
.../convergence_helicalbuckling.py | 16 ++++----
.../HelicalBucklingCase/helicalbuckling.py | 16 ++++----
examples/JointCases/fixed_joint.py | 35 +++++++++-------
examples/JointCases/fixed_joint_torsion.py | 35 +++++++++-------
examples/JointCases/hinge_joint.py | 35 +++++++++-------
examples/JointCases/spherical_joint.py | 35 +++++++++-------
.../MuscularFlagella/muscular_flagella.py | 29 +++++++------
examples/MuscularSnake/muscular_snake.py | 37 +++++++++--------
examples/RestartExample/restart_example.py | 20 ++++-----
.../rod_cylinder_contact.py | 33 ++++++++-------
.../rod_cylinder_contact_friction.py | 41 +++++++++++--------
.../rod_cylinder_contact_validation.py | 29 +++++++------
.../rod_cylinder_contact_with_y_normal.py | 29 +++++++------
.../rigid_cylinder_rotational_motion_case.py | 20 +++++----
...igid_cylinder_translational_motion_case.py | 20 +++++----
.../rigid_sphere_rotational_motion_case.py | 20 +++++----
.../rigid_sphere_translational_motion_case.py | 20 +++++----
.../rod_rod_contact_inclined_validation.py | 31 ++++++++------
.../rod_rod_contact_parallel_validation.py | 31 ++++++++------
.../PlectonemesCase/plectoneme_case.py | 38 ++++++++---------
.../SolenoidsCase/solenoid_case.py | 35 +++++++++-------
.../convergence_timoshenko.py | 28 +++++++------
examples/TimoshenkoBeamCase/timoshenko.py | 30 +++++++-------
36 files changed, 548 insertions(+), 437 deletions(-)
diff --git a/examples/AxialStretchingCase/axial_stretching.py b/examples/AxialStretchingCase/axial_stretching.py
index 53e1478e..e9383202 100644
--- a/examples/AxialStretchingCase/axial_stretching.py
+++ b/examples/AxialStretchingCase/axial_stretching.py
@@ -26,11 +26,11 @@
import numpy as np
from matplotlib import pyplot as plt
-from elastica import *
+import elastica as ea
class StretchingBeamSimulator(
- BaseSystemCollection, Constraints, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping, ea.CallBacks
):
pass
@@ -57,7 +57,7 @@ class StretchingBeamSimulator(
poisson_ratio = 0.5
shear_modulus = youngs_modulus / (poisson_ratio + 1.0)
-stretchable_rod = CosseratRod.straight_rod(
+stretchable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -72,13 +72,13 @@ class StretchingBeamSimulator(
stretch_sim.append(stretchable_rod)
stretch_sim.constrain(stretchable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
end_force_x = 1.0
end_force = np.array([end_force_x, 0.0, 0.0])
stretch_sim.add_forcing_to(stretchable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=1e-2
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=1e-2
)
# add damping
@@ -89,19 +89,19 @@ class StretchingBeamSimulator(
dt = 0.1 * dl
damping_constant = 0.1
stretch_sim.dampen(stretchable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
# Add call backs
-class AxialStretchingCallBack(CallBackBaseClass):
+class AxialStretchingCallBack(ea.CallBackBaseClass):
"""
Tracks the velocity norms of the rod
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -120,18 +120,18 @@ def make_callback(self, system, time, current_step: int):
return
-recorded_history = defaultdict(list)
+recorded_history = ea.defaultdict(list)
stretch_sim.collect_diagnostics(stretchable_rod).using(
AxialStretchingCallBack, step_skip=200, callback_params=recorded_history
)
stretch_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, stretch_sim, final_time, total_steps)
+ea.integrate(timestepper, stretch_sim, final_time, total_steps)
if PLOT_FIGURE:
# First-order theory with base-length
diff --git a/examples/BoundaryConditionsCases/general_constraint_allow_yaw.py b/examples/BoundaryConditionsCases/general_constraint_allow_yaw.py
index 35356588..94cd0bcb 100644
--- a/examples/BoundaryConditionsCases/general_constraint_allow_yaw.py
+++ b/examples/BoundaryConditionsCases/general_constraint_allow_yaw.py
@@ -1,7 +1,8 @@
__doc__ = """Fixed joint example, for detailed explanation refer to Zhang et. al. Nature Comm. methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
+
from examples.BoundaryConditionsCases.bc_cases_postprocessing import (
plot_position,
plot_orientation,
@@ -12,7 +13,12 @@
class GeneralConstraintSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -43,7 +49,7 @@ class GeneralConstraintSimulator(
start_rod_2 = start_rod_1 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -59,7 +65,7 @@ class GeneralConstraintSimulator(
# Apply boundary conditions to rod1: only allow yaw
general_constraint_sim.constrain(rod1).using(
- GeneralConstraint,
+ ea.GeneralConstraint,
constrained_position_idx=(0,),
constrained_director_idx=(0,),
translational_constraint_selector=np.array([True, True, True]),
@@ -68,37 +74,37 @@ class GeneralConstraintSimulator(
# add forces to endpoint
general_constraint_sim.add_forcing_to(rod1).using(
- EndpointForces,
+ ea.EndpointForces,
start_force=np.zeros((3,)),
end_force=1e-0 * np.ones((3,)),
ramp_up_time=0.5,
)
# add uniform torsion torque
general_constraint_sim.add_forcing_to(rod1).using(
- UniformTorques, torque=1e-3, direction=np.array([0, 0, 1])
+ ea.UniformTorques, torque=1e-3, direction=np.array([0, 0, 1])
)
# add damping
damping_constant = 0.4
general_constraint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
general_constraint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=diagnostic_step_skip, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=diagnostic_step_skip, callback_params=pp_list_rod1
)
general_constraint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
print("Total steps", total_steps)
-integrate(timestepper, general_constraint_sim, final_time, total_steps)
+ea.integrate(timestepper, general_constraint_sim, final_time, total_steps)
plot_orientation(
diff --git a/examples/ButterflyCase/butterfly.py b/examples/ButterflyCase/butterfly.py
index 8233c24d..9e28601d 100644
--- a/examples/ButterflyCase/butterfly.py
+++ b/examples/ButterflyCase/butterfly.py
@@ -3,11 +3,11 @@
from matplotlib.colors import to_rgb
-from elastica import *
+import elastica as ea
from elastica.utils import MaxDimension
-class ButterflySimulator(BaseSystemCollection, CallBacks):
+class ButterflySimulator(ea.BaseSystemCollection, ea.CallBacks):
pass
@@ -60,7 +60,7 @@ class ButterflySimulator(BaseSystemCollection, CallBacks):
- np.sin(angle_of_inclination) * vertical_direction
)
-butterfly_rod = CosseratRod.straight_rod(
+butterfly_rod = ea.CosseratRod.straight_rod(
n_elem,
start=origin.reshape(3),
direction=np.array([0.0, 0.0, 1.0]),
@@ -77,13 +77,13 @@ class ButterflySimulator(BaseSystemCollection, CallBacks):
butterfly_sim.append(butterfly_rod)
# Add call backs
-class VelocityCallBack(CallBackBaseClass):
+class VelocityCallBack(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -102,7 +102,7 @@ def make_callback(self, system, time, current_step: int):
return
-recorded_history = defaultdict(list)
+recorded_history = ea.defaultdict(list)
# initially record history
recorded_history["time"].append(0.0)
recorded_history["position"].append(butterfly_rod.position_collection.copy())
@@ -117,13 +117,13 @@ def make_callback(self, system, time, current_step: int):
butterfly_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
dt = 0.01 * dl
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, butterfly_sim, final_time, total_steps)
+ea.integrate(timestepper, butterfly_sim, final_time, total_steps)
if PLOT_FIGURE:
# Plot the histories
diff --git a/examples/ContinuumFlagellaCase/continuum_flagella.py b/examples/ContinuumFlagellaCase/continuum_flagella.py
index 1c8d8027..6038ee5f 100644
--- a/examples/ContinuumFlagellaCase/continuum_flagella.py
+++ b/examples/ContinuumFlagellaCase/continuum_flagella.py
@@ -3,7 +3,7 @@
import numpy as np
import os
-from elastica import *
+import elastica as ea
from examples.ContinuumFlagellaCase.continuum_flagella_postprocessing import (
plot_velocity,
plot_video,
@@ -11,7 +11,9 @@
)
-class FlagellaSimulator(BaseSystemCollection, Constraints, Forcing, Damping, CallBacks):
+class FlagellaSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping, ea.CallBacks
+):
pass
@@ -33,7 +35,7 @@ def run_flagella(
poisson_ratio = 0.5
shear_modulus = E / (poisson_ratio + 1.0)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -53,7 +55,7 @@ def run_flagella(
# Head and tail control points are zero.
control_points = np.hstack((0, b_coeff[:-1], 0))
flagella_sim.add_forcing_to(shearable_rod).using(
- MuscleTorques,
+ ea.MuscleTorques,
base_length=base_length,
b_coeff=control_points,
period=period,
@@ -72,7 +74,7 @@ def run_flagella(
fluid_density * base_length * base_length / (period * reynolds_number)
)
flagella_sim.add_forcing_to(shearable_rod).using(
- SlenderBodyTheory, dynamic_viscosity=dynamic_viscosity
+ ea.SlenderBodyTheory, dynamic_viscosity=dynamic_viscosity
)
# add damping
@@ -82,19 +84,19 @@ def run_flagella(
damping_constant = 0.625
dt = 1e-4 * period
flagella_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
# Add call backs
- class ContinuumFlagellaCallBack(CallBackBaseClass):
+ class ContinuumFlagellaCallBack(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -119,19 +121,19 @@ def make_callback(self, system, time, current_step: int):
return
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
flagella_sim.collect_diagnostics(shearable_rod).using(
ContinuumFlagellaCallBack, step_skip=200, callback_params=pp_list
)
flagella_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
final_time = (10.0 + 0.01) * period
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, flagella_sim, final_time, total_steps)
+ ea.integrate(timestepper, flagella_sim, final_time, total_steps)
if PLOT_FIGURE:
filename_plot = "continuum_flagella_velocity.png"
diff --git a/examples/ContinuumSnakeCase/continuum_snake.py b/examples/ContinuumSnakeCase/continuum_snake.py
index 9f19f595..2c03118a 100644
--- a/examples/ContinuumSnakeCase/continuum_snake.py
+++ b/examples/ContinuumSnakeCase/continuum_snake.py
@@ -2,7 +2,7 @@
import os
import numpy as np
-from elastica import *
+import elastica as ea
from examples.ContinuumSnakeCase.continuum_snake_postprocessing import (
plot_snake_velocity,
@@ -12,7 +12,9 @@
)
-class SnakeSimulator(BaseSystemCollection, Constraints, Forcing, Damping, CallBacks):
+class SnakeSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping, ea.CallBacks
+):
pass
@@ -38,7 +40,7 @@ def run_snake(
poisson_ratio = 0.5
shear_modulus = E / (poisson_ratio + 1.0)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -56,13 +58,13 @@ def run_snake(
# Add gravitational forces
gravitational_acc = -9.80665
snake_sim.add_forcing_to(shearable_rod).using(
- GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
+ ea.GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
)
# Add muscle torques
wave_length = b_coeff[-1]
snake_sim.add_forcing_to(shearable_rod).using(
- MuscleTorques,
+ ea.MuscleTorques,
base_length=base_length,
b_coeff=b_coeff[:-1],
period=period,
@@ -85,7 +87,7 @@ def run_snake(
) # [forward, backward, sideways]
static_mu_array = np.zeros(kinetic_mu_array.shape)
snake_sim.add_forcing_to(shearable_rod).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=1.0,
nu=1e-6,
plane_origin=origin_plane,
@@ -102,7 +104,7 @@ def run_snake(
damping_constant = 2e-3
time_step = 1e-4
snake_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=time_step,
)
@@ -112,13 +114,13 @@ def run_snake(
step_skip = int(1.0 / (rendering_fps * time_step))
# Add call backs
- class ContinuumSnakeCallBack(CallBackBaseClass):
+ class ContinuumSnakeCallBack(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -145,15 +147,15 @@ def make_callback(self, system, time, current_step: int):
return
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
snake_sim.collect_diagnostics(shearable_rod).using(
ContinuumSnakeCallBack, step_skip=step_skip, callback_params=pp_list
)
snake_sim.finalize()
- timestepper = PositionVerlet()
- integrate(timestepper, snake_sim, final_time, total_steps)
+ timestepper = ea.PositionVerlet()
+ ea.integrate(timestepper, snake_sim, final_time, total_steps)
if PLOT_FIGURE:
filename_plot = "continuum_snake_velocity.png"
diff --git a/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_fixed_joint.py b/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_fixed_joint.py
index d338b2a2..97ea44b0 100644
--- a/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_fixed_joint.py
+++ b/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_fixed_joint.py
@@ -1,7 +1,7 @@
__doc__ = """Fixed joint example, for detailed explanation refer to Zhang et. al. Nature Comm. methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from elastica.experimental.connection_contact_joint.generic_system_type_connection import (
GenericSystemTypeFixedJoint,
)
@@ -14,7 +14,12 @@
class FixedJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -45,7 +50,7 @@ class FixedJointSimulator(
start_cylinder = start_rod_2 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -59,7 +64,7 @@ class FixedJointSimulator(
)
fixed_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -72,7 +77,7 @@ class FixedJointSimulator(
shear_modulus=shear_modulus,
)
fixed_joint_sim.append(rod2)
-cylinder = Cylinder(
+cylinder = ea.Cylinder(
start=start_cylinder,
direction=direction,
normal=normal,
@@ -84,7 +89,7 @@ class FixedJointSimulator(
# Apply boundary conditions to rod1.
fixed_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
@@ -111,7 +116,7 @@ class FixedJointSimulator(
# Add forces to rod2
fixed_joint_sim.add_forcing_to(rod2).using(
- EndpointForcesSinusoidal,
+ ea.EndpointForcesSinusoidal,
start_force_mag=0,
end_force_mag=5e-3,
ramp_up_time=0.2,
@@ -125,38 +130,38 @@ class FixedJointSimulator(
# dt = 1e-5
damping_constant = 0.4
fixed_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
fixed_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
-pp_list_cylinder = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
+pp_list_cylinder = ea.defaultdict(list)
fixed_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_rod1
)
fixed_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_rod2
)
fixed_joint_sim.collect_diagnostics(cylinder).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_cylinder
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_cylinder
)
fixed_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, fixed_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, fixed_joint_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = True
diff --git a/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_spherical_joint.py b/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_spherical_joint.py
index 3d3a61da..811ac691 100644
--- a/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_spherical_joint.py
+++ b/examples/ExperimentalCases/GenericSystemConnectionCases/generic_system_type_spherical_joint.py
@@ -2,7 +2,7 @@
methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from elastica.experimental.connection_contact_joint.generic_system_type_connection import (
GenericSystemTypeFreeJoint,
)
@@ -15,7 +15,12 @@
class SphericalJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -46,7 +51,7 @@ class SphericalJointSimulator(
start_cylinder = start_rod_2 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -60,7 +65,7 @@ class SphericalJointSimulator(
)
spherical_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -74,7 +79,7 @@ class SphericalJointSimulator(
)
spherical_joint_sim.append(rod2)
# Create cylinder
-cylinder = Cylinder(
+cylinder = ea.Cylinder(
start=start_cylinder,
direction=direction,
normal=normal,
@@ -86,7 +91,7 @@ class SphericalJointSimulator(
# Apply boundary conditions to rod1.
spherical_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
@@ -107,7 +112,7 @@ class SphericalJointSimulator(
# Add forces to rod2
spherical_joint_sim.add_forcing_to(rod2).using(
- EndpointForcesSinusoidal,
+ ea.EndpointForcesSinusoidal,
start_force_mag=0,
end_force_mag=5e-3,
ramp_up_time=0.2,
@@ -121,38 +126,38 @@ class SphericalJointSimulator(
# dt = 1e-5
damping_constant = 4e-3
spherical_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
spherical_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
-pp_list_cylinder = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
+pp_list_cylinder = ea.defaultdict(list)
spherical_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_rod1
)
spherical_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_rod2
)
spherical_joint_sim.collect_diagnostics(cylinder).using(
- MyCallBack, step_skip=step_skip, callback_params=pp_list_cylinder
+ ea.MyCallBack, step_skip=step_skip, callback_params=pp_list_cylinder
)
spherical_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, spherical_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, spherical_joint_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = True
diff --git a/examples/ExperimentalCases/ParallelConnectionExample/parallel_connection_example.py b/examples/ExperimentalCases/ParallelConnectionExample/parallel_connection_example.py
index 636f043d..ba931c13 100644
--- a/examples/ExperimentalCases/ParallelConnectionExample/parallel_connection_example.py
+++ b/examples/ExperimentalCases/ParallelConnectionExample/parallel_connection_example.py
@@ -1,7 +1,7 @@
__doc__ = """Parallel connection example"""
import numpy as np
-from elastica import *
+import elastica as ea
from elastica.experimental.connection_contact_joint.parallel_connection import (
get_connection_vector_straight_straight_rod,
SurfaceJointSideBySide,
@@ -16,7 +16,12 @@
class ParallelConnection(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -40,7 +45,7 @@ class ParallelConnection(
start_rod_2 = start_rod_1 + binormal * 2 * base_radius
# Create rod 1
-rod_one = CosseratRod.straight_rod(
+rod_one = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -54,7 +59,7 @@ class ParallelConnection(
)
parallel_connection_sim.append(rod_one)
# Create rod 2
-rod_two = CosseratRod.straight_rod(
+rod_two = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -70,16 +75,16 @@ class ParallelConnection(
# Apply boundary conditions to rod1.
parallel_connection_sim.constrain(rod_one).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Apply boundary conditions to rod2.
parallel_connection_sim.constrain(rod_two).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Apply a contraction force on rod one.
-class ContractionForce(NoForces):
+class ContractionForce(ea.NoForces):
def __init__(
self,
ramp,
@@ -135,24 +140,24 @@ def apply_forces(self, system, time: np.float64 = 0.0):
damping_constant = 4e-3
dt = 1e-3
parallel_connection_sim.dampen(rod_one).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
parallel_connection_sim.dampen(rod_two).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-class ParallelConnecitonCallback(CallBackBaseClass):
+class ParallelConnecitonCallback(ea.CallBackBaseClass):
"""
Call back function for parallel connection
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -165,8 +170,8 @@ def make_callback(self, system, time, current_step: int):
return
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
parallel_connection_sim.collect_diagnostics(rod_one).using(
@@ -178,13 +183,13 @@ def make_callback(self, system, time, current_step: int):
parallel_connection_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
final_time = 20.0
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, parallel_connection_sim, final_time, total_steps)
+ea.integrate(timestepper, parallel_connection_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = False
diff --git a/examples/FlexibleSwingingPendulumCase/flexible_swinging_pendulum.py b/examples/FlexibleSwingingPendulumCase/flexible_swinging_pendulum.py
index abe94d13..d6364e24 100644
--- a/examples/FlexibleSwingingPendulumCase/flexible_swinging_pendulum.py
+++ b/examples/FlexibleSwingingPendulumCase/flexible_swinging_pendulum.py
@@ -1,14 +1,15 @@
""" Flexible swinging pendulum test-case
isort:skip_file
"""
+
import numpy as np
from matplotlib import pyplot as plt
-from elastica import *
+import elastica as ea
class SwingingFlexiblePendulumSimulator(
- BaseSystemCollection, Constraints, Forcing, CallBacks
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks
):
pass
@@ -36,7 +37,7 @@ class SwingingFlexiblePendulumSimulator(
# For shear modulus of 1e4, nu is 99!
poisson_ratio = 0.5
-pendulum_rod = CosseratRod.straight_rod(
+pendulum_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -53,7 +54,7 @@ class SwingingFlexiblePendulumSimulator(
# Bad name : whats a FreeRod anyway?
-class HingeBC(ConstraintBase):
+class HingeBC(ea.ConstraintBase):
"""
the end of the rod fixed x[0]
"""
@@ -77,18 +78,18 @@ def constrain_rates(self, rod, time):
# Add gravitational forces
gravitational_acc = -9.80665
pendulum_sim.add_forcing_to(pendulum_rod).using(
- GravityForces, acc_gravity=np.array([gravitational_acc, 0.0, 0.0])
+ ea.GravityForces, acc_gravity=np.array([gravitational_acc, 0.0, 0.0])
)
# Add call backs
-class PendulumCallBack(CallBackBaseClass):
+class PendulumCallBack(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -112,7 +113,7 @@ def make_callback(self, system, time, current_step: int):
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-recorded_history = defaultdict(list)
+recorded_history = ea.defaultdict(list)
step_skip = (
60
if PLOT_VIDEO
@@ -123,10 +124,10 @@ def make_callback(self, system, time, current_step: int):
)
pendulum_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
-integrate(timestepper, pendulum_sim, final_time, total_steps)
+ea.integrate(timestepper, pendulum_sim, final_time, total_steps)
if PLOT_VIDEO:
diff --git a/examples/FrictionValidationCases/axial_friction.py b/examples/FrictionValidationCases/axial_friction.py
index 14331121..685ffdea 100644
--- a/examples/FrictionValidationCases/axial_friction.py
+++ b/examples/FrictionValidationCases/axial_friction.py
@@ -1,13 +1,13 @@
__doc__ = """Axial friction validation, for detailed explanation refer to Gazzola et. al. R. Soc. 2018
section 4.1.4 and Appendix G """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_axial_friction_validation,
)
-class AxialFrictionSimulator(BaseSystemCollection, Constraints, Forcing):
+class AxialFrictionSimulator(ea.BaseSystemCollection, ea.Constraints, ea.Forcing):
pass
@@ -39,7 +39,7 @@ def simulate_axial_friction_with(force=0.0):
# Set shear matrix
shear_matrix = np.repeat(1e4 * np.identity((3))[:, :, np.newaxis], n_elem, axis=2)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -56,17 +56,17 @@ def simulate_axial_friction_with(force=0.0):
shearable_rod.shear_matrix = shear_matrix
axial_friction_sim.append(shearable_rod)
- axial_friction_sim.constrain(shearable_rod).using(FreeBC)
+ axial_friction_sim.constrain(shearable_rod).using(ea.FreeBC)
# Add gravitational forces
gravitational_acc = -9.80665
axial_friction_sim.add_forcing_to(shearable_rod).using(
- GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
+ ea.GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
)
# Add Uniform force on the rod
axial_friction_sim.add_forcing_to(shearable_rod).using(
- UniformForces, force=1.0 * force, direction=direction
+ ea.UniformForces, force=1.0 * force, direction=direction
)
# Add friction forces
@@ -77,7 +77,7 @@ def simulate_axial_friction_with(force=0.0):
kinetic_mu_array = np.array([0.4, 0.2, 0.2]) # [forward, backward, sideways]
axial_friction_sim.add_forcing_to(shearable_rod).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=10.0,
nu=1e-4,
plane_origin=origin_plane,
@@ -88,13 +88,13 @@ def simulate_axial_friction_with(force=0.0):
)
axial_friction_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.25
dt = 1e-5
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, axial_friction_sim, final_time, total_steps)
+ ea.integrate(timestepper, axial_friction_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = shearable_rod.compute_translational_energy()
diff --git a/examples/FrictionValidationCases/rolling_friction_initial_velocity.py b/examples/FrictionValidationCases/rolling_friction_initial_velocity.py
index 73d99a70..4919fb76 100644
--- a/examples/FrictionValidationCases/rolling_friction_initial_velocity.py
+++ b/examples/FrictionValidationCases/rolling_friction_initial_velocity.py
@@ -2,14 +2,14 @@
section 4.1.4 and Appendix G """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
class RollingFrictionInitialVelocitySimulator(
- BaseSystemCollection, Constraints, Forcing, Damping
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping
):
pass
@@ -43,7 +43,7 @@ def simulate_rolling_friction_initial_velocity_with(IFactor=0.0):
# Set shear matrix
shear_matrix = np.repeat(1e4 * np.identity((3))[:, :, np.newaxis], n_elem, axis=2)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -67,12 +67,12 @@ def simulate_rolling_friction_initial_velocity_with(IFactor=0.0):
shearable_rod.velocity_collection[0, :] += Vs
rolling_friction_initial_velocity_sim.append(shearable_rod)
- rolling_friction_initial_velocity_sim.constrain(shearable_rod).using(FreeBC)
+ rolling_friction_initial_velocity_sim.constrain(shearable_rod).using(ea.FreeBC)
# Add damping
dt = 1e-6 * 2
rolling_friction_initial_velocity_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
@@ -80,7 +80,7 @@ def simulate_rolling_friction_initial_velocity_with(IFactor=0.0):
# Add gravitational forces
gravitational_acc = -9.80665
rolling_friction_initial_velocity_sim.add_forcing_to(shearable_rod).using(
- GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
+ ea.GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
)
# Add friction forces
@@ -91,7 +91,7 @@ def simulate_rolling_friction_initial_velocity_with(IFactor=0.0):
kinetic_mu_array = np.array([0.2, 0.2, 0.2]) # [forward, backward, sideways]
rolling_friction_initial_velocity_sim.add_forcing_to(shearable_rod).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=10.0,
nu=1e-4,
plane_origin=origin_plane,
@@ -102,12 +102,12 @@ def simulate_rolling_friction_initial_velocity_with(IFactor=0.0):
)
rolling_friction_initial_velocity_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 2.0
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(
+ ea.integrate(
timestepper, rolling_friction_initial_velocity_sim, final_time, total_steps
)
diff --git a/examples/FrictionValidationCases/rolling_friction_on_inclined_plane.py b/examples/FrictionValidationCases/rolling_friction_on_inclined_plane.py
index af8f8326..3c36e2ae 100644
--- a/examples/FrictionValidationCases/rolling_friction_on_inclined_plane.py
+++ b/examples/FrictionValidationCases/rolling_friction_on_inclined_plane.py
@@ -2,14 +2,14 @@
section 4.1.4 and Appendix G """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
class RollingFrictionOnInclinedPlaneSimulator(
- BaseSystemCollection, Constraints, Forcing
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing
):
pass
@@ -42,7 +42,7 @@ def simulate_rolling_friction_on_inclined_plane_with(alpha_s=0.0):
# Set shear matrix
shear_matrix = np.repeat(1e4 * np.identity((3))[:, :, np.newaxis], n_elem, axis=2)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -59,11 +59,11 @@ def simulate_rolling_friction_on_inclined_plane_with(alpha_s=0.0):
shearable_rod.shear_matrix = shear_matrix
rolling_friction_on_inclined_plane_sim.append(shearable_rod)
- rolling_friction_on_inclined_plane_sim.constrain(shearable_rod).using(FreeBC)
+ rolling_friction_on_inclined_plane_sim.constrain(shearable_rod).using(ea.FreeBC)
gravitational_acc = -9.80665
rolling_friction_on_inclined_plane_sim.add_forcing_to(shearable_rod).using(
- GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
+ ea.GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
)
alpha = alpha_s * np.pi
@@ -77,7 +77,7 @@ def simulate_rolling_friction_on_inclined_plane_with(alpha_s=0.0):
kinetic_mu_array = np.array([0.2, 0.2, 0.2]) # [forward, backward, sideways]
rolling_friction_on_inclined_plane_sim.add_forcing_to(shearable_rod).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=10.0,
nu=1e-4,
plane_origin=origin_plane,
@@ -88,13 +88,13 @@ def simulate_rolling_friction_on_inclined_plane_with(alpha_s=0.0):
)
rolling_friction_on_inclined_plane_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.5
dt = 1e-6
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(
+ ea.integrate(
timestepper, rolling_friction_on_inclined_plane_sim, final_time, total_steps
)
diff --git a/examples/FrictionValidationCases/rolling_friction_torque.py b/examples/FrictionValidationCases/rolling_friction_torque.py
index 3284f769..dbc9f7a1 100644
--- a/examples/FrictionValidationCases/rolling_friction_torque.py
+++ b/examples/FrictionValidationCases/rolling_friction_torque.py
@@ -2,13 +2,15 @@
section 4.1.4 and Appendix G """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
-class RollingFrictionTorqueSimulator(BaseSystemCollection, Constraints, Forcing):
+class RollingFrictionTorqueSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing
+):
pass
@@ -40,7 +42,7 @@ def simulate_rolling_friction_torque_with(C_s=0.0):
# Set shear matrix
shear_matrix = np.repeat(1e4 * np.identity((3))[:, :, np.newaxis], n_elem, axis=2)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -57,17 +59,17 @@ def simulate_rolling_friction_torque_with(C_s=0.0):
shearable_rod.shear_matrix = shear_matrix
rolling_friction_torque_sim.append(shearable_rod)
- rolling_friction_torque_sim.constrain(shearable_rod).using(FreeBC)
+ rolling_friction_torque_sim.constrain(shearable_rod).using(ea.FreeBC)
# Add gravitational forces
gravitational_acc = -9.80665
rolling_friction_torque_sim.add_forcing_to(shearable_rod).using(
- GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
+ ea.GravityForces, acc_gravity=np.array([0.0, gravitational_acc, 0.0])
)
# Add Uniform torque on the rod
rolling_friction_torque_sim.add_forcing_to(shearable_rod).using(
- UniformTorques, torque=1.0 * C_s, direction=direction
+ ea.UniformTorques, torque=1.0 * C_s, direction=direction
)
# Add friction forces
@@ -78,7 +80,7 @@ def simulate_rolling_friction_torque_with(C_s=0.0):
kinetic_mu_array = np.array([0.2, 0.2, 0.2]) # [forward, backward, sideways]
rolling_friction_torque_sim.add_forcing_to(shearable_rod).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=10.0,
nu=1e-4,
plane_origin=origin_plane,
@@ -89,13 +91,13 @@ def simulate_rolling_friction_torque_with(C_s=0.0):
)
rolling_friction_torque_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 1.0
dt = 1e-6
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, rolling_friction_torque_sim, final_time, total_steps)
+ ea.integrate(timestepper, rolling_friction_torque_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = shearable_rod.compute_translational_energy()
diff --git a/examples/HelicalBucklingCase/convergence_helicalbuckling.py b/examples/HelicalBucklingCase/convergence_helicalbuckling.py
index 6ad5597f..21f7e8c8 100644
--- a/examples/HelicalBucklingCase/convergence_helicalbuckling.py
+++ b/examples/HelicalBucklingCase/convergence_helicalbuckling.py
@@ -2,7 +2,7 @@
section 3.4.1 """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.HelicalBucklingCase.helicalbuckling_postprocessing import (
analytical_solution,
envelope,
@@ -11,7 +11,9 @@
from examples.convergence_functions import plot_convergence, calculate_error_norm
-class HelicalBucklingSimulator(BaseSystemCollection, Constraints, Forcing, Damping):
+class HelicalBucklingSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping
+):
pass
@@ -47,7 +49,7 @@ def simulate_helicalbucklin_beam_with(
np.fill_diagonal(temp_bend_matrix, [1.345, 1.345, 0.789])
bend_matrix = np.repeat(temp_bend_matrix[:, :, np.newaxis], n_elem - 1, axis=2)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -68,13 +70,13 @@ def simulate_helicalbucklin_beam_with(
dl = base_length / n_elem
dt = 1e-3 * dl
helicalbuckling_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
helicalbuckling_sim.constrain(shearable_rod).using(
- HelicalBucklingBC,
+ ea.HelicalBucklingBC,
constrained_position_idx=(0, -1),
constrained_director_idx=(0, -1),
twisting_time=500,
@@ -83,7 +85,7 @@ def simulate_helicalbucklin_beam_with(
)
helicalbuckling_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
shearable_rod.velocity_collection[..., int((n_elem) / 2)] += np.array(
[0, 1e-6, 0.0]
)
@@ -92,7 +94,7 @@ def simulate_helicalbucklin_beam_with(
final_time = 10500
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, helicalbuckling_sim, final_time, total_steps)
+ ea.integrate(timestepper, helicalbuckling_sim, final_time, total_steps)
# calculate errors and norms
# Since we need to evaluate analytical solution only on nodes, n_nodes = n_elems+1
diff --git a/examples/HelicalBucklingCase/helicalbuckling.py b/examples/HelicalBucklingCase/helicalbuckling.py
index 2743dd8e..7c1a789c 100644
--- a/examples/HelicalBucklingCase/helicalbuckling.py
+++ b/examples/HelicalBucklingCase/helicalbuckling.py
@@ -2,13 +2,15 @@
Gazzola et. al. R. Soc. 2018 section 3.4.1 """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.HelicalBucklingCase.helicalbuckling_postprocessing import (
plot_helicalbuckling,
)
-class HelicalBucklingSimulator(BaseSystemCollection, Constraints, Damping, Forcing):
+class HelicalBucklingSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Damping, ea.Forcing
+):
pass
@@ -42,7 +44,7 @@ class HelicalBucklingSimulator(BaseSystemCollection, Constraints, Damping, Forci
np.fill_diagonal(temp_bend_matrix, [1.345, 1.345, 0.789])
bend_matrix = np.repeat(temp_bend_matrix[:, :, np.newaxis], n_elem - 1, axis=2)
-shearable_rod = CosseratRod.straight_rod(
+shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -65,13 +67,13 @@ class HelicalBucklingSimulator(BaseSystemCollection, Constraints, Damping, Forci
dl = base_length / n_elem
dt = 1e-3 * dl
helicalbuckling_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
helicalbuckling_sim.constrain(shearable_rod).using(
- HelicalBucklingBC,
+ ea.HelicalBucklingBC,
constrained_position_idx=(0, -1),
constrained_director_idx=(0, -1),
twisting_time=500,
@@ -80,14 +82,14 @@ class HelicalBucklingSimulator(BaseSystemCollection, Constraints, Damping, Forci
)
helicalbuckling_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
shearable_rod.velocity_collection[..., int((n_elem) / 2)] += np.array([0, 1e-6, 0.0])
# timestepper = PEFRL()
final_time = 10500.0
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, helicalbuckling_sim, final_time, total_steps)
+ea.integrate(timestepper, helicalbuckling_sim, final_time, total_steps)
if PLOT_FIGURE:
plot_helicalbuckling(shearable_rod, SAVE_FIGURE)
diff --git a/examples/JointCases/fixed_joint.py b/examples/JointCases/fixed_joint.py
index c5c8064e..4f6b9809 100644
--- a/examples/JointCases/fixed_joint.py
+++ b/examples/JointCases/fixed_joint.py
@@ -1,7 +1,7 @@
__doc__ = """Fixed joint example, for detailed explanation refer to Zhang et. al. Nature Comm. methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from examples.JointCases.joint_cases_postprocessing import (
plot_position,
plot_video,
@@ -11,7 +11,12 @@
class FixedJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -35,7 +40,7 @@ class FixedJointSimulator(
start_rod_2 = start_rod_1 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -49,7 +54,7 @@ class FixedJointSimulator(
)
fixed_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -65,17 +70,17 @@ class FixedJointSimulator(
# Apply boundary conditions to rod1.
fixed_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
fixed_joint_sim.connect(
first_rod=rod1, second_rod=rod2, first_connect_idx=-1, second_connect_idx=0
-).using(FixedJoint, k=1e5, nu=0.0, kt=1e1, nut=0.0)
+).using(ea.FixedJoint, k=1e5, nu=0.0, kt=1e1, nut=0.0)
# Add forces to rod2
fixed_joint_sim.add_forcing_to(rod2).using(
- EndpointForcesSinusoidal,
+ ea.EndpointForcesSinusoidal,
start_force_mag=0,
end_force_mag=5e-3,
ramp_up_time=0.2,
@@ -90,35 +95,35 @@ class FixedJointSimulator(
damping_constant = 0.4
dt = 1e-4
fixed_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
fixed_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
fixed_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod1
)
fixed_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod2
)
fixed_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
final_time = 10
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, fixed_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, fixed_joint_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = False
diff --git a/examples/JointCases/fixed_joint_torsion.py b/examples/JointCases/fixed_joint_torsion.py
index 35f9f7f3..5d90132a 100644
--- a/examples/JointCases/fixed_joint_torsion.py
+++ b/examples/JointCases/fixed_joint_torsion.py
@@ -1,7 +1,7 @@
__doc__ = """Fixed joint example, for detailed explanation refer to Zhang et. al. Nature Comm. methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from elastica.joint import get_relative_rotation_two_systems
from examples.JointCases.joint_cases_postprocessing import (
plot_position,
@@ -13,7 +13,12 @@
class FixedJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -38,7 +43,7 @@ class FixedJointSimulator(
start_rod_2 = start_rod_1 + direction_rod1 * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction_rod1,
@@ -52,7 +57,7 @@ class FixedJointSimulator(
)
fixed_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction_rod2,
@@ -68,14 +73,14 @@ class FixedJointSimulator(
# Apply boundary conditions to rod1.
fixed_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
fixed_joint_sim.connect(
first_rod=rod1, second_rod=rod2, first_connect_idx=-1, second_connect_idx=0
).using(
- FixedJoint,
+ ea.FixedJoint,
k=1e5,
nu=1.0,
kt=1e3,
@@ -85,43 +90,43 @@ class FixedJointSimulator(
# Add forces to rod2
fixed_joint_sim.add_forcing_to(rod2).using(
- UniformTorques, torque=5e-3, direction=np.array([0.0, 0.0, 1.0])
+ ea.UniformTorques, torque=5e-3, direction=np.array([0.0, 0.0, 1.0])
)
# add damping
damping_constant = 0.4
dt = 1e-5
fixed_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
fixed_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
fixed_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod1
)
fixed_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod2
)
fixed_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
final_time = 10
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, fixed_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, fixed_joint_sim, final_time, total_steps)
plot_orientation(
diff --git a/examples/JointCases/hinge_joint.py b/examples/JointCases/hinge_joint.py
index 9a165806..c478552e 100644
--- a/examples/JointCases/hinge_joint.py
+++ b/examples/JointCases/hinge_joint.py
@@ -1,7 +1,7 @@
__doc__ = """Hinge joint example, for detailed explanation refer to Zhang et. al. Nature Comm. methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from examples.JointCases.joint_cases_postprocessing import (
plot_position,
plot_video,
@@ -11,7 +11,12 @@
class HingeJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -35,7 +40,7 @@ class HingeJointSimulator(
start_rod_2 = start_rod_1 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -49,7 +54,7 @@ class HingeJointSimulator(
)
hinge_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -65,19 +70,19 @@ class HingeJointSimulator(
# Apply boundary conditions to rod1.
hinge_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
hinge_joint_sim.connect(
first_rod=rod1, second_rod=rod2, first_connect_idx=-1, second_connect_idx=0
).using(
- HingeJoint, k=1e5, nu=0, kt=1e1, normal_direction=roll_direction
+ ea.HingeJoint, k=1e5, nu=0, kt=1e1, normal_direction=roll_direction
) # 1e-2
# Add forces to rod2
hinge_joint_sim.add_forcing_to(rod2).using(
- EndpointForcesSinusoidal,
+ ea.EndpointForcesSinusoidal,
start_force_mag=0,
end_force_mag=5e-3,
ramp_up_time=0.2,
@@ -92,35 +97,35 @@ class HingeJointSimulator(
damping_constant = 4e-3
dt = 5e-5
hinge_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
hinge_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
hinge_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod1
)
hinge_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod2
)
hinge_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
final_time = 10
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, hinge_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, hinge_joint_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = False
diff --git a/examples/JointCases/spherical_joint.py b/examples/JointCases/spherical_joint.py
index b7c7a6b8..f71da4f5 100644
--- a/examples/JointCases/spherical_joint.py
+++ b/examples/JointCases/spherical_joint.py
@@ -2,7 +2,7 @@
methods section."""
import numpy as np
-from elastica import *
+import elastica as ea
from examples.JointCases.joint_cases_postprocessing import (
plot_position,
plot_video,
@@ -12,7 +12,12 @@
class SphericalJointSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -36,7 +41,7 @@ class SphericalJointSimulator(
start_rod_2 = start_rod_1 + direction * base_length
# Create rod 1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -50,7 +55,7 @@ class SphericalJointSimulator(
)
spherical_joint_sim.append(rod1)
# Create rod 2
-rod2 = CosseratRod.straight_rod(
+rod2 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_2,
direction,
@@ -66,19 +71,19 @@ class SphericalJointSimulator(
# Apply boundary conditions to rod1.
spherical_joint_sim.constrain(rod1).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Connect rod 1 and rod 2
spherical_joint_sim.connect(
first_rod=rod1, second_rod=rod2, first_connect_idx=-1, second_connect_idx=0
).using(
- FreeJoint, k=1e5, nu=0
+ ea.FreeJoint, k=1e5, nu=0
) # k=kg/s2 nu=kg/s 1e-2
# Add forces to rod2
spherical_joint_sim.add_forcing_to(rod2).using(
- EndpointForcesSinusoidal,
+ ea.EndpointForcesSinusoidal,
start_force_mag=0,
end_force_mag=5e-3,
ramp_up_time=0.2,
@@ -93,35 +98,35 @@ class SphericalJointSimulator(
damping_constant = 4e-3
dt = 5e-5
spherical_joint_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
spherical_joint_sim.dampen(rod2).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
-pp_list_rod1 = defaultdict(list)
-pp_list_rod2 = defaultdict(list)
+pp_list_rod1 = ea.defaultdict(list)
+pp_list_rod2 = ea.defaultdict(list)
spherical_joint_sim.collect_diagnostics(rod1).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod1
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod1
)
spherical_joint_sim.collect_diagnostics(rod2).using(
- MyCallBack, step_skip=1000, callback_params=pp_list_rod2
+ ea.MyCallBack, step_skip=1000, callback_params=pp_list_rod2
)
spherical_joint_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
final_time = 10
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, spherical_joint_sim, final_time, total_steps)
+ea.integrate(timestepper, spherical_joint_sim, final_time, total_steps)
PLOT_FIGURE = True
SAVE_FIGURE = False
diff --git a/examples/MuscularFlagella/muscular_flagella.py b/examples/MuscularFlagella/muscular_flagella.py
index 1d64a100..dcca35c2 100644
--- a/examples/MuscularFlagella/muscular_flagella.py
+++ b/examples/MuscularFlagella/muscular_flagella.py
@@ -1,7 +1,7 @@
__doc__ = """Muscular flagella example from Zhang et. al. Nature Comm 2019 paper."""
import numpy as np
-from elastica import *
+import elastica as ea
from examples.MuscularFlagella.post_processing import (
plot_video_2D,
plot_video,
@@ -15,7 +15,12 @@
class MuscularFlagellaSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -54,7 +59,7 @@ class MuscularFlagellaSimulator(
binormal = np.cross(direction, normal)
nu_body = 0
-flagella_body = CosseratRod.straight_rod(
+flagella_body = ea.CosseratRod.straight_rod(
n_elem_body,
start,
direction,
@@ -140,7 +145,7 @@ class MuscularFlagellaSimulator(
start_muscle = np.array([4.5 * base_length_muscle, 0.0053, 0.1])
-flagella_muscle = CosseratRod.straight_rod(
+flagella_muscle = ea.CosseratRod.straight_rod(
n_elem_muscle,
start_muscle,
direction,
@@ -157,7 +162,7 @@ class MuscularFlagellaSimulator(
# add damping
muscular_flagella_sim.dampen(flagella_muscle).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu_muscle,
time_step=time_step,
)
@@ -193,13 +198,13 @@ class MuscularFlagellaSimulator(
reynolds_number = 1.8e-2
dynamic_viscosity = 1.2e-3
muscular_flagella_sim.add_forcing_to(flagella_body).using(
- SlenderBodyTheory, dynamic_viscosity=dynamic_viscosity
+ ea.SlenderBodyTheory, dynamic_viscosity=dynamic_viscosity
)
# Add call backs
-class MuscularFlagellaCallBack(CallBackBaseClass):
+class MuscularFlagellaCallBack(ea.CallBackBaseClass):
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -214,14 +219,14 @@ def make_callback(self, system, time, current_step: int):
self.callback_params["tangents"].append(system.tangents.copy())
-post_processing_dict_body = defaultdict(list)
+post_processing_dict_body = ea.defaultdict(list)
muscular_flagella_sim.collect_diagnostics(flagella_body).using(
MuscularFlagellaCallBack,
step_skip=step_skip,
callback_params=post_processing_dict_body,
)
-post_processing_dict_muscle = defaultdict(list)
+post_processing_dict_muscle = ea.defaultdict(list)
muscular_flagella_sim.collect_diagnostics(flagella_muscle).using(
MuscularFlagellaCallBack,
step_skip=step_skip,
@@ -231,9 +236,9 @@ def make_callback(self, system, time, current_step: int):
muscular_flagella_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
print("Total steps", total_steps)
-integrate(timestepper, muscular_flagella_sim, final_time, total_steps)
+ea.integrate(timestepper, muscular_flagella_sim, final_time, total_steps)
# Plot the videos
diff --git a/examples/MuscularSnake/muscular_snake.py b/examples/MuscularSnake/muscular_snake.py
index 1329c5d5..1c9474b2 100644
--- a/examples/MuscularSnake/muscular_snake.py
+++ b/examples/MuscularSnake/muscular_snake.py
@@ -1,6 +1,6 @@
__doc__ = """Muscular snake example from Zhang et. al. Nature Comm 2019 paper."""
import numpy as np
-from elastica import *
+import elastica as ea
from examples.MuscularSnake.post_processing import (
plot_video_with_surface,
plot_snake_velocity,
@@ -14,7 +14,12 @@
# Set base simulator class
class MuscularSnakeSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -45,7 +50,7 @@ class MuscularSnakeSimulator(
normal = np.array([0.0, 0.0, 1.0])
start = np.array([0.0, 0.0, base_radius_body])
-snake_body = CosseratRod.straight_rod(
+snake_body = ea.CosseratRod.straight_rod(
n_elem_body,
start,
direction,
@@ -115,7 +120,7 @@ class MuscularSnakeSimulator(
]
)
- muscle_rod = CosseratRod.straight_rod(
+ muscle_rod = ea.CosseratRod.straight_rod(
n_elem_muscle_group_one_to_three,
start_muscle,
direction,
@@ -180,7 +185,7 @@ class MuscularSnakeSimulator(
]
)
- muscle_rod = CosseratRod.straight_rod(
+ muscle_rod = ea.CosseratRod.straight_rod(
n_elem_muscle_group_two_to_four,
start_muscle,
direction,
@@ -228,7 +233,7 @@ class MuscularSnakeSimulator(
# Add dissipation to backbone
muscular_snake_simulator.dampen(snake_body).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu_body,
time_step=time_step,
)
@@ -236,7 +241,7 @@ class MuscularSnakeSimulator(
# Add dissipation to muscles
for rod in rod_list:
muscular_snake_simulator.dampen(rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu_muscle,
time_step=time_step,
)
@@ -245,7 +250,7 @@ class MuscularSnakeSimulator(
post_processing_forces_dict_list = []
for i in range(n_muscle_fibers):
- post_processing_forces_dict_list.append(defaultdict(list))
+ post_processing_forces_dict_list.append(ea.defaultdict(list))
muscle_rod = muscle_rod_list[i]
side_of_body = 1 if i % 2 == 0 else -1
@@ -265,7 +270,7 @@ class MuscularSnakeSimulator(
straight_straight_rod_connection_list = []
-straight_straight_rod_connection_post_processing_dict = defaultdict(list)
+straight_straight_rod_connection_post_processing_dict = ea.defaultdict(list)
for idx, rod_two in enumerate(muscle_rod_list):
rod_one = snake_body
(
@@ -331,7 +336,7 @@ class MuscularSnakeSimulator(
# Only apply to the snake body.
gravitational_acc = -9.81
muscular_snake_simulator.add_forcing_to(snake_body).using(
- GravityForces, acc_gravity=np.array([0.0, 0.0, gravitational_acc])
+ ea.GravityForces, acc_gravity=np.array([0.0, 0.0, gravitational_acc])
)
origin_plane = np.array([0.0, 0.0, 0.0])
@@ -345,7 +350,7 @@ class MuscularSnakeSimulator(
) # [forward, backward, sideways]
static_mu_array = 2 * kinetic_mu_array
muscular_snake_simulator.add_forcing_to(snake_body).using(
- AnisotropicFrictionalPlane,
+ ea.AnisotropicFrictionalPlane,
k=1e1,
nu=40,
plane_origin=origin_plane,
@@ -356,9 +361,9 @@ class MuscularSnakeSimulator(
)
-class MuscularSnakeCallBack(CallBackBaseClass):
+class MuscularSnakeCallBack(ea.CallBackBaseClass):
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -383,7 +388,7 @@ def make_callback(self, system, time, current_step: int):
post_processing_dict_list = []
for idx, rod in enumerate(rod_list):
- post_processing_dict_list.append(defaultdict(list))
+ post_processing_dict_list.append(ea.defaultdict(list))
muscular_snake_simulator.collect_diagnostics(rod).using(
MuscularSnakeCallBack,
step_skip=step_skip,
@@ -391,8 +396,8 @@ def make_callback(self, system, time, current_step: int):
)
muscular_snake_simulator.finalize()
-timestepper = PositionVerlet()
-integrate(timestepper, muscular_snake_simulator, final_time, total_steps)
+timestepper = ea.PositionVerlet()
+ea.integrate(timestepper, muscular_snake_simulator, final_time, total_steps)
plot_video_with_surface(
diff --git a/examples/RestartExample/restart_example.py b/examples/RestartExample/restart_example.py
index 1d291f09..2765a23c 100644
--- a/examples/RestartExample/restart_example.py
+++ b/examples/RestartExample/restart_example.py
@@ -3,11 +3,11 @@
"""
import numpy as np
-from elastica import *
+import elastica as ea
class RestartExampleSimulator(
- BaseSystemCollection, Constraints, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping, ea.CallBacks
):
pass
@@ -30,7 +30,7 @@ class RestartExampleSimulator(
shear_modulus = E / (poisson_ratio + 1.0)
# Create rod
-shearable_rod = CosseratRod.straight_rod(
+shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -49,13 +49,13 @@ class RestartExampleSimulator(
# Constrain one end of the rod.
restart_example_simulator.constrain(shearable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Add end point forces to rod
end_force = np.array([-15.0, 0.0, 0.0])
restart_example_simulator.add_forcing_to(shearable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
)
# add damping
@@ -63,7 +63,7 @@ class RestartExampleSimulator(
dl = base_length / n_elem
dt = 0.01 * dl
restart_example_simulator.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
@@ -78,14 +78,14 @@ class RestartExampleSimulator(
restart_file_location = "data/"
if LOAD_FROM_RESTART:
- restart_time = load_state(restart_example_simulator, restart_file_location, True)
+ restart_time = ea.load_state(restart_example_simulator, restart_file_location, True)
else:
restart_time = np.float64(0.0)
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
total_steps = int(final_time / dt)
-time = integrate(
+time = ea.integrate(
timestepper,
restart_example_simulator,
final_time,
@@ -97,4 +97,4 @@ class RestartExampleSimulator(
# `restart_file_location` directory there is one file called system_0.npz . For each system appended on the simulator
# separate system_#.npz file will be created.
if SAVE_DATA_RESTART:
- save_state(restart_example_simulator, restart_file_location, time, True)
+ ea.save_state(restart_example_simulator, restart_file_location, time, True)
diff --git a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact.py b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact.py
index 81781e3a..30ed71bb 100644
--- a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact.py
+++ b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact.py
@@ -1,11 +1,16 @@
import numpy as np
-from elastica import *
+import elastica as ea
from post_processing import plot_velocity, plot_video_with_surface
def rod_cylinder_contact_case(inclination_angle=0.0):
class RodCylinderParallelContact(
- BaseSystemCollection, Constraints, Connections, CallBacks, Forcing, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.CallBacks,
+ ea.Forcing,
+ ea.Damping,
):
pass
@@ -29,7 +34,7 @@ class RodCylinderParallelContact(
direction = np.array([np.sin(inclination_angle), 0.0, np.cos(inclination_angle)])
normal = np.array([0.0, 1.0, 0.0])
- rod = CosseratRod.straight_rod(
+ rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -52,7 +57,7 @@ class RodCylinderParallelContact(
cylinder_direction = np.array([0.0, 0.0, 1.0])
cylinder_normal = np.array([0.0, 1.0, 0.0])
- rigid_body = Cylinder(
+ rigid_body = ea.Cylinder(
start=cylinder_start,
direction=cylinder_direction,
normal=cylinder_normal,
@@ -64,7 +69,7 @@ class RodCylinderParallelContact(
# Add contact between rigid body and rod
rod_cylinder_parallel_contact_simulator.connect(rod, rigid_body).using(
- ExternalContact,
+ ea.ExternalContact,
k=5e4,
nu=0.1,
)
@@ -72,7 +77,7 @@ class RodCylinderParallelContact(
# add damping
damping_constant = 1e-2
rod_cylinder_parallel_contact_simulator.dampen(rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=time_step,
)
@@ -80,13 +85,13 @@ class RodCylinderParallelContact(
# Add callbacks
post_processing_dict_list = []
# For rod
- class StraightRodCallBack(CallBackBaseClass):
+ class StraightRodCallBack(ea.CallBackBaseClass):
"""
Call back function for two arm octopus
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -120,7 +125,7 @@ def make_callback(self, system, time, current_step: int):
return
- class RigidCylinderCallBack(CallBackBaseClass):
+ class RigidCylinderCallBack(ea.CallBackBaseClass):
"""
Call back function for two arm octopus
"""
@@ -128,7 +133,7 @@ class RigidCylinderCallBack(CallBackBaseClass):
def __init__(
self, step_skip: int, callback_params: dict, resize_cylinder_elems: int
):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
self.n_elem_cylinder = resize_cylinder_elems
@@ -191,14 +196,14 @@ def make_callback(self, system, time, current_step: int):
return
- post_processing_dict_list.append(defaultdict(list))
+ post_processing_dict_list.append(ea.defaultdict(list))
rod_cylinder_parallel_contact_simulator.collect_diagnostics(rod).using(
StraightRodCallBack,
step_skip=step_skip,
callback_params=post_processing_dict_list[0],
)
# For rigid body
- post_processing_dict_list.append(defaultdict(list))
+ post_processing_dict_list.append(ea.defaultdict(list))
rod_cylinder_parallel_contact_simulator.collect_diagnostics(rigid_body).using(
RigidCylinderCallBack,
step_skip=step_skip,
@@ -207,9 +212,9 @@ def make_callback(self, system, time, current_step: int):
)
rod_cylinder_parallel_contact_simulator.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
- integrate(
+ ea.integrate(
timestepper, rod_cylinder_parallel_contact_simulator, final_time, total_steps
)
diff --git a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_friction.py b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_friction.py
index 5f83f3be..35d9cef2 100644
--- a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_friction.py
+++ b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_friction.py
@@ -1,5 +1,5 @@
import numpy as np
-from elastica import *
+import elastica as ea
from post_processing import plot_velocity, plot_video_with_surface
@@ -7,7 +7,12 @@ def rod_cylinder_contact_friction_case(
force_coefficient=0.1, normal_force_mag=10, POST_PROCESSING=False
):
class RodCylinderParallelContact(
- BaseSystemCollection, Constraints, Connections, CallBacks, Forcing, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.CallBacks,
+ ea.Forcing,
+ ea.Damping,
):
pass
@@ -31,7 +36,7 @@ class RodCylinderParallelContact(
direction = np.array([0, 0.0, 1.0])
normal = np.array([0.0, 1.0, 0.0])
- rod = CosseratRod.straight_rod(
+ rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -49,17 +54,19 @@ class RodCylinderParallelContact(
# Push the rod towards the cylinder to make sure contact is there
normal_force_direction = np.array([-1.0, 0.0, 0.0])
rod_cylinder_parallel_contact_simulator.add_forcing_to(rod).using(
- UniformForces, force=normal_force_mag, direction=normal_force_direction
+ ea.UniformForces, force=normal_force_mag, direction=normal_force_direction
)
# Apply uniform forces on the rod
rod_cylinder_parallel_contact_simulator.add_forcing_to(rod).using(
- UniformForces, force=normal_force_mag * force_coefficient, direction=direction
+ ea.UniformForces,
+ force=normal_force_mag * force_coefficient,
+ direction=direction,
)
# add damping
damping_constant = 2e-3
rod_cylinder_parallel_contact_simulator.dampen(rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=time_step,
)
@@ -71,7 +78,7 @@ class RodCylinderParallelContact(
cylinder_direction = np.array([0.0, 0.0, 1.0])
cylinder_normal = np.array([0.0, 1.0, 0.0])
- rigid_body = Cylinder(
+ rigid_body = ea.Cylinder(
start=cylinder_start,
direction=cylinder_direction,
normal=cylinder_normal,
@@ -83,12 +90,12 @@ class RodCylinderParallelContact(
# Constrain the rigid body position and directors
rod_cylinder_parallel_contact_simulator.constrain(rigid_body).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
# Add contact between rigid body and rod
rod_cylinder_parallel_contact_simulator.connect(rod, rigid_body).using(
- ExternalContact,
+ ea.ExternalContact,
k=1e5,
nu=100,
velocity_damping_coefficient=1e5,
@@ -98,13 +105,13 @@ class RodCylinderParallelContact(
# Add callbacks
post_processing_dict_list = []
# For rod
- class StraightRodCallBack(CallBackBaseClass):
+ class StraightRodCallBack(ea.CallBackBaseClass):
"""
Call back function for two arm octopus
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -138,7 +145,7 @@ def make_callback(self, system, time, current_step: int):
return
- class RigidCylinderCallBack(CallBackBaseClass):
+ class RigidCylinderCallBack(ea.CallBackBaseClass):
"""
Call back function for two arm octopus
"""
@@ -146,7 +153,7 @@ class RigidCylinderCallBack(CallBackBaseClass):
def __init__(
self, step_skip: int, callback_params: dict, resize_cylinder_elems: int
):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
self.n_elem_cylinder = resize_cylinder_elems
@@ -210,14 +217,14 @@ def make_callback(self, system, time, current_step: int):
return
if POST_PROCESSING:
- post_processing_dict_list.append(defaultdict(list))
+ post_processing_dict_list.append(ea.defaultdict(list))
rod_cylinder_parallel_contact_simulator.collect_diagnostics(rod).using(
StraightRodCallBack,
step_skip=step_skip,
callback_params=post_processing_dict_list[0],
)
# For rigid body
- post_processing_dict_list.append(defaultdict(list))
+ post_processing_dict_list.append(ea.defaultdict(list))
rod_cylinder_parallel_contact_simulator.collect_diagnostics(rigid_body).using(
RigidCylinderCallBack,
step_skip=step_skip,
@@ -226,9 +233,9 @@ def make_callback(self, system, time, current_step: int):
)
rod_cylinder_parallel_contact_simulator.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
- integrate(
+ ea.integrate(
timestepper, rod_cylinder_parallel_contact_simulator, final_time, total_steps
)
diff --git a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_validation.py b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_validation.py
index b7cc970b..33b16b6d 100644
--- a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_validation.py
+++ b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_validation.py
@@ -1,10 +1,15 @@
import numpy as np
-from elastica import *
+import elastica as ea
from post_processing import plot_video, plot_cylinder_rod_position
class SingleRodSingleCylinderInteractionSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -78,7 +83,7 @@ class SingleRodSingleCylinderInteractionSimulator(
)
start_rod_1 = global_rot_mat @ start_rod_1
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -95,7 +100,7 @@ class SingleRodSingleCylinderInteractionSimulator(
single_rod_sim.append(rod1)
-cylinder = Cylinder(
+cylinder = ea.Cylinder(
cylinder_start,
cylinder_direction,
cylinder_normal,
@@ -105,17 +110,17 @@ class SingleRodSingleCylinderInteractionSimulator(
)
single_rod_sim.append(cylinder)
-single_rod_sim.connect(rod1, cylinder).using(ExternalContact, 1e2, 0.1)
+single_rod_sim.connect(rod1, cylinder).using(ea.ExternalContact, 1e2, 0.1)
# Add call backs
-class PositionCollector(CallBackBaseClass):
+class PositionCollector(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -128,11 +133,11 @@ def make_callback(self, system, time, current_step: int):
return
-recorded_rod_history = defaultdict(list)
+recorded_rod_history = ea.defaultdict(list)
single_rod_sim.collect_diagnostics(rod1).using(
PositionCollector, step_skip=200, callback_params=recorded_rod_history
)
-recorded_cyl_history = defaultdict(list)
+recorded_cyl_history = ea.defaultdict(list)
single_rod_sim.collect_diagnostics(cylinder).using(
PositionCollector, step_skip=200, callback_params=recorded_cyl_history
)
@@ -141,19 +146,19 @@ def make_callback(self, system, time, current_step: int):
damping_constant = 1e-3
dt = 1e-4
single_rod_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
single_rod_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
final_time = 2.0
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, single_rod_sim, final_time, total_steps)
+ea.integrate(timestepper, single_rod_sim, final_time, total_steps)
if PLOT_FIGURE:
plot_video(
diff --git a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_with_y_normal.py b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_with_y_normal.py
index 87303d34..b9692f90 100644
--- a/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_with_y_normal.py
+++ b/examples/RigidBodyCases/RodRigidBodyContact/rod_cylinder_contact_with_y_normal.py
@@ -1,10 +1,15 @@
import numpy as np
-from elastica import *
+import elastica as ea
from post_processing import plot_video, plot_cylinder_rod_position
class SingleRodSingleCylinderInteractionSimulator(
- BaseSystemCollection, Constraints, Connections, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -56,7 +61,7 @@ class SingleRodSingleCylinderInteractionSimulator(
)
# start_rod_1[2] = cylinder_radius + base_length
-rod1 = CosseratRod.straight_rod(
+rod1 = ea.CosseratRod.straight_rod(
n_elem,
start_rod_1,
direction,
@@ -73,7 +78,7 @@ class SingleRodSingleCylinderInteractionSimulator(
single_rod_sim.append(rod1)
-cylinder = Cylinder(
+cylinder = ea.Cylinder(
cylinder_start,
cylinder_direction,
cylinder_normal,
@@ -83,17 +88,17 @@ class SingleRodSingleCylinderInteractionSimulator(
)
single_rod_sim.append(cylinder)
-single_rod_sim.connect(rod1, cylinder).using(ExternalContact, 1e2, 0.1)
+single_rod_sim.connect(rod1, cylinder).using(ea.ExternalContact, 1e2, 0.1)
# Add call backs
-class PositionCollector(CallBackBaseClass):
+class PositionCollector(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -106,11 +111,11 @@ def make_callback(self, system, time, current_step: int):
return
-recorded_rod_history = defaultdict(list)
+recorded_rod_history = ea.defaultdict(list)
single_rod_sim.collect_diagnostics(rod1).using(
PositionCollector, step_skip=200, callback_params=recorded_rod_history
)
-recorded_cyl_history = defaultdict(list)
+recorded_cyl_history = ea.defaultdict(list)
single_rod_sim.collect_diagnostics(cylinder).using(
PositionCollector, step_skip=200, callback_params=recorded_cyl_history
)
@@ -119,19 +124,19 @@ def make_callback(self, system, time, current_step: int):
damping_constant = 1e-3
dt = 1e-4
single_rod_sim.dampen(rod1).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
single_rod_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
final_time = 2.0
dl = base_length / n_elem
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, single_rod_sim, final_time, total_steps)
+ea.integrate(timestepper, single_rod_sim, final_time, total_steps)
if PLOT_FIGURE:
plot_video(
diff --git a/examples/RigidBodyCases/rigid_cylinder_rotational_motion_case.py b/examples/RigidBodyCases/rigid_cylinder_rotational_motion_case.py
index 32316656..9a8149b8 100644
--- a/examples/RigidBodyCases/rigid_cylinder_rotational_motion_case.py
+++ b/examples/RigidBodyCases/rigid_cylinder_rotational_motion_case.py
@@ -1,11 +1,13 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
-class RigidCylinderSimulator(BaseSystemCollection, Constraints, Forcing, CallBacks):
+class RigidCylinderSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks
+):
pass
@@ -37,11 +39,11 @@ def rigid_cylinder_rotational_motion_verification(torque=0.0):
base_area = np.pi * base_radius ** 2
density = 1000
- cylinder = Cylinder(start, direction, normal, base_length, base_radius, density)
+ cylinder = ea.Cylinder(start, direction, normal, base_length, base_radius, density)
rigid_cylinder_sim.append(cylinder)
- class PointCoupleToCenter(NoForces):
+ class PointCoupleToCenter(ea.NoForces):
"""
Applies torque on rigid body
"""
@@ -61,13 +63,13 @@ def apply_forces(self, system, time: np.float = 0.0):
)
# Add call backs
- class RigidSphereCallBack(CallBackBaseClass):
+ class RigidSphereCallBack(ea.CallBackBaseClass):
"""
Call back function for continuum snake
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -85,19 +87,19 @@ def make_callback(self, system, time, current_step: int):
return
step_skip = 200
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
rigid_cylinder_sim.collect_diagnostics(cylinder).using(
RigidSphereCallBack, step_skip=step_skip, callback_params=pp_list
)
rigid_cylinder_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.25
dt = 4.0e-5
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, rigid_cylinder_sim, final_time, total_steps)
+ ea.integrate(timestepper, rigid_cylinder_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = cylinder.compute_translational_energy()
diff --git a/examples/RigidBodyCases/rigid_cylinder_translational_motion_case.py b/examples/RigidBodyCases/rigid_cylinder_translational_motion_case.py
index 40496076..c70d3510 100644
--- a/examples/RigidBodyCases/rigid_cylinder_translational_motion_case.py
+++ b/examples/RigidBodyCases/rigid_cylinder_translational_motion_case.py
@@ -1,11 +1,13 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
-class RigidCylinderSimulator(BaseSystemCollection, Constraints, Forcing, CallBacks):
+class RigidCylinderSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks
+):
pass
@@ -37,11 +39,11 @@ def rigid_cylinder_translational_motion_verification(force=0.0):
base_area = np.pi * base_radius ** 2
density = 1000
- cylinder = Cylinder(start, direction, normal, base_length, base_radius, density)
+ cylinder = ea.Cylinder(start, direction, normal, base_length, base_radius, density)
rigid_cylinder_sim.append(cylinder)
- class PointForceToCenter(NoForces):
+ class PointForceToCenter(ea.NoForces):
"""
Applies force on rigid body
"""
@@ -59,13 +61,13 @@ def apply_forces(self, system, time: np.float = 0.0):
)
# Add call backs
- class RigidSphereCallBack(CallBackBaseClass):
+ class RigidSphereCallBack(ea.CallBackBaseClass):
"""
Call back function
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -83,19 +85,19 @@ def make_callback(self, system, time, current_step: int):
return
step_skip = 200
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
rigid_cylinder_sim.collect_diagnostics(cylinder).using(
RigidSphereCallBack, step_skip=step_skip, callback_params=pp_list
)
rigid_cylinder_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.25
dt = 4.0e-5
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, rigid_cylinder_sim, final_time, total_steps)
+ ea.integrate(timestepper, rigid_cylinder_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = cylinder.compute_translational_energy()
diff --git a/examples/RigidBodyCases/rigid_sphere_rotational_motion_case.py b/examples/RigidBodyCases/rigid_sphere_rotational_motion_case.py
index 1e051ede..a4871d87 100644
--- a/examples/RigidBodyCases/rigid_sphere_rotational_motion_case.py
+++ b/examples/RigidBodyCases/rigid_sphere_rotational_motion_case.py
@@ -1,11 +1,13 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
-class RigidSphereSimulator(BaseSystemCollection, Constraints, Forcing, CallBacks):
+class RigidSphereSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks
+):
pass
@@ -28,11 +30,11 @@ def rigid_sphere_rolling_verification(torque=0.0):
# setting up test params
density = 1000
sphere_radius = 0.05
- sphere = Sphere([0.0, sphere_radius, 0.0], sphere_radius, density)
+ sphere = ea.Sphere([0.0, sphere_radius, 0.0], sphere_radius, density)
rigid_sphere_sim.append(sphere)
- class PointCoupleToCenter(NoForces):
+ class PointCoupleToCenter(ea.NoForces):
"""
Applies torque on rigid body
"""
@@ -52,13 +54,13 @@ def apply_forces(self, system, time: np.float = 0.0):
)
# Add call backs
- class RigidSphereCallBack(CallBackBaseClass):
+ class RigidSphereCallBack(ea.CallBackBaseClass):
"""
Call back function
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -76,19 +78,19 @@ def make_callback(self, system, time, current_step: int):
return
step_skip = 200
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
rigid_sphere_sim.collect_diagnostics(sphere).using(
RigidSphereCallBack, step_skip=step_skip, callback_params=pp_list
)
rigid_sphere_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.25 # 11.0 + 0.01)
dt = 4.0e-5
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, rigid_sphere_sim, final_time, total_steps)
+ ea.integrate(timestepper, rigid_sphere_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = sphere.compute_translational_energy()
diff --git a/examples/RigidBodyCases/rigid_sphere_translational_motion_case.py b/examples/RigidBodyCases/rigid_sphere_translational_motion_case.py
index 9c8fdafa..ee1116d2 100644
--- a/examples/RigidBodyCases/rigid_sphere_translational_motion_case.py
+++ b/examples/RigidBodyCases/rigid_sphere_translational_motion_case.py
@@ -1,11 +1,13 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.FrictionValidationCases.friction_validation_postprocessing import (
plot_friction_validation,
)
-class RigidSphereSimulator(BaseSystemCollection, Constraints, Forcing, CallBacks):
+class RigidSphereSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks
+):
pass
@@ -29,11 +31,11 @@ def rigid_sphere_translational_motion_verification(force=0.0):
# setting up test params
density = 1000
sphere_radius = 0.05
- sphere = Sphere([0.0, sphere_radius, 0.0], sphere_radius, density)
+ sphere = ea.Sphere([0.0, sphere_radius, 0.0], sphere_radius, density)
rigid_sphere_sim.append(sphere)
- class PointForceToCenter(NoForces):
+ class PointForceToCenter(ea.NoForces):
"""
Applies force on rigid body
"""
@@ -53,13 +55,13 @@ def apply_forces(self, system, time: np.float = 0.0):
)
# Add call backs
- class RigidSphereCallBack(CallBackBaseClass):
+ class RigidSphereCallBack(ea.CallBackBaseClass):
"""
Call back function
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -77,19 +79,19 @@ def make_callback(self, system, time, current_step: int):
return
step_skip = 200
- pp_list = defaultdict(list)
+ pp_list = ea.defaultdict(list)
rigid_sphere_sim.collect_diagnostics(sphere).using(
RigidSphereCallBack, step_skip=step_skip, callback_params=pp_list
)
rigid_sphere_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
final_time = 0.25
dt = 4.0e-5
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, rigid_sphere_sim, final_time, total_steps)
+ ea.integrate(timestepper, rigid_sphere_sim, final_time, total_steps)
# compute translational and rotational energy
translational_energy = sphere.compute_translational_energy()
diff --git a/examples/RodContactCase/RodRodContact/rod_rod_contact_inclined_validation.py b/examples/RodContactCase/RodRodContact/rod_rod_contact_inclined_validation.py
index dd3d3ee0..90908264 100644
--- a/examples/RodContactCase/RodRodContact/rod_rod_contact_inclined_validation.py
+++ b/examples/RodContactCase/RodRodContact/rod_rod_contact_inclined_validation.py
@@ -1,5 +1,5 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.RodContactCase.post_processing import (
plot_video_with_surface,
plot_velocity,
@@ -7,7 +7,12 @@
class InclinedRodRodContact(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -47,7 +52,7 @@ class InclinedRodRodContact(
n_elem_rod_one = 50
start_rod_one = start + normal * 0.2
-rod_one = CosseratRod.straight_rod(
+rod_one = ea.CosseratRod.straight_rod(
n_elem_rod_one,
start_rod_one,
direction,
@@ -72,7 +77,7 @@ class InclinedRodRodContact(
normal = np.array([0.0, -np.sin(inclination), np.cos(inclination)])
start_rod_two = start
-rod_two = CosseratRod.straight_rod(
+rod_two = ea.CosseratRod.straight_rod(
n_elem_rod_two,
start_rod_two,
direction,
@@ -89,7 +94,7 @@ class InclinedRodRodContact(
# Contact between two rods
inclined_rod_rod_contact_sim.connect(rod_one, rod_two).using(
- ExternalContact, k=1e3, nu=0.0
+ ea.ExternalContact, k=1e3, nu=0.0
)
# add damping
@@ -97,22 +102,22 @@ class InclinedRodRodContact(
# damping_constant = 2e-3
damping_constant = 4e-4
inclined_rod_rod_contact_sim.dampen(rod_one).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
inclined_rod_rod_contact_sim.dampen(rod_two).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
# Add call backs
-class RodCallBack(CallBackBaseClass):
+class RodCallBack(ea.CallBackBaseClass):
""" """
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -138,7 +143,7 @@ def make_callback(self, system, time, current_step: int):
return
-post_processing_dict_rod1 = defaultdict(
+post_processing_dict_rod1 = ea.defaultdict(
list
) # list which collected data will be append
# set the diagnostics for rod and collect data
@@ -148,7 +153,7 @@ def make_callback(self, system, time, current_step: int):
callback_params=post_processing_dict_rod1,
)
-post_processing_dict_rod2 = defaultdict(
+post_processing_dict_rod2 = ea.defaultdict(
list
) # list which collected data will be append
# set the diagnostics for rod and collect data
@@ -161,8 +166,8 @@ def make_callback(self, system, time, current_step: int):
inclined_rod_rod_contact_sim.finalize()
# Do the simulation
-timestepper = PositionVerlet()
-integrate(timestepper, inclined_rod_rod_contact_sim, final_time, total_steps)
+timestepper = ea.PositionVerlet()
+ea.integrate(timestepper, inclined_rod_rod_contact_sim, final_time, total_steps)
# plotting the videos
filename_video = "inclined_rods_contact.mp4"
diff --git a/examples/RodContactCase/RodRodContact/rod_rod_contact_parallel_validation.py b/examples/RodContactCase/RodRodContact/rod_rod_contact_parallel_validation.py
index 68d07633..bbe17fbc 100644
--- a/examples/RodContactCase/RodRodContact/rod_rod_contact_parallel_validation.py
+++ b/examples/RodContactCase/RodRodContact/rod_rod_contact_parallel_validation.py
@@ -1,5 +1,5 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.RodContactCase.post_processing import (
plot_video_with_surface,
plot_velocity,
@@ -7,7 +7,12 @@
class ParallelRodRodContact(
- BaseSystemCollection, Constraints, Connections, Forcing, Damping, CallBacks
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.Damping,
+ ea.CallBacks,
):
pass
@@ -47,7 +52,7 @@ class ParallelRodRodContact(
n_elem_rod_one = 50
start_rod_one = start + normal * 0.2
-rod_one = CosseratRod.straight_rod(
+rod_one = ea.CosseratRod.straight_rod(
n_elem_rod_one,
start_rod_one,
direction,
@@ -69,7 +74,7 @@ class ParallelRodRodContact(
start_rod_two = start
-rod_two = CosseratRod.straight_rod(
+rod_two = ea.CosseratRod.straight_rod(
n_elem_rod_two,
start_rod_two,
direction,
@@ -86,7 +91,7 @@ class ParallelRodRodContact(
# Contact between two rods
parallel_rod_rod_contact_sim.connect(rod_one, rod_two).using(
- ExternalContact, k=1e3, nu=0.001
+ ea.ExternalContact, k=1e3, nu=0.001
)
# add damping
@@ -94,22 +99,22 @@ class ParallelRodRodContact(
# damping_constant = 2e-3
damping_constant = 2e-4
parallel_rod_rod_contact_sim.dampen(rod_one).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
parallel_rod_rod_contact_sim.dampen(rod_two).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=damping_constant,
time_step=dt,
)
# Add call backs
-class RodCallBack(CallBackBaseClass):
+class RodCallBack(ea.CallBackBaseClass):
""" """
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -135,7 +140,7 @@ def make_callback(self, system, time, current_step: int):
return
-post_processing_dict_rod1 = defaultdict(
+post_processing_dict_rod1 = ea.defaultdict(
list
) # list which collected data will be append
# set the diagnostics for rod and collect data
@@ -145,7 +150,7 @@ def make_callback(self, system, time, current_step: int):
callback_params=post_processing_dict_rod1,
)
-post_processing_dict_rod2 = defaultdict(
+post_processing_dict_rod2 = ea.defaultdict(
list
) # list which collected data will be append
# set the diagnostics for rod and collect data
@@ -158,8 +163,8 @@ def make_callback(self, system, time, current_step: int):
parallel_rod_rod_contact_sim.finalize()
# Do the simulation
-timestepper = PositionVerlet()
-integrate(timestepper, parallel_rod_rod_contact_sim, final_time, total_steps)
+timestepper = ea.PositionVerlet()
+ea.integrate(timestepper, parallel_rod_rod_contact_sim, final_time, total_steps)
# plotting the videos
filename_video = "parallel_rods_contact.mp4"
diff --git a/examples/RodContactCase/RodSelfContact/PlectonemesCase/plectoneme_case.py b/examples/RodContactCase/RodSelfContact/PlectonemesCase/plectoneme_case.py
index 761aa994..4280d280 100644
--- a/examples/RodContactCase/RodSelfContact/PlectonemesCase/plectoneme_case.py
+++ b/examples/RodContactCase/RodSelfContact/PlectonemesCase/plectoneme_case.py
@@ -1,5 +1,5 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.RodContactCase.post_processing import (
plot_video_with_surface,
plot_velocity,
@@ -8,12 +8,12 @@
class PlectonemesCase(
- BaseSystemCollection,
- Constraints,
- Connections,
- Forcing,
- CallBacks,
- Damping,
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -53,7 +53,7 @@ class PlectonemesCase(
3,
)
-sherable_rod = CosseratRod.straight_rod(
+sherable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -73,7 +73,7 @@ class PlectonemesCase(
# Add damping
plectonemes_sim.dampen(sherable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
@@ -82,7 +82,7 @@ class PlectonemesCase(
from elastica._rotations import _get_rotation_matrix
-class SelonoidsBC(ConstraintBase):
+class SelonoidsBC(ea.ConstraintBase):
""" """
def __init__(
@@ -167,14 +167,14 @@ def constrain_rates(self, rod, time):
)
# Add self contact to prevent penetration
-plectonemes_sim.connect(sherable_rod, sherable_rod).using(SelfContact, k=1e4, nu=10)
+plectonemes_sim.connect(sherable_rod, sherable_rod).using(ea.SelfContact, k=1e4, nu=10)
# Add callback functions for plotting position of the rod later on
-class RodCallBack(CallBackBaseClass):
+class RodCallBack(ea.CallBackBaseClass):
""" """
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -201,7 +201,7 @@ def make_callback(self, system, time, current_step: int):
return
-post_processing_dict = defaultdict(list) # list which collected data will be append
+post_processing_dict = ea.defaultdict(list) # list which collected data will be append
# set the diagnostics for rod and collect data
plectonemes_sim.collect_diagnostics(sherable_rod).using(
RodCallBack,
@@ -213,8 +213,8 @@ def make_callback(self, system, time, current_step: int):
plectonemes_sim.finalize()
# Run the simulation
-time_stepper = PositionVerlet()
-integrate(time_stepper, plectonemes_sim, final_time, total_steps)
+time_stepper = ea.PositionVerlet()
+ea.integrate(time_stepper, plectonemes_sim, final_time, total_steps)
# plotting the videos
filename_video = "plectonemes.mp4"
@@ -255,9 +255,9 @@ def make_callback(self, system, time, current_step: int):
type_of_additional_segment = "next_tangent"
-total_twist, local_twist = compute_twist(position_history, normal_history)
+total_twist, local_twist = ea.compute_twist(position_history, normal_history)
-total_link = compute_link(
+total_link = ea.compute_link(
position_history,
normal_history,
radius_history,
@@ -265,7 +265,7 @@ def make_callback(self, system, time, current_step: int):
type_of_additional_segment,
)
-total_writhe = compute_writhe(
+total_writhe = ea.compute_writhe(
position_history, segment_length, type_of_additional_segment
)
diff --git a/examples/RodContactCase/RodSelfContact/SolenoidsCase/solenoid_case.py b/examples/RodContactCase/RodSelfContact/SolenoidsCase/solenoid_case.py
index 2c3ec335..7ac594f1 100644
--- a/examples/RodContactCase/RodSelfContact/SolenoidsCase/solenoid_case.py
+++ b/examples/RodContactCase/RodSelfContact/SolenoidsCase/solenoid_case.py
@@ -1,5 +1,5 @@
import numpy as np
-from elastica import *
+import elastica as ea
from examples.RodContactCase.post_processing import (
plot_video_with_surface,
plot_velocity,
@@ -8,7 +8,12 @@
class SolenoidCase(
- BaseSystemCollection, Constraints, Connections, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection,
+ ea.Constraints,
+ ea.Connections,
+ ea.Forcing,
+ ea.CallBacks,
+ ea.Damping,
):
pass
@@ -52,7 +57,7 @@ class SolenoidCase(
F_pulling_scalar = 300
-sherable_rod = CosseratRod.straight_rod(
+sherable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -70,7 +75,7 @@ class SolenoidCase(
# Add damping
solenoid_sim.dampen(sherable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
@@ -79,7 +84,7 @@ class SolenoidCase(
from elastica._rotations import _get_rotation_matrix
-class SelonoidsBC(ConstraintBase):
+class SelonoidsBC(ea.ConstraintBase):
""" """
def __init__(
@@ -164,7 +169,7 @@ def constrain_rates(self, rod, time):
)
solenoid_sim.add_forcing_to(sherable_rod).using(
- EndpointForces,
+ ea.EndpointForces,
np.zeros(
3,
),
@@ -173,14 +178,14 @@ def constrain_rates(self, rod, time):
)
# Add self contact to prevent penetration
-solenoid_sim.connect(sherable_rod, sherable_rod).using(SelfContact, k=1e4, nu=10)
+solenoid_sim.connect(sherable_rod, sherable_rod).using(ea.SelfContact, k=1e4, nu=10)
# Add callback functions for plotting position of the rod later on
-class RodCallBack(CallBackBaseClass):
+class RodCallBack(ea.CallBackBaseClass):
""" """
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -207,7 +212,7 @@ def make_callback(self, system, time, current_step: int):
return
-post_processing_dict = defaultdict(list) # list which collected data will be append
+post_processing_dict = ea.defaultdict(list) # list which collected data will be append
# set the diagnostics for rod and collect data
solenoid_sim.collect_diagnostics(sherable_rod).using(
RodCallBack,
@@ -219,8 +224,8 @@ def make_callback(self, system, time, current_step: int):
solenoid_sim.finalize()
# Run the simulation
-time_stepper = PositionVerlet()
-integrate(time_stepper, solenoid_sim, final_time, total_steps)
+time_stepper = ea.PositionVerlet()
+ea.integrate(time_stepper, solenoid_sim, final_time, total_steps)
# plotting the videos
filename_video = "solenoid.mp4"
@@ -261,9 +266,9 @@ def make_callback(self, system, time, current_step: int):
type_of_additional_segment = "next_tangent"
-total_twist, local_twist = compute_twist(position_history, normal_history)
+total_twist, local_twist = ea.compute_twist(position_history, normal_history)
-total_link = compute_link(
+total_link = ea.compute_link(
position_history,
normal_history,
radius_history,
@@ -271,7 +276,7 @@ def make_callback(self, system, time, current_step: int):
type_of_additional_segment,
)
-total_writhe = compute_writhe(
+total_writhe = ea.compute_writhe(
position_history, segment_length, type_of_additional_segment
)
diff --git a/examples/TimoshenkoBeamCase/convergence_timoshenko.py b/examples/TimoshenkoBeamCase/convergence_timoshenko.py
index 2a896b25..98c16dce 100644
--- a/examples/TimoshenkoBeamCase/convergence_timoshenko.py
+++ b/examples/TimoshenkoBeamCase/convergence_timoshenko.py
@@ -2,7 +2,7 @@
Gazzola et. al. R. Soc. 2018 section 3.4.3 """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.TimoshenkoBeamCase.timoshenko_postprocessing import (
plot_timoshenko,
analytical_shearable,
@@ -10,7 +10,9 @@
from examples.convergence_functions import calculate_error_norm, plot_convergence
-class TimoshenkoBeamSimulator(BaseSystemCollection, Constraints, Forcing, Damping):
+class TimoshenkoBeamSimulator(
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.Damping
+):
pass
@@ -40,7 +42,7 @@ def simulate_timoshenko_beam_with(
poisson_ratio = 99
shear_modulus = E / (poisson_ratio + 1.0)
- shearable_rod = CosseratRod.straight_rod(
+ shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -58,23 +60,23 @@ def simulate_timoshenko_beam_with(
dl = base_length / n_elem
dt = 0.07 * dl
timoshenko_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
timoshenko_sim.constrain(shearable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
end_force = np.array([-15.0, 0.0, 0.0])
timoshenko_sim.add_forcing_to(shearable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2
)
if ADD_UNSHEARABLE_ROD:
# Start into the plane
unshearable_start = np.array([0.0, -1.0, 0.0])
shear_modulus = E / (-0.7 + 1.0)
- unshearable_rod = CosseratRod.straight_rod(
+ unshearable_rod = ea.CosseratRod.straight_rod(
n_elem,
unshearable_start,
direction,
@@ -91,26 +93,28 @@ def simulate_timoshenko_beam_with(
timoshenko_sim.append(unshearable_rod)
# add damping
timoshenko_sim.dampen(unshearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
timoshenko_sim.constrain(unshearable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC,
+ constrained_position_idx=(0,),
+ constrained_director_idx=(0,),
)
timoshenko_sim.add_forcing_to(unshearable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2
)
timoshenko_sim.finalize()
- timestepper = PositionVerlet()
+ timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
dl = base_length / n_elem
dt = 0.01 * dl
total_steps = int(final_time / dt)
print("Total steps", total_steps)
- integrate(timestepper, timoshenko_sim, final_time, total_steps)
+ ea.integrate(timestepper, timoshenko_sim, final_time, total_steps)
if PLOT_FIGURE:
plot_timoshenko(shearable_rod, end_force, SAVE_FIGURE, ADD_UNSHEARABLE_ROD)
diff --git a/examples/TimoshenkoBeamCase/timoshenko.py b/examples/TimoshenkoBeamCase/timoshenko.py
index e459f803..8b9ac44d 100644
--- a/examples/TimoshenkoBeamCase/timoshenko.py
+++ b/examples/TimoshenkoBeamCase/timoshenko.py
@@ -2,12 +2,12 @@
Gazzola et. al. R. Soc. 2018 section 3.4.3 """
import numpy as np
-from elastica import *
+import elastica as ea
from examples.TimoshenkoBeamCase.timoshenko_postprocessing import plot_timoshenko
class TimoshenkoBeamSimulator(
- BaseSystemCollection, Constraints, Forcing, CallBacks, Damping
+ ea.BaseSystemCollection, ea.Constraints, ea.Forcing, ea.CallBacks, ea.Damping
):
pass
@@ -36,7 +36,7 @@ class TimoshenkoBeamSimulator(
poisson_ratio = 99
shear_modulus = E / (poisson_ratio + 1.0)
-shearable_rod = CosseratRod.straight_rod(
+shearable_rod = ea.CosseratRod.straight_rod(
n_elem,
start,
direction,
@@ -54,18 +54,18 @@ class TimoshenkoBeamSimulator(
dl = base_length / n_elem
dt = 0.07 * dl
timoshenko_sim.dampen(shearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
timoshenko_sim.constrain(shearable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
end_force = np.array([-15.0, 0.0, 0.0])
timoshenko_sim.add_forcing_to(shearable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
)
@@ -73,7 +73,7 @@ class TimoshenkoBeamSimulator(
# Start into the plane
unshearable_start = np.array([0.0, -1.0, 0.0])
shear_modulus = E / (-0.7 + 1.0)
- unshearable_rod = CosseratRod.straight_rod(
+ unshearable_rod = ea.CosseratRod.straight_rod(
n_elem,
unshearable_start,
direction,
@@ -91,25 +91,25 @@ class TimoshenkoBeamSimulator(
# add damping
timoshenko_sim.dampen(unshearable_rod).using(
- AnalyticalLinearDamper,
+ ea.AnalyticalLinearDamper,
damping_constant=nu,
time_step=dt,
)
timoshenko_sim.constrain(unshearable_rod).using(
- OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
+ ea.OneEndFixedBC, constrained_position_idx=(0,), constrained_director_idx=(0,)
)
timoshenko_sim.add_forcing_to(unshearable_rod).using(
- EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
+ ea.EndpointForces, 0.0 * end_force, end_force, ramp_up_time=final_time / 2.0
)
# Add call backs
-class VelocityCallBack(CallBackBaseClass):
+class VelocityCallBack(ea.CallBackBaseClass):
"""
Tracks the velocity norms of the rod
"""
def __init__(self, step_skip: int, callback_params: dict):
- CallBackBaseClass.__init__(self)
+ ea.CallBackBaseClass.__init__(self)
self.every = step_skip
self.callback_params = callback_params
@@ -125,18 +125,18 @@ def make_callback(self, system, time, current_step: int):
return
-recorded_history = defaultdict(list)
+recorded_history = ea.defaultdict(list)
timoshenko_sim.collect_diagnostics(shearable_rod).using(
VelocityCallBack, step_skip=500, callback_params=recorded_history
)
timoshenko_sim.finalize()
-timestepper = PositionVerlet()
+timestepper = ea.PositionVerlet()
# timestepper = PEFRL()
total_steps = int(final_time / dt)
print("Total steps", total_steps)
-integrate(timestepper, timoshenko_sim, final_time, total_steps)
+ea.integrate(timestepper, timoshenko_sim, final_time, total_steps)
if PLOT_FIGURE:
plot_timoshenko(shearable_rod, end_force, SAVE_FIGURE, ADD_UNSHEARABLE_ROD)
From c33c98107255c22e90c21dcea89a1b87bf7085d4 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Tue, 4 Apr 2023 12:23:22 +0530
Subject: [PATCH 4/8] Removed wildcards imports from the module
---
elastica/boundary_conditions.py | 8 --------
elastica/callback_functions.py | 1 -
elastica/dissipation.py | 6 +-----
.../generic_system_type_connection.py | 1 -
elastica/experimental/interaction.py | 4 ----
elastica/external_forces.py | 10 +---------
elastica/interaction.py | 6 ------
elastica/joint.py | 2 +-
elastica/restart.py | 2 +-
elastica/rigidbody/cylinder.py | 1 -
elastica/rigidbody/sphere.py | 1 -
elastica/rod/cosserat_rod.py | 1 -
elastica/rod/data_structures.py | 9 +--------
elastica/rod/factory_function.py | 1 -
elastica/rod/knot_theory.py | 7 -------
elastica/transformations.py | 1 -
elastica/utils.py | 2 +-
elastica/wrappers.py | 9 +--------
18 files changed, 7 insertions(+), 65 deletions(-)
diff --git a/elastica/boundary_conditions.py b/elastica/boundary_conditions.py
index 5fbaf4da..b9310658 100644
--- a/elastica/boundary_conditions.py
+++ b/elastica/boundary_conditions.py
@@ -1,12 +1,4 @@
__doc__ = """ Built-in boundary condition implementationss """
-__all__ = [
- "ConstraintBase",
- "FreeBC",
- "OneEndFixedBC",
- "GeneralConstraint",
- "FixedConstraint",
- "HelicalBucklingBC",
-]
import warnings
from typing import Optional, Type, Union
diff --git a/elastica/callback_functions.py b/elastica/callback_functions.py
index 09f5b8aa..ab865dfd 100644
--- a/elastica/callback_functions.py
+++ b/elastica/callback_functions.py
@@ -1,5 +1,4 @@
__doc__ = """ Module contains callback classes to save simulation data for rod-like objects """
-__all__ = ["CallBackBaseClass", "MyCallBack", "ExportCallBack"]
import os
import sys
diff --git a/elastica/dissipation.py b/elastica/dissipation.py
index 5004d7d1..f52cdc5d 100644
--- a/elastica/dissipation.py
+++ b/elastica/dissipation.py
@@ -3,11 +3,7 @@
Built in damper module implementations
"""
-__all__ = [
- "DamperBase",
- "AnalyticalLinearDamper",
- "LaplaceDissipationFilter",
-]
+
from abc import ABC, abstractmethod
from elastica.typing import RodType, SystemType
diff --git a/elastica/experimental/connection_contact_joint/generic_system_type_connection.py b/elastica/experimental/connection_contact_joint/generic_system_type_connection.py
index d4a0e235..e2628ae2 100644
--- a/elastica/experimental/connection_contact_joint/generic_system_type_connection.py
+++ b/elastica/experimental/connection_contact_joint/generic_system_type_connection.py
@@ -1,7 +1,6 @@
__doc__ = (
""" Module containing joint classes to connect rods and rigid bodies together. """
)
-__all__ = ["GenericSystemTypeFreeJoint", "GenericSystemTypeFixedJoint"]
from elastica.joint import FreeJoint, FixedJoint
from elastica.typing import SystemType
from elastica.utils import Tolerance, MaxDimension
diff --git a/elastica/experimental/interaction.py b/elastica/experimental/interaction.py
index c603e016..5e41f784 100644
--- a/elastica/experimental/interaction.py
+++ b/elastica/experimental/interaction.py
@@ -1,12 +1,8 @@
__doc__ = """ Experimental interaction implementation."""
-__all__ = [
- "AnisotropicFrictionalPlaneRigidBody",
-]
import numpy as np
from elastica.external_forces import NoForces
-from elastica.interaction import *
from elastica.interaction import (
find_slipping_elements,
apply_normal_force_numba_rigid_body,
diff --git a/elastica/external_forces.py b/elastica/external_forces.py
index 68604fd9..e7edc668 100644
--- a/elastica/external_forces.py
+++ b/elastica/external_forces.py
@@ -1,13 +1,5 @@
__doc__ = """ Numba implementation module for boundary condition implementations that apply external forces to the rod."""
-__all__ = [
- "NoForces",
- "GravityForces",
- "EndpointForces",
- "UniformTorques",
- "UniformForces",
- "MuscleTorques",
- "EndpointForcesSinusoidal",
-]
+
import numpy as np
from elastica._linalg import _batch_matvec
diff --git a/elastica/interaction.py b/elastica/interaction.py
index 587598dd..a0da78ff 100644
--- a/elastica/interaction.py
+++ b/elastica/interaction.py
@@ -1,10 +1,4 @@
__doc__ = """ Numba implementation module containing interactions between a rod and its environment."""
-__all__ = [
- "AnisotropicFrictionalPlane",
- "InteractionPlane",
- "InteractionPlaneRigidBody",
- "SlenderBodyTheory",
-]
import numpy as np
diff --git a/elastica/joint.py b/elastica/joint.py
index 4db75f97..8cc9bd85 100644
--- a/elastica/joint.py
+++ b/elastica/joint.py
@@ -1,5 +1,5 @@
__doc__ = """ Module containing joint classes to connect multiple rods together. """
-__all__ = ["FreeJoint", "HingeJoint", "FixedJoint", "ExternalContact", "SelfContact"]
+
from elastica._linalg import _batch_product_k_ik_to_ik
from elastica._rotations import _inv_rotate
from math import sqrt
diff --git a/elastica/restart.py b/elastica/restart.py
index 0ca4c931..7e97cb83 100644
--- a/elastica/restart.py
+++ b/elastica/restart.py
@@ -1,5 +1,5 @@
__doc__ = """Generate or load restart file implementations."""
-__all__ = ["save_state", "load_state"]
+
import numpy as np
import os
from itertools import groupby
diff --git a/elastica/rigidbody/cylinder.py b/elastica/rigidbody/cylinder.py
index fe095f2f..f9078d49 100644
--- a/elastica/rigidbody/cylinder.py
+++ b/elastica/rigidbody/cylinder.py
@@ -1,5 +1,4 @@
__doc__ = """"""
-__all__ = ["Cylinder"]
import numpy as np
diff --git a/elastica/rigidbody/sphere.py b/elastica/rigidbody/sphere.py
index dfce60e1..a02d4259 100644
--- a/elastica/rigidbody/sphere.py
+++ b/elastica/rigidbody/sphere.py
@@ -1,5 +1,4 @@
__doc__ = """"""
-__all__ = ["Sphere"]
import numpy as np
diff --git a/elastica/rod/cosserat_rod.py b/elastica/rod/cosserat_rod.py
index 6af88e6b..5b8c8fcd 100644
--- a/elastica/rod/cosserat_rod.py
+++ b/elastica/rod/cosserat_rod.py
@@ -1,5 +1,4 @@
__doc__ = """ Rod classes and implementation details """
-__all__ = ["CosseratRod"]
import typing
diff --git a/elastica/rod/data_structures.py b/elastica/rod/data_structures.py
index 705c0971..0e199b97 100644
--- a/elastica/rod/data_structures.py
+++ b/elastica/rod/data_structures.py
@@ -1,12 +1,5 @@
__doc__ = "Data structure wrapper for rod components"
-__all__ = [
- "_RodSymplecticStepperMixin",
- "_bootstrap_from_data",
- "_State",
- "_DerivativeState",
- "_KinematicState",
- "_DynamicState",
-]
+
import numpy as np
import numba
from numba import njit
diff --git a/elastica/rod/factory_function.py b/elastica/rod/factory_function.py
index 871d8de8..e259f62f 100644
--- a/elastica/rod/factory_function.py
+++ b/elastica/rod/factory_function.py
@@ -1,5 +1,4 @@
__doc__ = """ Factory function to allocate variables for Cosserat Rod"""
-__all__ = ["allocate"]
from typing import Optional, Tuple
import logging
import numpy as np
diff --git a/elastica/rod/knot_theory.py b/elastica/rod/knot_theory.py
index f31d2abe..e9688423 100644
--- a/elastica/rod/knot_theory.py
+++ b/elastica/rod/knot_theory.py
@@ -9,13 +9,6 @@
The details discussion is included in `N Charles et. al. PRL (2019) `_.
"""
-__all__ = [
- "KnotTheoryCompatibleProtocol",
- "KnotTheory",
- "compute_twist",
- "compute_link",
- "compute_writhe",
-]
import sys
diff --git a/elastica/transformations.py b/elastica/transformations.py
index 142b9f5d..882094c4 100644
--- a/elastica/transformations.py
+++ b/elastica/transformations.py
@@ -1,5 +1,4 @@
__doc__ = """ Rotation interface functions"""
-__all__ = ["skew_symmetrize", "inv_skew_symmetrize", "rotate"]
import numpy as np
diff --git a/elastica/utils.py b/elastica/utils.py
index 57fb24a1..5d84741c 100644
--- a/elastica/utils.py
+++ b/elastica/utils.py
@@ -1,6 +1,6 @@
""" Handy utilities
"""
-__all__ = ["isqrt"]
+
import functools
import numpy as np
from numpy import finfo, float64
diff --git a/elastica/wrappers.py b/elastica/wrappers.py
index af8940f2..e6ef6d51 100644
--- a/elastica/wrappers.py
+++ b/elastica/wrappers.py
@@ -1,13 +1,6 @@
import warnings
-__all__ = [
- "BaseSystemCollection",
- "Connections",
- "Constraints",
- "Forcing",
- "CallBacks",
- "Damping",
-]
+
from elastica.modules.base_system import BaseSystemCollection
from elastica.modules.connections import Connections
from elastica.modules.constraints import Constraints
From 72013103f9e8ce6731765ea1735067079b3a9f38 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Tue, 4 Apr 2023 22:25:50 +0530
Subject: [PATCH 5/8] update
---
elastica/__init__.py | 15 ---------------
elastica/wrappers.py | 7 -------
2 files changed, 22 deletions(-)
diff --git a/elastica/__init__.py b/elastica/__init__.py
index 27f5138a..e69de29b 100644
--- a/elastica/__init__.py
+++ b/elastica/__init__.py
@@ -1,15 +0,0 @@
-from collections import defaultdict
-from elastica.modules import *
-from elastica.rod.cosserat_rod import *
-from elastica.rod.knot_theory import *
-from elastica.rigidbody import *
-from elastica.boundary_conditions import *
-from elastica.external_forces import *
-from elastica.callback_functions import *
-from elastica.dissipation import *
-from elastica.interaction import *
-from elastica.joint import *
-from elastica.timestepper import *
-from elastica.restart import *
-from elastica.reset_functions_for_block_structure import *
-from elastica.typing import *
diff --git a/elastica/wrappers.py b/elastica/wrappers.py
index e6ef6d51..bfdd3cf1 100644
--- a/elastica/wrappers.py
+++ b/elastica/wrappers.py
@@ -1,13 +1,6 @@
import warnings
-from elastica.modules.base_system import BaseSystemCollection
-from elastica.modules.connections import Connections
-from elastica.modules.constraints import Constraints
-from elastica.modules.forcing import Forcing
-from elastica.modules.callbacks import CallBacks
-from elastica.modules.damping import Damping
-
warnings.warn(
"elastica.wrappers is refactored to elastica.modules in version 0.3.0.",
DeprecationWarning,
From d943f1df84da066706138902fe1b009668c2af02 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Thu, 6 Apr 2023 00:41:02 +0530
Subject: [PATCH 6/8] removed all wildcards import
---
elastica/__init__.py | 73 +++++++++++++++++++
elastica/memory_block/__init__.py | 9 +--
elastica/modules/__init__.py | 8 --
.../__init__.py | 5 --
elastica/rigidbody/__init__.py | 1 -
elastica/rod/__init__.py | 2 +-
elastica/timestepper/__init__.py | 9 +--
7 files changed, 77 insertions(+), 30 deletions(-)
diff --git a/elastica/__init__.py b/elastica/__init__.py
index e69de29b..7622bf26 100644
--- a/elastica/__init__.py
+++ b/elastica/__init__.py
@@ -0,0 +1,73 @@
+from collections import defaultdict
+from elastica.rod.knot_theory import KnotTheory, KnotTheoryCompatibleProtocol
+from elastica.rod.rod_base import RodBase
+from elastica.rod.cosserat_rod import CosseratRod
+from elastica.rigidbody.rigid_body import RigidBodyBase
+from elastica.rigidbody.cylinder import Cylinder
+from elastica.rigidbody.sphere import Sphere
+from elastica.boundary_conditions import (
+ ConstraintBase,
+ FreeBC,
+ OneEndFixedBC,
+ GeneralConstraint,
+ FixedConstraint,
+ HelicalBucklingBC,
+ FreeRod,
+ OneEndFixedRod,
+)
+from elastica.external_forces import (
+ NoForces,
+ EndpointForces,
+ GravityForces,
+ UniformForces,
+ UniformTorques,
+ MuscleTorques,
+ EndpointForcesSinusoidal,
+)
+from elastica.interaction import (
+ AnisotropicFrictionalPlane,
+ InteractionPlane,
+ SlenderBodyTheory,
+)
+from elastica.joint import (
+ FreeJoint,
+ ExternalContact,
+ FixedJoint,
+ HingeJoint,
+ SelfContact,
+)
+from elastica.callback_functions import CallBackBaseClass, ExportCallBack, MyCallBack
+from elastica.dissipation import (
+ DamperBase,
+ AnalyticalLinearDamper,
+ LaplaceDissipationFilter,
+)
+from elastica.modules.base_system import BaseSystemCollection
+from elastica.modules.callbacks import CallBacks
+from elastica.modules.connections import Connections
+from elastica.modules.constraints import Constraints
+from elastica.modules.forcing import Forcing
+from elastica.modules.damping import Damping
+from elastica.transformations import inv_skew_symmetrize
+from elastica.transformations import rotate
+from elastica._calculus import (
+ position_difference_kernel,
+ position_average,
+ quadrature_kernel,
+ difference_kernel,
+ quadrature_kernel_for_block_structure,
+ difference_kernel_for_block_structure,
+)
+from elastica._linalg import levi_civita_tensor
+from elastica.utils import isqrt
+from elastica.typing import RodType, SystemType
+from elastica.timestepper import (
+ integrate,
+ PositionVerlet,
+ PEFRL,
+ RungeKutta4,
+ EulerForward,
+ extend_stepper_interface,
+)
+from elastica.memory_block.memory_block_rigid_body import MemoryBlockRigidBody
+from elastica.memory_block.memory_block_rod import MemoryBlockCosseratRod
diff --git a/elastica/memory_block/__init__.py b/elastica/memory_block/__init__.py
index 4d89d9d7..e14c5108 100644
--- a/elastica/memory_block/__init__.py
+++ b/elastica/memory_block/__init__.py
@@ -1,7 +1,2 @@
-__all__ = [
- "MemoryBlockCosseratRod",
- "MemoryBlockRigidBody",
-]
-
-from elastica.memory_block.memory_block_rod import MemoryBlockCosseratRod
-from elastica.memory_block.memory_block_rigid_body import MemoryBlockRigidBody
+from .memory_block_rigid_body import MemoryBlockRigidBody
+from .memory_block_rod import MemoryBlockCosseratRod
diff --git a/elastica/modules/__init__.py b/elastica/modules/__init__.py
index 6dec136a..889bf69f 100644
--- a/elastica/modules/__init__.py
+++ b/elastica/modules/__init__.py
@@ -4,14 +4,6 @@
"""
-__all__ = [
- "BaseSystemCollection",
- "Connections",
- "Constraints",
- "Forcing",
- "CallBacks",
- "Damping",
-]
from .base_system import BaseSystemCollection
from .connections import Connections
from .constraints import Constraints
diff --git a/elastica/reset_functions_for_block_structure/__init__.py b/elastica/reset_functions_for_block_structure/__init__.py
index dc00ff55..5ef94f94 100644
--- a/elastica/reset_functions_for_block_structure/__init__.py
+++ b/elastica/reset_functions_for_block_structure/__init__.py
@@ -1,8 +1,3 @@
-__all__ = [
- "_reset_scalar_ghost",
- "_reset_vector_ghost",
-]
-
from elastica.reset_functions_for_block_structure._reset_ghost_vector_or_scalar import (
_reset_scalar_ghost,
_reset_vector_ghost,
diff --git a/elastica/rigidbody/__init__.py b/elastica/rigidbody/__init__.py
index f72edff3..732577df 100644
--- a/elastica/rigidbody/__init__.py
+++ b/elastica/rigidbody/__init__.py
@@ -1,4 +1,3 @@
-__all__ = ["RigidBodyBase", "Cylinder", "Sphere"]
from .rigid_body import RigidBodyBase
from .cylinder import Cylinder
from .sphere import Sphere
diff --git a/elastica/rod/__init__.py b/elastica/rod/__init__.py
index 08263853..6dca5160 100644
--- a/elastica/rod/__init__.py
+++ b/elastica/rod/__init__.py
@@ -1,6 +1,6 @@
__doc__ = """Rod classes and its data structures """
-from elastica.rod.knot_theory import *
+from elastica.rod.knot_theory import KnotTheory
from elastica.rod.data_structures import *
from elastica.rod.rod_base import RodBase
diff --git a/elastica/timestepper/__init__.py b/elastica/timestepper/__init__.py
index 5e275ec5..3efa466e 100644
--- a/elastica/timestepper/__init__.py
+++ b/elastica/timestepper/__init__.py
@@ -1,12 +1,5 @@
__doc__ = """Timestepping utilities to be used with Rod and RigidBody classes"""
-__all__ = [
- "integrate",
- "PositionVerlet",
- "PEFRL",
- "RungeKutta4",
- "EulerForward",
- "extend_stepper_interface",
-]
+
import numpy as np
from tqdm import tqdm
From 0e875d9151e8f94cd33bfab93ca28bf9fafdba95 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Thu, 6 Apr 2023 01:26:03 +0530
Subject: [PATCH 7/8] update
---
elastica/rod/__init__.py | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/elastica/rod/__init__.py b/elastica/rod/__init__.py
index 6dca5160..b9285b3c 100644
--- a/elastica/rod/__init__.py
+++ b/elastica/rod/__init__.py
@@ -2,5 +2,11 @@
from elastica.rod.knot_theory import KnotTheory
-from elastica.rod.data_structures import *
from elastica.rod.rod_base import RodBase
+from elastica.rod.data_structures import (
+ _RodSymplecticStepperMixin,
+ _State,
+ _DerivativeState,
+ _KinematicState,
+ _DynamicState,
+)
From 530387bef6d2d0f44dede15a31b92e9b74141bf8 Mon Sep 17 00:00:00 2001
From: AsadNizami
Date: Fri, 7 Apr 2023 02:57:21 +0530
Subject: [PATCH 8/8] bringing back __all__
---
elastica/wrappers.py | 16 ++++++++++++++++
1 file changed, 16 insertions(+)
diff --git a/elastica/wrappers.py b/elastica/wrappers.py
index bfdd3cf1..fa3990f8 100644
--- a/elastica/wrappers.py
+++ b/elastica/wrappers.py
@@ -1,5 +1,21 @@
import warnings
+__all__ = [
+ "BaseSystemCollection",
+ "Connections",
+ "Constraints",
+ "Forcing",
+ "CallBacks",
+ "Damping",
+]
+
+from elastica.modules.base_system import BaseSystemCollection
+from elastica.modules.connections import Connections
+from elastica.modules.constraints import Constraints
+from elastica.modules.forcing import Forcing
+from elastica.modules.callbacks import CallBacks
+from elastica.modules.damping import Damping
+
warnings.warn(
"elastica.wrappers is refactored to elastica.modules in version 0.3.0.",