-
Notifications
You must be signed in to change notification settings - Fork 112
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #404 from skim0119/wip/401
Use OperatorGroup for constrain and callback features
- Loading branch information
Showing
26 changed files
with
464 additions
and
355 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
from typing import Protocol | ||
|
||
from elastica.typing import StepType, StateType | ||
from elastica.systems.protocol import SystemProtocol, SlenderBodyGeometryProtocol | ||
from elastica.timestepper.protocol import StepperProtocol | ||
|
||
import numpy as np | ||
|
||
|
||
class ExplicitSystemProtocol(SystemProtocol, SlenderBodyGeometryProtocol, Protocol): | ||
# TODO: Temporarily made to handle explicit stepper. | ||
# Need to be refactored as the explicit stepper is further developed. | ||
def __call__(self, time: np.float64, dt: np.float64) -> np.float64: ... | ||
@property | ||
def state(self) -> StateType: ... | ||
@state.setter | ||
def state(self, state: StateType) -> None: ... | ||
@property | ||
def n_elems(self) -> int: ... | ||
|
||
|
||
class MemoryProtocol(Protocol): | ||
@property | ||
def initial_state(self) -> bool: ... | ||
|
||
|
||
class ExplicitStepperProtocol(StepperProtocol, Protocol): | ||
"""symplectic stepper protocol.""" | ||
|
||
def get_stages(self) -> list[StepType]: ... | ||
|
||
def get_updates(self) -> list[StepType]: ... | ||
|
||
|
||
# class _LinearExponentialIntegratorMixin: | ||
# """ | ||
# Linear Exponential integrator mixin wrapper. | ||
# """ | ||
# | ||
# def __init__(self): | ||
# pass | ||
# | ||
# def _do_stage(self, System, Memory, time, dt): | ||
# # TODO : Make more general, system should not be calculating what the state | ||
# # transition matrix directly is, but rather it should just give | ||
# Memory.linear_operator = System.get_linear_state_transition_operator(time, dt) | ||
# | ||
# def _do_update(self, System, Memory, time, dt): | ||
# # FIXME What's the right formula when doing update? | ||
# # System.linearly_evolving_state = _batch_matmul( | ||
# # System.linearly_evolving_state, | ||
# # Memory.linear_operator | ||
# # ) | ||
# System.linearly_evolving_state = np.einsum( | ||
# "ijk,ljk->ilk", System.linearly_evolving_state, Memory.linear_operator | ||
# ) | ||
# return time + dt | ||
# | ||
# def _first_prefactor(self, dt): | ||
# """Prefactor call to satisfy interface of SymplecticStepper. Should never | ||
# be used in actual code. | ||
# | ||
# Parameters | ||
# ---------- | ||
# dt : the time step of simulation | ||
# | ||
# Raises | ||
# ------ | ||
# RuntimeError | ||
# """ | ||
# raise RuntimeError( | ||
# "Symplectic prefactor of LinearExponentialIntegrator should not be called!" | ||
# ) | ||
# | ||
# # Code repeat! | ||
# # Easy to avoid, but keep for performance. | ||
# def _do_one_step(self, System, time, prefac): | ||
# System.linearly_evolving_state = np.einsum( | ||
# "ijk,ljk->ilk", | ||
# System.linearly_evolving_state, | ||
# System.get_linear_state_transition_operator(time, prefac), | ||
# ) | ||
# return ( | ||
# time # TODO fix hack that treats time separately here. Shuold be time + dt | ||
# ) | ||
# # return time + dt |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.