openscvx 0.4.1.dev155__tar.gz → 0.4.1.dev156__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {openscvx-0.4.1.dev155/openscvx.egg-info → openscvx-0.4.1.dev156}/PKG-INFO +1 -1
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car_waypoint_stl.py +1 -1
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/dr_vp_nodal.py +2 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/dr_vp_polytope.py +1 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/logo.py +1 -0
- openscvx-0.4.1.dev156/examples/spacecraft/halo_orbit.py +210 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/spacecraft/proxops_cw.py +1 -1
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/__init__.py +8 -1
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/_version.py +3 -3
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/__init__.py +7 -2
- openscvx-0.4.1.dev156/openscvx/discretization/discretize_linearize.py +369 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/problem.py +2 -2
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156/openscvx.egg-info}/PKG-INFO +1 -1
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx.egg-info/SOURCES.txt +2 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/assets/logo.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/release-drafter.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/_docs.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/branch-name.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/docs.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/lint.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/nightly.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/release-drafter.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/release.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/tests-integration.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.github/workflows/tests-unit.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/.gitignore +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/CONTRIBUTING.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/LICENSE +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/README.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/constraint_reformulation.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/control_parameterization.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/discretization.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/ocp.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/scvx.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/Foundations/time_dilation.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UnderTheHood/lowering_architecture.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UnderTheHood/vectorization_and_vmapping.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/00_introduction.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/01_hello_world_brachistochrone.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/02_drone_racing_constraints.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/03_obstacle_avoidance_vmap.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/04_viewpoint_constraints.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/05_visualization.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/06_logic.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/07_lie.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/UsersGuide/08_mpcc.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/favicon.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/ct-scvx_dark.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/ct-scvx_light.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/ctcs_dark.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/ctcs_light.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/problem_class_dark.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/images/problem_class_light.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/assets/logo.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/citation.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/examples.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/getting-started.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/index.md +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/docs/javascripts/mathjax.js +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/abstract/brachistochrone.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/abstract/impulsive.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/abstract/stl_integer_variable.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/abstract/stl_or.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/arm/three_link_arm.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car_disjoint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car_obstacle_conditional.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car_obstacle_stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/car/dubins_car_stl_or.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/cinema_vp.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/dr_double_integrator.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/dr_vp.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/drone_racing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/logo_utils/acl_logo.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/logo_utils/svg_path_utils.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/obstacle_avoidance.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/obstacle_avoidance_nodal.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/drone/obstacle_avoidance_vmap.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/mpc/double_integrator_discrete.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/mpc/double_integrator_drone_racing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/mpc/dubins_car_circle_analytical.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/mpc/dubins_car_circle_discrete.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/mpc/realtime_double_integrator_drone_racing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/plotting.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/plotting_viser.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/base_problems/cinema_vp_realtime_base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/base_problems/drone_racing_realtime_base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/base_problems/obstacle_avoidance_realtime_base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/cinema_vp_realtime.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/drone_racing_realtime.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/dubins_car_realtime.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/realtime/obstacle_avoidance_realtime.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/rocket/3DoF_pdg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/examples/spacecraft/hohmann_transfer.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/ctlos_cine.gif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/ctlos_dr.gif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/dtlos_cine.gif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/dtlos_dr.gif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/openscvx_logo.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/openscvx_logo_square.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/oscvx_structure_full_dark.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/figures/video_preview.png +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/1-background.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/1-background@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/1-background@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/1-background@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/1-background@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/2-mars.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/2-mars@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/2-mars@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/2-mars@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/2-mars@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/3-moon.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/3-moon@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/3-moon@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/3-moon@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/3-moon@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/4-sat1.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/4-sat1@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/4-sat1@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/4-sat1@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/4-sat1@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/5-space.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/5-space@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/5-space@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/5-space@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/5-space@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/6-earth.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/6-earth@1x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/6-earth@2x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/6-earth@3x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/images/layers/6-earth@4x.avif +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/javascripts/parallax.js +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/logo.svg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/stylesheets/custom.css +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/assets/stylesheets/parallax.css +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/home.html +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/main.html +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/partials/parallax/hero.html +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/material/overrides/partials/parallax.html +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/mkdocs.yml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/__main__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/augmented_lagrangian.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/constant_proximal_weight.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/optimization_results.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/penalized_trust_region.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/algorithms/ramp_proximal_weight.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/config.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/linearize_discretize.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/linearize_discretize_sparse.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/sparse_utils/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/sparse_utils/bcoo_helpers.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/discretization/sparse_utils/sparse_jacobian.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/expert/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/expert/byof.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/expert/lowering.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/expert/validation.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/init/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/init/interpolation.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/integrators/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/integrators/diffrax.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/integrators/runge_kutta.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/loader.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/cvxpy_constraints.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/cvxpy_variables.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/dynamics.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/jax_constraints.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/parameters.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/problem.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/lowered/unified.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/plotting.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/scp_iteration.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/animated.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/orbits.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/plotly_integration.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/primitives.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/scp.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/plotting/viser/server.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/propagation/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/propagation/post_processing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/propagation/propagation.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/solvers/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/solvers/base.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/solvers/ptr_solver.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/augmentation.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/builder.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/constraint_set.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/arithmetic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/control.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/expr.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/lie/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/lie/adjoint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/lie/se3.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/lie/so3.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/spatial.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/state.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/stljax.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/time.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/variable.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/expr/vmap.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/hashing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lower.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/_lowerer.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/_registry.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/arithmetic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/control.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/expr.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/cvxpy/state.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/_lowerer.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/_registry.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/arithmetic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/control.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/expr.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/lie.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/spatial.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/state.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/stljax.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/lowerers/jax/vmap.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/_registry.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/lie.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/parser.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/spatial.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/stljax.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/parser/tokenizer.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/preprocessing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/problem.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/sparsity.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/symbolic/unified.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/cache.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/caching.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/printing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/profiling.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx/utils/utils.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx.egg-info/dependency_links.txt +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx.egg-info/entry_points.txt +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx.egg-info/requires.txt +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/openscvx.egg-info/top_level.txt +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/pyproject.toml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/scripts/gen_example_pages.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/scripts/gen_ref_pages.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/setup.cfg +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/brachistochrone_analytical.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/expr/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/expr/test_gmsr.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/fixtures/brachistochrone.json +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/fixtures/brachistochrone.yaml +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/hohmann_analytical.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_arithmetic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_expr.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_lie.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_node_reference.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_parameters.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_scaling.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_spatial.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_variable.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/expr/test_vmap.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/__init__.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_array.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_constraint.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_lie.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_linalg.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_load.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_logic.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_math.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_parser.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_spatial.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_stl.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_tokenizer.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/parser/test_vmap.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_augmentation.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_hashing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_lower_cvxpy.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_lower_jax.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_preprocessing.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_sparsity.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/symbolic/test_unified.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_autotuning.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_brachistochrone.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_cvxpygen_optional.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_discretization.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_examples.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_expert.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_impulsive.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_init.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_integrators.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_loader.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_optimization_results.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_plotting.py +0 -0
- {openscvx-0.4.1.dev155 → openscvx-0.4.1.dev156}/tests/test_propagation.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: openscvx
|
|
3
|
-
Version: 0.4.1.
|
|
3
|
+
Version: 0.4.1.dev156
|
|
4
4
|
Summary: A general Python-based successive convexification implementation which uses a JAX backend.
|
|
5
5
|
Author-email: Chris Hayner and Griffin Norris <haynec@uw.edu>
|
|
6
6
|
License: Apache Software License
|
|
@@ -85,7 +85,7 @@ safety_region = ox.linalg.Norm(position - obs_center) <= 1.6
|
|
|
85
85
|
# Globally the control bound is 10.0; inside the waypoint window we restrict to 1.0.
|
|
86
86
|
slow_speed_in_waypoint = ox.linalg.Norm(speed) <= 1.0
|
|
87
87
|
|
|
88
|
-
speed_constraint = ox.stl.IfThen(safety_region, slow_speed_in_waypoint
|
|
88
|
+
speed_constraint = ox.stl.IfThen(safety_region, slow_speed_in_waypoint)
|
|
89
89
|
|
|
90
90
|
constraints.append(
|
|
91
91
|
speed_constraint.over(
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
"""Southern L2 Halo orbit initial conditions definition
|
|
2
|
+
|
|
3
|
+
- Earth-Moon CR3BP rotating-frame dynamics
|
|
4
|
+
- Symmetry structure at initial node: y0 = vx0 = vz0 = 0
|
|
5
|
+
- Free design variables at initial node: x0, z0, vy0
|
|
6
|
+
- Terminal objective to drive (y, vx, vz) toward zero after n revolutions
|
|
7
|
+
|
|
8
|
+
"""
|
|
9
|
+
|
|
10
|
+
import os
|
|
11
|
+
import sys
|
|
12
|
+
|
|
13
|
+
import jax
|
|
14
|
+
import jax.numpy as jnp
|
|
15
|
+
import numpy as np
|
|
16
|
+
|
|
17
|
+
# Add grandparent directory to path to import openscvx without installation.
|
|
18
|
+
current_dir = os.path.dirname(os.path.abspath(__file__))
|
|
19
|
+
grandparent_dir = os.path.dirname(os.path.dirname(current_dir))
|
|
20
|
+
sys.path.append(grandparent_dir)
|
|
21
|
+
|
|
22
|
+
import openscvx as ox
|
|
23
|
+
from openscvx import Problem
|
|
24
|
+
from openscvx.algorithms import OptimizationResults
|
|
25
|
+
from openscvx.integrators import solve_ivp_diffrax
|
|
26
|
+
from openscvx.plotting import plot_projections_2d
|
|
27
|
+
from openscvx.symbolic.lower import lower_to_jax
|
|
28
|
+
|
|
29
|
+
# Use float64 in JAX for high-accuracy propagation.
|
|
30
|
+
jax.config.update("jax_enable_x64", True)
|
|
31
|
+
|
|
32
|
+
r0 = np.array([0.98736, 0.0, 0.00877])
|
|
33
|
+
v0 = np.array([0.0, 1.63446, 0.0])
|
|
34
|
+
x0_seed = np.concatenate([r0, v0])
|
|
35
|
+
|
|
36
|
+
# Earth-Moon mass ratio used in normalized CR3BP
|
|
37
|
+
mu_earth = 398600.4354360959
|
|
38
|
+
mu_moon = 4902.800066163796
|
|
39
|
+
mu = mu_moon / (mu_earth + mu_moon)
|
|
40
|
+
t_f = 1.522
|
|
41
|
+
t_opt = 6.0 * t_f # 6 revolutions
|
|
42
|
+
n_nodes = 2
|
|
43
|
+
integration_tol = 1e-10
|
|
44
|
+
|
|
45
|
+
# Build symbolic CR3BP model once and reuse it for both optimization and propagation.
|
|
46
|
+
position = ox.State("position", shape=(3,))
|
|
47
|
+
velocity = ox.State("velocity", shape=(3,))
|
|
48
|
+
|
|
49
|
+
# Assign slices for standalone lowering/evaluation on [x, y, z, vx, vy, vz].
|
|
50
|
+
position._slice = slice(0, 3)
|
|
51
|
+
velocity._slice = slice(3, 6)
|
|
52
|
+
|
|
53
|
+
r1x = position[0] + mu
|
|
54
|
+
r1y = position[1]
|
|
55
|
+
r1z = position[2]
|
|
56
|
+
r2x = position[0] - (1.0 - mu)
|
|
57
|
+
r2y = position[1]
|
|
58
|
+
r2z = position[2]
|
|
59
|
+
|
|
60
|
+
d1 = ox.Sqrt(r1x**2 + r1y**2 + r1z**2)
|
|
61
|
+
d2 = ox.Sqrt(r2x**2 + r2y**2 + r2z**2)
|
|
62
|
+
|
|
63
|
+
ax = 2.0 * velocity[1] + position[0] - (1.0 - mu) * r1x / d1**3 - mu * r2x / d2**3
|
|
64
|
+
ay = -2.0 * velocity[0] + position[1] - (1.0 - mu) * r1y / d1**3 - mu * r2y / d2**3
|
|
65
|
+
az = -(1.0 - mu) * r1z / d1**3 - mu * r2z / d2**3
|
|
66
|
+
|
|
67
|
+
velocity_dot = ox.Concat(ax, ay, az)
|
|
68
|
+
dynamics = {
|
|
69
|
+
"position": velocity,
|
|
70
|
+
"velocity": velocity_dot,
|
|
71
|
+
}
|
|
72
|
+
cr3bp_rhs = lower_to_jax(ox.Concat(velocity, velocity_dot))
|
|
73
|
+
|
|
74
|
+
# Dense high-accuracy propagation used only to build a reliable guess and for plotting.
|
|
75
|
+
guess_dense = np.asarray(
|
|
76
|
+
solve_ivp_diffrax(
|
|
77
|
+
lambda t, x: cr3bp_rhs(x, jnp.zeros((0,), dtype=x.dtype), 0, {}),
|
|
78
|
+
tau_final=t_opt,
|
|
79
|
+
y_0=jnp.asarray(x0_seed, dtype=jnp.float64),
|
|
80
|
+
args=(),
|
|
81
|
+
tau_0=0.0,
|
|
82
|
+
num_substeps=1000,
|
|
83
|
+
solver_name="Dopri8",
|
|
84
|
+
rtol=integration_tol,
|
|
85
|
+
atol=integration_tol,
|
|
86
|
+
),
|
|
87
|
+
dtype=float,
|
|
88
|
+
)
|
|
89
|
+
|
|
90
|
+
# Keep optimization decision vector at two nodes only: initial and final.
|
|
91
|
+
nominal_guess = np.vstack([guess_dense[0], guess_dense[-1]])
|
|
92
|
+
|
|
93
|
+
# Broad bounds (required by OpenSCvx for all variables)
|
|
94
|
+
position.min = np.array([-2.0, -2.0, -2.0])
|
|
95
|
+
position.max = np.array([2.0, 2.0, 2.0])
|
|
96
|
+
velocity.min = np.array([-3.0, -3.0, -3.0])
|
|
97
|
+
velocity.max = np.array([3.0, 3.0, 3.0])
|
|
98
|
+
|
|
99
|
+
# Initial/final conditions:
|
|
100
|
+
# y0 = vx0 = vz0 = 0 (fixed), x0/z0/vy0 free around the seed values.
|
|
101
|
+
position.initial = [ox.Free(float(x0_seed[0])), 0.0, ox.Free(float(x0_seed[2]))]
|
|
102
|
+
velocity.initial = [0.0, ox.Free(float(x0_seed[4])), 0.0]
|
|
103
|
+
|
|
104
|
+
# Final state is mostly free; terminal objective handles y,vx,vz.
|
|
105
|
+
x_tf_guess = nominal_guess[-1]
|
|
106
|
+
position.final = [
|
|
107
|
+
ox.Free(float(x_tf_guess[0])),
|
|
108
|
+
0,
|
|
109
|
+
ox.Free(float(x_tf_guess[2])),
|
|
110
|
+
]
|
|
111
|
+
velocity.final = [
|
|
112
|
+
0,
|
|
113
|
+
ox.Free(float(x_tf_guess[4])),
|
|
114
|
+
0,
|
|
115
|
+
]
|
|
116
|
+
|
|
117
|
+
# Guesses
|
|
118
|
+
position.guess = nominal_guess[:, :3]
|
|
119
|
+
velocity.guess = nominal_guess[:, 3:]
|
|
120
|
+
|
|
121
|
+
states = [position, velocity]
|
|
122
|
+
|
|
123
|
+
time = ox.Time(initial=0.0, final=t_opt, min=0.0, max=t_opt)
|
|
124
|
+
discretizer = {
|
|
125
|
+
"ode_solver": "Dopri8",
|
|
126
|
+
"atol": integration_tol,
|
|
127
|
+
"rtol": integration_tol,
|
|
128
|
+
}
|
|
129
|
+
algorithm = {
|
|
130
|
+
"k_max": 400,
|
|
131
|
+
"lam_prox": 2e-1,
|
|
132
|
+
"lam_vc": 5e-2,
|
|
133
|
+
"ep_vc": 1e-6,
|
|
134
|
+
"autotuner": ox.AugmentedLagrangian(eta_lambda=1e0),
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
problem = Problem(
|
|
138
|
+
dynamics=dynamics,
|
|
139
|
+
states=states,
|
|
140
|
+
controls=[],
|
|
141
|
+
time=time,
|
|
142
|
+
constraints=[],
|
|
143
|
+
N=n_nodes,
|
|
144
|
+
discretizer=discretizer,
|
|
145
|
+
algorithm=algorithm,
|
|
146
|
+
float_dtype="float64",
|
|
147
|
+
)
|
|
148
|
+
|
|
149
|
+
# Keep post-process propagation tolerances aligned with discretization.
|
|
150
|
+
problem.settings.prp.solver = "Dopri8"
|
|
151
|
+
problem.settings.prp.atol = integration_tol
|
|
152
|
+
problem.settings.prp.rtol = integration_tol
|
|
153
|
+
|
|
154
|
+
if __name__ == "__main__":
|
|
155
|
+
problem.initialize()
|
|
156
|
+
results = problem.solve()
|
|
157
|
+
results = problem.post_process()
|
|
158
|
+
|
|
159
|
+
pos = results.trajectory["position"]
|
|
160
|
+
vel = results.trajectory["velocity"]
|
|
161
|
+
x0_opt = np.concatenate([pos[0], vel[0]])
|
|
162
|
+
xf_opt = np.concatenate([pos[-1], vel[-1]])
|
|
163
|
+
|
|
164
|
+
# Match the post-optimization check style in main_orbs_2.py:
|
|
165
|
+
# integrate only to t_f from optimized initial state and export xyz.
|
|
166
|
+
traj_plot = np.asarray(
|
|
167
|
+
solve_ivp_diffrax(
|
|
168
|
+
lambda t, x: cr3bp_rhs(x, jnp.zeros((0,), dtype=x.dtype), 0, {}),
|
|
169
|
+
tau_final=t_opt,
|
|
170
|
+
y_0=jnp.asarray(x0_opt, dtype=jnp.float64),
|
|
171
|
+
args=(),
|
|
172
|
+
tau_0=0.0,
|
|
173
|
+
num_substeps=2000,
|
|
174
|
+
solver_name="Dopri8",
|
|
175
|
+
rtol=integration_tol,
|
|
176
|
+
atol=integration_tol,
|
|
177
|
+
),
|
|
178
|
+
dtype=float,
|
|
179
|
+
)
|
|
180
|
+
|
|
181
|
+
# Plot guess and solution using the exact plot_projections_2d style.
|
|
182
|
+
guess_results = OptimizationResults(converged=True, t_final=float(t_opt))
|
|
183
|
+
guess_results.trajectory = {
|
|
184
|
+
"time": np.linspace(0.0, t_opt, guess_dense.shape[0]).reshape(-1, 1),
|
|
185
|
+
"position": guess_dense[:, :3],
|
|
186
|
+
"velocity": guess_dense[:, 3:6],
|
|
187
|
+
}
|
|
188
|
+
guess_results.nodes = {
|
|
189
|
+
"time": np.array([0.0, t_opt]).reshape(-1, 1),
|
|
190
|
+
"position": nominal_guess[:, :3],
|
|
191
|
+
"velocity": nominal_guess[:, 3:6],
|
|
192
|
+
}
|
|
193
|
+
fig_guess = plot_projections_2d(guess_results, velocity_var_name="velocity")
|
|
194
|
+
fig_guess.update_layout(title="Initial Guess - XY, XZ, YZ Projections")
|
|
195
|
+
fig_guess.show()
|
|
196
|
+
|
|
197
|
+
solution_results = OptimizationResults(converged=bool(results.converged), t_final=float(t_opt))
|
|
198
|
+
solution_results.trajectory = {
|
|
199
|
+
"time": np.linspace(0.0, t_opt, traj_plot.shape[0]).reshape(-1, 1),
|
|
200
|
+
"position": traj_plot[:, :3],
|
|
201
|
+
"velocity": traj_plot[:, 3:6],
|
|
202
|
+
}
|
|
203
|
+
solution_results.nodes = {
|
|
204
|
+
"time": results.nodes["time"],
|
|
205
|
+
"position": results.nodes["position"],
|
|
206
|
+
"velocity": results.nodes["velocity"],
|
|
207
|
+
}
|
|
208
|
+
fig_solution = plot_projections_2d(solution_results, velocity_var_name="velocity")
|
|
209
|
+
fig_solution.update_layout(title="Solution - XY, XZ, YZ Projections")
|
|
210
|
+
fig_solution.show()
|
|
@@ -18,7 +18,12 @@ from openscvx.algorithms import (
|
|
|
18
18
|
RampProximalWeight,
|
|
19
19
|
)
|
|
20
20
|
from openscvx.algorithms.optimization_results import OptimizationResults
|
|
21
|
-
from openscvx.discretization import
|
|
21
|
+
from openscvx.discretization import (
|
|
22
|
+
DiscretizeLinearizeVectorize,
|
|
23
|
+
LinearizeDiscretize,
|
|
24
|
+
LinearizeDiscretizeSparse,
|
|
25
|
+
VectorizeDiscretizeLinearize,
|
|
26
|
+
)
|
|
22
27
|
from openscvx.expert import ByofSpec
|
|
23
28
|
from openscvx.loader import load_dict, load_json, load_yaml
|
|
24
29
|
from openscvx.problem import Problem
|
|
@@ -172,8 +177,10 @@ __all__ = [
|
|
|
172
177
|
# Expert mode types
|
|
173
178
|
"ByofSpec",
|
|
174
179
|
# Discretization
|
|
180
|
+
"DiscretizeLinearizeVectorize",
|
|
175
181
|
"LinearizeDiscretize",
|
|
176
182
|
"LinearizeDiscretizeSparse",
|
|
183
|
+
"VectorizeDiscretizeLinearize",
|
|
177
184
|
# Convex Solver
|
|
178
185
|
"PTRSolver",
|
|
179
186
|
# Algorithm & Autotuning
|
|
@@ -18,7 +18,7 @@ version_tuple: tuple[int | str, ...]
|
|
|
18
18
|
commit_id: str | None
|
|
19
19
|
__commit_id__: str | None
|
|
20
20
|
|
|
21
|
-
__version__ = version = '0.4.1.
|
|
22
|
-
__version_tuple__ = version_tuple = (0, 4, 1, '
|
|
21
|
+
__version__ = version = '0.4.1.dev156'
|
|
22
|
+
__version_tuple__ = version_tuple = (0, 4, 1, 'dev156')
|
|
23
23
|
|
|
24
|
-
__commit_id__ = commit_id = '
|
|
24
|
+
__commit_id__ = commit_id = 'gf2c540a12'
|
|
@@ -20,6 +20,7 @@ import inspect
|
|
|
20
20
|
from typing import Any
|
|
21
21
|
|
|
22
22
|
from .base import Discretizer
|
|
23
|
+
from .discretize_linearize import DiscretizeLinearizeVectorize, VectorizeDiscretizeLinearize
|
|
23
24
|
from .linearize_discretize import (
|
|
24
25
|
LinearizeDiscretize,
|
|
25
26
|
calculate_impulsive_discretization,
|
|
@@ -33,8 +34,10 @@ from .sparse_utils import color_columns, make_sparse_jacobian_fns
|
|
|
33
34
|
# ---------------------------------------------------------------------------
|
|
34
35
|
|
|
35
36
|
_DISCRETIZER_MAP = {
|
|
37
|
+
"DiscretizeLinearizeVectorize": DiscretizeLinearizeVectorize,
|
|
36
38
|
"LinearizeDiscretize": LinearizeDiscretize,
|
|
37
39
|
"LinearizeDiscretizeSparse": LinearizeDiscretizeSparse,
|
|
40
|
+
"VectorizeDiscretizeLinearize": VectorizeDiscretizeLinearize,
|
|
38
41
|
}
|
|
39
42
|
|
|
40
43
|
|
|
@@ -46,7 +49,7 @@ def _resolve_discretizer(val: Any) -> Discretizer:
|
|
|
46
49
|
* **instance** — already-constructed :class:`Discretizer` (pass-through).
|
|
47
50
|
* **dict** — keyword arguments passed to the selected discretizer class.
|
|
48
51
|
An optional ``"type"`` key selects the class (defaults to
|
|
49
|
-
:class:`
|
|
52
|
+
:class:`VectorizeLinearizeDiscretize`).
|
|
50
53
|
|
|
51
54
|
Examples::
|
|
52
55
|
|
|
@@ -71,7 +74,7 @@ def _resolve_discretizer(val: Any) -> Discretizer:
|
|
|
71
74
|
raise TypeError(f"Expected a Discretizer instance or dict, got {type(val).__name__}")
|
|
72
75
|
|
|
73
76
|
kwargs = dict(val) # copy to avoid mutating caller's dict
|
|
74
|
-
name = kwargs.pop("type", "
|
|
77
|
+
name = kwargs.pop("type", "VectorizeDiscretizeLinearize")
|
|
75
78
|
|
|
76
79
|
cls = _DISCRETIZER_MAP.get(name)
|
|
77
80
|
if cls is None:
|
|
@@ -89,8 +92,10 @@ def _resolve_discretizer(val: Any) -> Discretizer:
|
|
|
89
92
|
|
|
90
93
|
__all__ = [
|
|
91
94
|
"Discretizer",
|
|
95
|
+
"DiscretizeLinearizeVectorize",
|
|
92
96
|
"LinearizeDiscretize",
|
|
93
97
|
"LinearizeDiscretizeSparse",
|
|
98
|
+
"VectorizeDiscretizeLinearize",
|
|
94
99
|
"_resolve_discretizer",
|
|
95
100
|
"calculate_impulsive_discretization",
|
|
96
101
|
"color_columns",
|