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.

Files changed (167) hide show
  1. {placo-0.6.2 → placo-0.6.3}/CMakeLists.txt +1 -0
  2. {placo-0.6.2 → placo-0.6.3}/PKG-INFO +1 -1
  3. {placo-0.6.2 → placo-0.6.3}/bindings/expose-tools.cpp +4 -0
  4. {placo-0.6.2 → placo-0.6.3}/doxygen_parse.py +2 -1
  5. {placo-0.6.2 → placo-0.6.3}/placo.pyi +29 -0
  6. {placo-0.6.2 → placo-0.6.3}/pyproject.toml +1 -1
  7. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_pattern_generator.cpp +18 -9
  8. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_pattern_generator.h +3 -3
  9. placo-0.6.3/src/placo/tools/directions.cpp +42 -0
  10. placo-0.6.3/src/placo/tools/directions.h +22 -0
  11. {placo-0.6.2 → placo-0.6.3}/.clang-format +0 -0
  12. {placo-0.6.2 → placo-0.6.3}/.gitattributes +0 -0
  13. {placo-0.6.2 → placo-0.6.3}/.gitignore +0 -0
  14. {placo-0.6.2 → placo-0.6.3}/.readthedocs.yaml +0 -0
  15. {placo-0.6.2 → placo-0.6.3}/Doxyfile +0 -0
  16. {placo-0.6.2 → placo-0.6.3}/LICENSE +0 -0
  17. {placo-0.6.2 → placo-0.6.3}/Makefile +0 -0
  18. {placo-0.6.2 → placo-0.6.3}/README.md +0 -0
  19. {placo-0.6.2 → placo-0.6.3}/bindings/expose-dynamics.cpp +0 -0
  20. {placo-0.6.2 → placo-0.6.3}/bindings/expose-eigen.cpp +0 -0
  21. {placo-0.6.2 → placo-0.6.3}/bindings/expose-footsteps.cpp +0 -0
  22. {placo-0.6.2 → placo-0.6.3}/bindings/expose-kinematics.cpp +0 -0
  23. {placo-0.6.2 → placo-0.6.3}/bindings/expose-parameters.cpp +0 -0
  24. {placo-0.6.2 → placo-0.6.3}/bindings/expose-problem.cpp +0 -0
  25. {placo-0.6.2 → placo-0.6.3}/bindings/expose-robot-wrapper.cpp +0 -0
  26. {placo-0.6.2 → placo-0.6.3}/bindings/expose-utils.hpp +0 -0
  27. {placo-0.6.2 → placo-0.6.3}/bindings/expose-walk-pattern-generator.cpp +0 -0
  28. {placo-0.6.2 → placo-0.6.3}/bindings/module.cpp +0 -0
  29. {placo-0.6.2 → placo-0.6.3}/bindings/module.h +0 -0
  30. {placo-0.6.2 → placo-0.6.3}/bindings/registry.cpp +0 -0
  31. {placo-0.6.2 → placo-0.6.3}/bindings/registry.h +0 -0
  32. {placo-0.6.2 → placo-0.6.3}/python/.vscode/settings.json +0 -0
  33. {placo-0.6.2 → placo-0.6.3}/python/Makefile +0 -0
  34. {placo-0.6.2 → placo-0.6.3}/python/placo_utils/__init__.py +0 -0
  35. {placo-0.6.2 → placo-0.6.3}/python/placo_utils/tf.py +0 -0
  36. {placo-0.6.2 → placo-0.6.3}/python/placo_utils/view.py +0 -0
  37. {placo-0.6.2 → placo-0.6.3}/python/placo_utils/visualization.py +0 -0
  38. {placo-0.6.2 → placo-0.6.3}/python/run_tests.sh +0 -0
  39. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/avoid_self_collisions_constraint.cpp +0 -0
  40. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/avoid_self_collisions_constraint.h +0 -0
  41. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/com_task.cpp +0 -0
  42. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/com_task.h +0 -0
  43. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/constraint.cpp +0 -0
  44. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/constraint.h +0 -0
  45. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/contacts.cpp +0 -0
  46. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/contacts.h +0 -0
  47. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/dynamics_solver.cpp +0 -0
  48. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/dynamics_solver.h +0 -0
  49. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/frame_task.cpp +0 -0
  50. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/frame_task.h +0 -0
  51. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/gear_task.cpp +0 -0
  52. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/gear_task.h +0 -0
  53. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/joints_task.cpp +0 -0
  54. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/joints_task.h +0 -0
  55. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/orientation_task.cpp +0 -0
  56. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/orientation_task.h +0 -0
  57. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/position_task.cpp +0 -0
  58. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/position_task.h +0 -0
  59. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_frame_task.cpp +0 -0
  60. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_frame_task.h +0 -0
  61. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_orientation_task.cpp +0 -0
  62. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_orientation_task.h +0 -0
  63. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_position_task.cpp +0 -0
  64. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/relative_position_task.h +0 -0
  65. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/task.cpp +0 -0
  66. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/task.h +0 -0
  67. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/torque_task.cpp +0 -0
  68. {placo-0.6.2 → placo-0.6.3}/src/placo/dynamics/torque_task.h +0 -0
  69. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/foot_trajectory.cpp +0 -0
  70. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/foot_trajectory.h +0 -0
  71. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner.cpp +0 -0
  72. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner.h +0 -0
  73. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_naive.cpp +0 -0
  74. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_naive.h +0 -0
  75. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_repetitive.cpp +0 -0
  76. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/footsteps_planner_repetitive.h +0 -0
  77. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_parameters.cpp +0 -0
  78. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_parameters.h +0 -0
  79. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_robot.cpp +0 -0
  80. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/humanoid_robot.h +0 -0
  81. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/kick.cpp +0 -0
  82. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/kick.h +0 -0
  83. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/lipm.cpp +0 -0
  84. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/lipm.h +0 -0
  85. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot.cpp +0 -0
  86. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot.h +0 -0
  87. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_cubic.cpp +0 -0
  88. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_cubic.h +0 -0
  89. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_quintic.cpp +0 -0
  90. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/swing_foot_quintic.h +0 -0
  91. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_tasks.cpp +0 -0
  92. {placo-0.6.2 → placo-0.6.3}/src/placo/humanoid/walk_tasks.h +0 -0
  93. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/avoid_self_collisions_constraint.cpp +0 -0
  94. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/avoid_self_collisions_constraint.h +0 -0
  95. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/axis_align_task.cpp +0 -0
  96. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/axis_align_task.h +0 -0
  97. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/centroidal_momentum_task.cpp +0 -0
  98. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/centroidal_momentum_task.h +0 -0
  99. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_polygon_constraint.cpp +0 -0
  100. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_polygon_constraint.h +0 -0
  101. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_task.cpp +0 -0
  102. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/com_task.h +0 -0
  103. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/cone_constraint.cpp +0 -0
  104. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/cone_constraint.h +0 -0
  105. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/constraint.cpp +0 -0
  106. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/constraint.h +0 -0
  107. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/distance_task.cpp +0 -0
  108. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/distance_task.h +0 -0
  109. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/frame_task.cpp +0 -0
  110. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/frame_task.h +0 -0
  111. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/gear_task.cpp +0 -0
  112. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/gear_task.h +0 -0
  113. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/joints_task.cpp +0 -0
  114. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/joints_task.h +0 -0
  115. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinematics_solver.cpp +0 -0
  116. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinematics_solver.h +0 -0
  117. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinetic_energy_regularization_task.cpp +0 -0
  118. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/kinetic_energy_regularization_task.h +0 -0
  119. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/manipulability_task.cpp +0 -0
  120. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/manipulability_task.h +0 -0
  121. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/orientation_task.cpp +0 -0
  122. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/orientation_task.h +0 -0
  123. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/position_task.cpp +0 -0
  124. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/position_task.h +0 -0
  125. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/regularization_task.cpp +0 -0
  126. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/regularization_task.h +0 -0
  127. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_frame_task.cpp +0 -0
  128. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_frame_task.h +0 -0
  129. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_orientation_task.cpp +0 -0
  130. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_orientation_task.h +0 -0
  131. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_position_task.cpp +0 -0
  132. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/relative_position_task.h +0 -0
  133. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/task.cpp +0 -0
  134. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/task.h +0 -0
  135. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/wheel_task.cpp +0 -0
  136. {placo-0.6.2 → placo-0.6.3}/src/placo/kinematics/wheel_task.h +0 -0
  137. {placo-0.6.2 → placo-0.6.3}/src/placo/model/robot_wrapper.cpp +0 -0
  138. {placo-0.6.2 → placo-0.6.3}/src/placo/model/robot_wrapper.h +0 -0
  139. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/constraint.cpp +0 -0
  140. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/constraint.h +0 -0
  141. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/expression.cpp +0 -0
  142. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/expression.h +0 -0
  143. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/integrator.cpp +0 -0
  144. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/integrator.h +0 -0
  145. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/polygon_constraint.cpp +0 -0
  146. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/polygon_constraint.h +0 -0
  147. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/problem.cpp +0 -0
  148. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/problem.h +0 -0
  149. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/qp_error.cpp +0 -0
  150. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/qp_error.h +0 -0
  151. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/sparsity.cpp +0 -0
  152. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/sparsity.h +0 -0
  153. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/variable.cpp +0 -0
  154. {placo-0.6.2 → placo-0.6.3}/src/placo/problem/variable.h +0 -0
  155. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/axises_mask.cpp +0 -0
  156. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/axises_mask.h +0 -0
  157. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline.cpp +0 -0
  158. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline.h +0 -0
  159. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline_3d.cpp +0 -0
  160. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/cubic_spline_3d.h +0 -0
  161. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/prioritized.cpp +0 -0
  162. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/prioritized.h +0 -0
  163. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/utils.cpp +0 -0
  164. {placo-0.6.2 → placo-0.6.3}/src/placo/tools/utils.h +0 -0
  165. {placo-0.6.2 → placo-0.6.3}/stubs.py +0 -0
  166. {placo-0.6.2 → placo-0.6.3}/tweak_sdist.sh +0 -0
  167. {placo-0.6.2 → placo-0.6.3}/wks.yml +0 -0
@@ -51,6 +51,7 @@ add_library(libplaco SHARED
51
51
  src/placo/tools/prioritized.cpp
52
52
  src/placo/tools/cubic_spline.cpp
53
53
  src/placo/tools/cubic_spline_3d.cpp
54
+ src/placo/tools/directions.cpp
54
55
 
55
56
  # Problem formulation
56
57
  src/placo/problem/problem.cpp
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: placo
3
- Version: 0.6.2
3
+ Version: 0.6.3
4
4
  Summary: PlaCo: Rhoban Planning and Control
5
5
  Requires-Python: >= 3.8
6
6
  License-Expression: MIT
@@ -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|str):
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
 
@@ -23,7 +23,7 @@ description = "PlaCo: Rhoban Planning and Control"
23
23
  license = "MIT"
24
24
  name = "placo"
25
25
  requires-python = ">= 3.8"
26
- version = "0.6.2"
26
+ version = "0.6.3"
27
27
 
28
28
  [project.urls]
29
29
  changelog = "https://github.com/rhoban/placo/blob/main/CHANGELOG.md"
@@ -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); timestep++)
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
- trajectory.trunk_yaw.add_point(t, frame_yaw(T_world_flyingTarget.rotation()), 0);
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
- trajectory.trunk_yaw.add_point(t, frame_yaw(trajectory.supports[0].frame().rotation()), 0);
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