placo 0.6.2__tar.gz → 0.6.3__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.
Potentially problematic release.
This version of placo might be problematic. Click here for more details.
- {placo-0.6.2 → placo-0.6.3}/CMakeLists.txt +1 -0
- {placo-0.6.2 → placo-0.6.3}/PKG-INFO +1 -1
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-tools.cpp +4 -0
- {placo-0.6.2 → placo-0.6.3}/doxygen_parse.py +2 -1
- {placo-0.6.2 → placo-0.6.3}/placo.pyi +29 -0
- {placo-0.6.2 → placo-0.6.3}/pyproject.toml +1 -1
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_pattern_generator.cpp +18 -9
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_pattern_generator.h +3 -3
- placo-0.6.3/src/placo/tools/directions.cpp +42 -0
- placo-0.6.3/src/placo/tools/directions.h +22 -0
- {placo-0.6.2 → placo-0.6.3}/.clang-format +0 -0
- {placo-0.6.2 → placo-0.6.3}/.gitattributes +0 -0
- {placo-0.6.2 → placo-0.6.3}/.gitignore +0 -0
- {placo-0.6.2 → placo-0.6.3}/.readthedocs.yaml +0 -0
- {placo-0.6.2 → placo-0.6.3}/Doxyfile +0 -0
- {placo-0.6.2 → placo-0.6.3}/LICENSE +0 -0
- {placo-0.6.2 → placo-0.6.3}/Makefile +0 -0
- {placo-0.6.2 → placo-0.6.3}/README.md +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-dynamics.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-eigen.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-footsteps.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-kinematics.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-parameters.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-problem.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-robot-wrapper.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-utils.hpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/expose-walk-pattern-generator.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/module.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/module.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/registry.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/bindings/registry.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/.vscode/settings.json +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/Makefile +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/placo_utils/__init__.py +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/placo_utils/tf.py +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/placo_utils/view.py +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/placo_utils/visualization.py +0 -0
- {placo-0.6.2 → placo-0.6.3}/python/run_tests.sh +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/avoid_self_collisions_constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/avoid_self_collisions_constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/com_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/com_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/contacts.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/contacts.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/dynamics_solver.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/dynamics_solver.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/frame_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/frame_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/gear_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/gear_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/joints_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/joints_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/orientation_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/orientation_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/position_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/position_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_frame_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_frame_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_orientation_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_orientation_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_position_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_position_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/torque_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/torque_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/foot_trajectory.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/foot_trajectory.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_naive.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_naive.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_repetitive.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_repetitive.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_parameters.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_parameters.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_robot.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_robot.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/kick.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/kick.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/lipm.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/lipm.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_cubic.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_cubic.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_quintic.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_quintic.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_tasks.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_tasks.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/avoid_self_collisions_constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/avoid_self_collisions_constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/axis_align_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/axis_align_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/centroidal_momentum_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/centroidal_momentum_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_polygon_constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_polygon_constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/cone_constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/cone_constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/distance_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/distance_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/frame_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/frame_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/gear_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/gear_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/joints_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/joints_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinematics_solver.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinematics_solver.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinetic_energy_regularization_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinetic_energy_regularization_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/manipulability_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/manipulability_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/orientation_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/orientation_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/position_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/position_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/regularization_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/regularization_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_frame_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_frame_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_orientation_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_orientation_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_position_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_position_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/wheel_task.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/wheel_task.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/model/robot_wrapper.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/model/robot_wrapper.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/expression.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/expression.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/integrator.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/integrator.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/polygon_constraint.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/polygon_constraint.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/problem.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/problem.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/qp_error.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/qp_error.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/sparsity.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/sparsity.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/variable.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/problem/variable.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/axises_mask.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/axises_mask.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline_3d.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline_3d.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/prioritized.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/prioritized.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/utils.cpp +0 -0
- {placo-0.6.2 → placo-0.6.3}/src/placo/tools/utils.h +0 -0
- {placo-0.6.2 → placo-0.6.3}/stubs.py +0 -0
- {placo-0.6.2 → placo-0.6.3}/tweak_sdist.sh +0 -0
- {placo-0.6.2 → placo-0.6.3}/wks.yml +0 -0
|
@@ -9,6 +9,7 @@
|
|
|
9
9
|
#include "placo/tools/cubic_spline_3d.h"
|
|
10
10
|
#include "placo/tools/axises_mask.h"
|
|
11
11
|
#include "placo/tools/prioritized.h"
|
|
12
|
+
#include "placo/tools/directions.h"
|
|
12
13
|
#include "expose-utils.hpp"
|
|
13
14
|
#ifdef HAVE_RHOBAN_UTILS
|
|
14
15
|
#include "rhoban_utils/history/history.h"
|
|
@@ -24,6 +25,7 @@ BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(loadReplays_overloads, loadReplays, 1, 2)
|
|
|
24
25
|
|
|
25
26
|
BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(set_axises_overloads, set_axises, 1, 2);
|
|
26
27
|
BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(configure_overloads, configure, 2, 3);
|
|
28
|
+
BOOST_PYTHON_FUNCTION_OVERLOADS(directions_3d_overloads, directions_3d, 1, 2);
|
|
27
29
|
|
|
28
30
|
void exposeTools()
|
|
29
31
|
{
|
|
@@ -33,6 +35,8 @@ void exposeTools()
|
|
|
33
35
|
def("frame_yaw", &frame_yaw);
|
|
34
36
|
def("flatten_on_floor", &flatten_on_floor);
|
|
35
37
|
def("optimal_transformation", &optimal_transformation);
|
|
38
|
+
def("directions_2d", &directions_2d);
|
|
39
|
+
def("directions_3d", &directions_3d, directions_3d_overloads());
|
|
36
40
|
|
|
37
41
|
exposeStdVector<int>("vector_int");
|
|
38
42
|
exposeStdVector<double>("vector_double");
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import glob
|
|
2
2
|
import re
|
|
3
|
+
from typing import Union
|
|
3
4
|
import xml.etree.ElementTree as ET
|
|
4
5
|
|
|
5
6
|
# Mapping member definitions (id) to all informations
|
|
@@ -148,7 +149,7 @@ def parse_xml(xml_file: str):
|
|
|
148
149
|
parse_compound(compounddef_node)
|
|
149
150
|
|
|
150
151
|
|
|
151
|
-
def resolve_doxygen_id(id: list
|
|
152
|
+
def resolve_doxygen_id(id: Union[list,str]):
|
|
152
153
|
if type(id) == list:
|
|
153
154
|
tpl = resolve_doxygen_id(id[0])
|
|
154
155
|
typ = resolve_doxygen_id(id[1])
|
|
@@ -7236,6 +7236,35 @@ class WheelTask:
|
|
|
7236
7236
|
...
|
|
7237
7237
|
|
|
7238
7238
|
|
|
7239
|
+
def directions_2d(
|
|
7240
|
+
n: int, # int
|
|
7241
|
+
|
|
7242
|
+
) -> numpy.ndarray:
|
|
7243
|
+
"""Generates a set of directions in 2D.
|
|
7244
|
+
|
|
7245
|
+
|
|
7246
|
+
:param n: the number of directions
|
|
7247
|
+
|
|
7248
|
+
:return: matrix of size n x 2"""
|
|
7249
|
+
...
|
|
7250
|
+
|
|
7251
|
+
|
|
7252
|
+
def directions_3d(
|
|
7253
|
+
n: int, # int
|
|
7254
|
+
epsilon: float = 0.5, # double
|
|
7255
|
+
|
|
7256
|
+
) -> numpy.ndarray:
|
|
7257
|
+
"""Generates a set of directions in 3D, using Fibonacci lattice.
|
|
7258
|
+
|
|
7259
|
+
|
|
7260
|
+
:param n: the number of directions
|
|
7261
|
+
|
|
7262
|
+
:param epsilon: the epsilon parameter for the Fibonacci lattice
|
|
7263
|
+
|
|
7264
|
+
:return: matrix of size n x 3"""
|
|
7265
|
+
...
|
|
7266
|
+
|
|
7267
|
+
|
|
7239
7268
|
def flatten_on_floor(
|
|
7240
7269
|
transformation: numpy.ndarray, # const Eigen::Affine3d &
|
|
7241
7270
|
|
|
@@ -342,8 +342,7 @@ void WalkPatternGenerator::planCoM(Trajectory& trajectory, Eigen::Vector2d initi
|
|
|
342
342
|
for (int timestep = 1; timestep < kept_timesteps; timestep++)
|
|
343
343
|
{
|
|
344
344
|
Eigen::Vector2d jerk = old_trajectory->get_j_world_CoM(trajectory.t_start + timestep * parameters.dt()).head(2);
|
|
345
|
-
problem.add_constraint(lipm.jerk(timestep) == jerk)
|
|
346
|
-
.configure(ProblemConstraint::Soft, 1e-4);
|
|
345
|
+
problem.add_constraint(lipm.jerk(timestep) == jerk).configure(ProblemConstraint::Soft, 1e-4);
|
|
347
346
|
}
|
|
348
347
|
}
|
|
349
348
|
|
|
@@ -355,7 +354,8 @@ void WalkPatternGenerator::planCoM(Trajectory& trajectory, Eigen::Vector2d initi
|
|
|
355
354
|
current_support = trajectory.supports[i];
|
|
356
355
|
int step_timesteps = support_timesteps(current_support);
|
|
357
356
|
|
|
358
|
-
for (int timestep = constrained_timesteps; timestep < fmin(timesteps, constrained_timesteps + step_timesteps);
|
|
357
|
+
for (int timestep = constrained_timesteps; timestep < fmin(timesteps, constrained_timesteps + step_timesteps);
|
|
358
|
+
timestep++)
|
|
359
359
|
{
|
|
360
360
|
// Ensuring ZMP remains in the support polygon
|
|
361
361
|
if (timestep > kept_timesteps)
|
|
@@ -363,7 +363,7 @@ void WalkPatternGenerator::planCoM(Trajectory& trajectory, Eigen::Vector2d initi
|
|
|
363
363
|
problem.add_constraint(PolygonConstraint::in_polygon_xy(
|
|
364
364
|
lipm.zmp(timestep, omega_2), current_support.support_polygon(), parameters.zmp_margin));
|
|
365
365
|
}
|
|
366
|
-
|
|
366
|
+
|
|
367
367
|
// ZMP reference trajectory : aiming for the center of single supports
|
|
368
368
|
if (!current_support.is_both() || current_support.start || current_support.end)
|
|
369
369
|
{
|
|
@@ -509,7 +509,10 @@ void WalkPatternGenerator::planSingleSupportTrajectory(TrajectoryPart& part, Tra
|
|
|
509
509
|
trajectory.yaw(flying_side).add_point(t, frame_yaw(T_world_flyingTarget.rotation()), 0);
|
|
510
510
|
|
|
511
511
|
// The trunk orientation follow the steps orientation
|
|
512
|
-
|
|
512
|
+
if (!parameters.has_double_support())
|
|
513
|
+
{
|
|
514
|
+
trajectory.trunk_yaw.add_point(t, frame_yaw(T_world_flyingTarget.rotation()), 0);
|
|
515
|
+
}
|
|
513
516
|
|
|
514
517
|
// Support foot remaining steady
|
|
515
518
|
trajectory.add_supports(t, part.support);
|
|
@@ -522,7 +525,14 @@ void WalkPatternGenerator::planFeetTrajectories(Trajectory& trajectory, Trajecto
|
|
|
522
525
|
// Add the initial position to the trajectory
|
|
523
526
|
trajectory.add_supports(t, trajectory.supports[0]);
|
|
524
527
|
|
|
525
|
-
|
|
528
|
+
if (old_trajectory == nullptr)
|
|
529
|
+
{
|
|
530
|
+
trajectory.trunk_yaw.add_point(t, frame_yaw(trajectory.supports[0].frame().rotation()), 0);
|
|
531
|
+
}
|
|
532
|
+
else
|
|
533
|
+
{
|
|
534
|
+
trajectory.trunk_yaw.add_point(t, old_trajectory->trunk_yaw.pos(t), old_trajectory->trunk_yaw.vel(t));
|
|
535
|
+
}
|
|
526
536
|
|
|
527
537
|
if (!trajectory.supports[0].is_both())
|
|
528
538
|
{
|
|
@@ -556,7 +566,6 @@ void WalkPatternGenerator::planFeetTrajectories(Trajectory& trajectory, Trajecto
|
|
|
556
566
|
planSingleSupportTrajectory(part, trajectory, step, t, old_trajectory, t_replan);
|
|
557
567
|
}
|
|
558
568
|
}
|
|
559
|
-
|
|
560
569
|
// Double support
|
|
561
570
|
else
|
|
562
571
|
{
|
|
@@ -625,7 +634,7 @@ WalkPatternGenerator::Trajectory WalkPatternGenerator::replan(std::vector<Footst
|
|
|
625
634
|
bool WalkPatternGenerator::can_replan_supports(Trajectory& trajectory, double t_replan)
|
|
626
635
|
{
|
|
627
636
|
// We can't replan from an "end", a "start" or a "kick"
|
|
628
|
-
if (trajectory.get_support(t_replan).end || trajectory.get_support(t_replan).start ||
|
|
637
|
+
if (trajectory.get_support(t_replan).end || trajectory.get_support(t_replan).start ||
|
|
629
638
|
trajectory.get_next_support(t_replan).end || trajectory.get_support(t_replan).kick())
|
|
630
639
|
{
|
|
631
640
|
return false;
|
|
@@ -673,7 +682,7 @@ std::vector<FootstepsPlanner::Support> WalkPatternGenerator::replan_supports(Foo
|
|
|
673
682
|
|
|
674
683
|
std::vector<FootstepsPlanner::Support> supports;
|
|
675
684
|
supports = FootstepsPlanner::make_supports(footsteps, false, parameters.has_double_support(), true);
|
|
676
|
-
|
|
685
|
+
|
|
677
686
|
if (current_support.is_both())
|
|
678
687
|
{
|
|
679
688
|
supports.erase(supports.begin());
|
|
@@ -65,18 +65,18 @@ public:
|
|
|
65
65
|
|
|
66
66
|
/**
|
|
67
67
|
* @brief Returns the support corresponding to the given time in the trajectory
|
|
68
|
-
|
|
68
|
+
*/
|
|
69
69
|
FootstepsPlanner::Support get_support(double t);
|
|
70
70
|
|
|
71
71
|
/**
|
|
72
72
|
* @brief Returns the nth next support corresponding to the given time in the trajectory
|
|
73
73
|
*/
|
|
74
|
-
FootstepsPlanner::Support get_next_support(double t, int n=1);
|
|
74
|
+
FootstepsPlanner::Support get_next_support(double t, int n = 1);
|
|
75
75
|
|
|
76
76
|
/**
|
|
77
77
|
* @brief Returns the nth previous support corresponding to the given time in the trajectory
|
|
78
78
|
*/
|
|
79
|
-
FootstepsPlanner::Support get_prev_support(double t, int n=1);
|
|
79
|
+
FootstepsPlanner::Support get_prev_support(double t, int n = 1);
|
|
80
80
|
|
|
81
81
|
std::vector<FootstepsPlanner::Support> get_supports();
|
|
82
82
|
int remaining_supports(double t);
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
#include "directions.h"
|
|
2
|
+
|
|
3
|
+
namespace placo::tools
|
|
4
|
+
{
|
|
5
|
+
Eigen::MatrixXd directions_2d(int n)
|
|
6
|
+
{
|
|
7
|
+
Eigen::MatrixXd directions(n, 2);
|
|
8
|
+
|
|
9
|
+
for (int i = 0; i < n; i++)
|
|
10
|
+
{
|
|
11
|
+
double angle = 2 * M_PI * i / n;
|
|
12
|
+
directions(i, 0) = cos(angle);
|
|
13
|
+
directions(i, 1) = sin(angle);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
return directions;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
Eigen::MatrixXd directions_3d(int n, double epsilon)
|
|
20
|
+
{
|
|
21
|
+
Eigen::MatrixXd directions(n, 3);
|
|
22
|
+
|
|
23
|
+
// Golden ratio
|
|
24
|
+
double phi = (1 + sqrt(5)) / 2;
|
|
25
|
+
|
|
26
|
+
for (int i = 0; i < n; i++)
|
|
27
|
+
{
|
|
28
|
+
double x = fmod(i / phi, 1);
|
|
29
|
+
double y = (i + epsilon) / (n - 1 + 2 * epsilon);
|
|
30
|
+
|
|
31
|
+
double alpha = 2 * M_PI * x;
|
|
32
|
+
double beta = acos(1 - 2 * y);
|
|
33
|
+
|
|
34
|
+
directions(i, 0) = sin(beta) * cos(alpha);
|
|
35
|
+
directions(i, 1) = sin(beta) * sin(alpha);
|
|
36
|
+
directions(i, 2) = cos(beta);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return directions;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
} // namespace placo::tools
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <vector>
|
|
4
|
+
#include <Eigen/Dense>
|
|
5
|
+
|
|
6
|
+
namespace placo::tools
|
|
7
|
+
{
|
|
8
|
+
/**
|
|
9
|
+
* @brief Generates a set of directions in 2D
|
|
10
|
+
* @param n the number of directions
|
|
11
|
+
* @return matrix of size n x 2
|
|
12
|
+
*/
|
|
13
|
+
Eigen::MatrixXd directions_2d(int n);
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @brief Generates a set of directions in 3D, using Fibonacci lattice
|
|
17
|
+
* @param n the number of directions
|
|
18
|
+
* @param epsilon the epsilon parameter for the Fibonacci lattice
|
|
19
|
+
* @return matrix of size n x 3
|
|
20
|
+
*/
|
|
21
|
+
Eigen::MatrixXd directions_3d(int n, double epsilon = 0.5);
|
|
22
|
+
} // namespace placo::tools
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|