From 0853c43a8814ae27330173c6b0c108dc1d0e9475 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Sun, 17 Mar 2024 23:12:32 +0100 Subject: [PATCH 01/10] Install manifpy from cmake in CI --- .github/workflows/ci.yml | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index fda727cb1c..b71c8d91c4 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -254,6 +254,7 @@ jobs: mkdir build cd build cmake -A x64 -DCMAKE_TOOLCHAIN_FILE=${VCPKG_INSTALLATION_ROOT}/scripts/buildsystems/vcpkg.cmake \ + -DBUILD_PYTHON_BINDINGS:BOOL=ON \ -DCMAKE_PREFIX_PATH=${GITHUB_WORKSPACE}/install/deps \ -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \ -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. @@ -425,7 +426,7 @@ jobs: git checkout ${manif_TAG} mkdir build cd build - cmake -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. + cmake -DBUILD_PYTHON_BINDINGS:BOOL=ON -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} # matioCpp @@ -502,14 +503,6 @@ jobs: cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} - - name: Install manifpy [Ubuntu/macOS] - if: startsWith(matrix.os, 'ubuntu') || matrix.os == 'macos-latest' - run: | - git clone https://github.com/artivis/manif.git manifpy - cd manifpy - git checkout ${manif_TAG} - python3 -m pip install . - - name: Check Python setup shell: bash run: | From 07e7f224d30930f65fab56a885a111523d92d796 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Sun, 17 Mar 2024 23:19:40 +0100 Subject: [PATCH 02/10] Update ci.yml --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b71c8d91c4..7666b443eb 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ env: YARP_TAG: v3.8.0 iDynTree_TAG: v8.0.0 CasADi_TAG: 3.5.5.2 - manif_TAG: 0.0.4 + manif_TAG: 974a2413e462774b77b4e9e68f863e250161f290 matioCpp_TAG: v0.2.0 LieGroupControllers_TAG: v0.2.0 osqp_TAG: v0.6.2 From d3b06719599d721573e5ce5594d846980b8c75d0 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 18 Mar 2024 10:43:00 +0100 Subject: [PATCH 03/10] Update ci.yml --- .github/workflows/ci.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 7666b443eb..5b6cd31393 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -254,7 +254,6 @@ jobs: mkdir build cd build cmake -A x64 -DCMAKE_TOOLCHAIN_FILE=${VCPKG_INSTALLATION_ROOT}/scripts/buildsystems/vcpkg.cmake \ - -DBUILD_PYTHON_BINDINGS:BOOL=ON \ -DCMAKE_PREFIX_PATH=${GITHUB_WORKSPACE}/install/deps \ -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \ -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. @@ -426,7 +425,7 @@ jobs: git checkout ${manif_TAG} mkdir build cd build - cmake -DBUILD_PYTHON_BINDINGS:BOOL=ON -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. + cmake -DBUILD_PYTHON_BINDINGS:BOOL=ON -DMANIFPY_PKGDIR:PATH=${GITHUB_WORKSPACE}/install/deps/lib/python3/dist-packages -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} # matioCpp From 176881977cf3da74388efc4411d486f845ea7088 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 18 Mar 2024 13:40:13 +0100 Subject: [PATCH 04/10] Update ci.yml --- .github/workflows/ci.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5b6cd31393..f613f48f99 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ env: YARP_TAG: v3.8.0 iDynTree_TAG: v8.0.0 CasADi_TAG: 3.5.5.2 - manif_TAG: 974a2413e462774b77b4e9e68f863e250161f290 + manif_TAG: 0.0.4.102 matioCpp_TAG: v0.2.0 LieGroupControllers_TAG: v0.2.0 osqp_TAG: v0.6.2 @@ -248,7 +248,7 @@ jobs: # manif cd ${GITHUB_WORKSPACE} - git clone https://github.com/artivis/manif.git + git clone https://github.com/robotology-dependencies/manif.git cd manif git checkout ${manif_TAG} mkdir build @@ -420,7 +420,7 @@ jobs: # manif cd ${GITHUB_WORKSPACE} - git clone https://github.com/artivis/manif.git + git clone https://github.com/robotology-dependencies/manif.git cd manif git checkout ${manif_TAG} mkdir build From eb84ed9c39d642b3bfac79c8f8189944727bf40f Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 18 Mar 2024 13:41:54 +0100 Subject: [PATCH 05/10] Update ci.yml --- .github/workflows/ci.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f613f48f99..a9a81fdada 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -248,7 +248,7 @@ jobs: # manif cd ${GITHUB_WORKSPACE} - git clone https://github.com/robotology-dependencies/manif.git + git clone https://github.com/robotology-dependencies/manif.git cd manif git checkout ${manif_TAG} mkdir build @@ -420,7 +420,7 @@ jobs: # manif cd ${GITHUB_WORKSPACE} - git clone https://github.com/robotology-dependencies/manif.git + git clone https://github.com/robotology-dependencies/manif.git cd manif git checkout ${manif_TAG} mkdir build From a184b23921615d990f931683da29faa192cacf44 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 18 Mar 2024 15:37:36 +0100 Subject: [PATCH 06/10] Update ci.yml --- .github/workflows/ci.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a9a81fdada..22c1bbef15 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -384,7 +384,8 @@ jobs: -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \ -DIDYNTREE_USES_PYTHON:BOOL=ON \ -DIDYNTREE_USES_ASSIMP:BOOL=ON \ - -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. + -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps \ + -DIDYNTREE_PYTHON_INSTALL_DIR:PATH=${GITHUB_WORKSPACE}/install/deps/lib/python3/dist-packages .. cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} # osqp From 7101b533eb4165f01c19de33020087ec14ac897f Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 25 Mar 2024 10:05:05 +0100 Subject: [PATCH 07/10] Update ci.yml --- .github/workflows/ci.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 22c1bbef15..a9a81fdada 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -384,8 +384,7 @@ jobs: -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \ -DIDYNTREE_USES_PYTHON:BOOL=ON \ -DIDYNTREE_USES_ASSIMP:BOOL=ON \ - -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps \ - -DIDYNTREE_PYTHON_INSTALL_DIR:PATH=${GITHUB_WORKSPACE}/install/deps/lib/python3/dist-packages .. + -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} # osqp From 1bec178b70353ae92c6ea4fda82ec5e7344dcf31 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Mon, 25 Mar 2024 10:33:17 +0100 Subject: [PATCH 08/10] Update ci.yml --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a9a81fdada..fb35ef93bb 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -14,7 +14,7 @@ env: vcpkg_robotology_TAG: v0.11.0 YCM_TAG: v0.15.3 YARP_TAG: v3.8.0 - iDynTree_TAG: v8.0.0 + iDynTree_TAG: 42f2874b729348575aeee723c1775c3425735ef9 CasADi_TAG: 3.5.5.2 manif_TAG: 0.0.4.102 matioCpp_TAG: v0.2.0 From 70ed7aa6f0642098ac8574589516681bfd0cc618 Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Sat, 30 Mar 2024 21:28:11 +0100 Subject: [PATCH 09/10] Remove all the usage of getRandomModel in QPInverseKinematicsTest and QPFixedBaseInverseKinematicsTest --- .../QPFixedBaseInverseKinematicsTest.cpp | 20 ++++++---- src/IK/tests/QPInverseKinematicsTest.cpp | 39 +++++++++++++------ 2 files changed, 41 insertions(+), 18 deletions(-) diff --git a/src/IK/tests/QPFixedBaseInverseKinematicsTest.cpp b/src/IK/tests/QPFixedBaseInverseKinematicsTest.cpp index 4f3d725ae7..b216ab9fa7 100644 --- a/src/IK/tests/QPFixedBaseInverseKinematicsTest.cpp +++ b/src/IK/tests/QPFixedBaseInverseKinematicsTest.cpp @@ -39,7 +39,7 @@ using namespace BipedalLocomotion::Conversions; using namespace std::chrono_literals; constexpr auto robotVelocity = "robotVelocity"; -constexpr std::chrono::nanoseconds dT = 5ms; +constexpr std::chrono::nanoseconds dT = 10ms; struct InverseKinematicsAndTasks { @@ -62,7 +62,7 @@ struct System std::shared_ptr createParameterHandler() { - constexpr double gain = 0.5; + constexpr double gain = 20.0; auto parameterHandler = std::make_shared(); parameterHandler->setParameter("robot_velocity_variable_name", robotVelocity); @@ -110,7 +110,6 @@ InverseKinematicsAndTasks createIK(std::shared_ptr handler, out.regularizationTask = std::make_shared(); - REQUIRE(out.regularizationTask->setKinDyn(kinDyn)); REQUIRE(out.regularizationTask->initialize(handler->getGroup("REGULARIZATION_TASK"))); REQUIRE(out.ik->addTask(out.regularizationTask, @@ -189,7 +188,11 @@ System getSystem(std::shared_ptr kinDyn) Eigen::VectorXd jointPositions(kinDyn->getNrOfDegreesOfFreedom()); Eigen::Vector3d gravity; - REQUIRE(kinDyn->getRobotState(basePose, jointPositions, baseVelocity, jointVelocities, gravity)); + REQUIRE(kinDyn->getRobotState(basePose, // + jointPositions, + baseVelocity, + jointVelocities, + gravity)); // perturb the joint position for (int i = 0; i < kinDyn->getNrOfDegreesOfFreedom(); i++) @@ -197,7 +200,6 @@ System getSystem(std::shared_ptr kinDyn) jointPositions[i] += distribution(generator); } - out.dynamics = std::make_shared(); out.dynamics->setState({basePose.topRightCorner<3, 1>(), toManifRot(basePose.topLeftCorner<3, 3>()), @@ -226,7 +228,11 @@ TEST_CASE("QP-IK") DYNAMIC_SECTION("Model with " << numberOfJoints << " joints") { // create the model - const iDynTree::Model model = iDynTree::getRandomModel(numberOfJoints); + constexpr std::size_t nrOfAdditionalFrames = 10; + constexpr bool onlyRevoluteJoints = true; + const iDynTree::Model model = iDynTree::getRandomChain(numberOfJoints, + nrOfAdditionalFrames, + onlyRevoluteJoints); REQUIRE(kinDyn->loadRobotModel(model)); const auto desiredSetPoints = getDesiredReference(kinDyn, numberOfJoints); @@ -251,7 +257,7 @@ TEST_CASE("QP-IK") REQUIRE(ikAndTasks.regularizationTask->setSetPoint(desiredSetPoints.joints)); // propagate the inverse kinematics for - constexpr std::size_t iterations = 10; + constexpr std::size_t iterations = 20; Eigen::Vector3d gravity; gravity << 0, 0, -9.81; Eigen::Matrix4d baseTransform = Eigen::Matrix4d::Identity(); diff --git a/src/IK/tests/QPInverseKinematicsTest.cpp b/src/IK/tests/QPInverseKinematicsTest.cpp index 65e4e35b12..87f757859c 100644 --- a/src/IK/tests/QPInverseKinematicsTest.cpp +++ b/src/IK/tests/QPInverseKinematicsTest.cpp @@ -320,31 +320,33 @@ inline std::string customInt2string(int i) return ss.str(); } -// Workaround for https://github.com/ami-iit/bipedal-locomotion-framework/issues/799 -inline iDynTree::Model customGetRandomModelWithNoPrismaticJoints(unsigned int nrOfJoints, size_t nrOfAdditionalFrames = 10, bool onlyRevoluteJoints=false) +// Workaround for https://github.com/ami-iit/bipedal-locomotion-framework/issues/799 and +// https://github.com/robotology/idyntree/pull/1171 +inline iDynTree::Model customGetRandomModelWithNoPrismaticJoints(unsigned int nrOfJoints, + size_t nrOfAdditionalFrames = 10, + bool onlyRevoluteJoints = false) { iDynTree::Model model; model.addLink("baseLink", iDynTree::getRandomLink()); - for(unsigned int i=0; i < nrOfJoints; i++) + for (unsigned int i = 0; i < nrOfJoints; i++) { std::string parentLink = iDynTree::getRandomLinkOfModel(model); std::string linkName = "link" + customInt2string(i); - iDynTree::addRandomLinkToModel(model,parentLink,linkName,onlyRevoluteJoints); + iDynTree::addRandomLinkToModel(model, parentLink, linkName, onlyRevoluteJoints); } - for(unsigned int i=0; i < nrOfAdditionalFrames; i++) + for (unsigned int i = 0; i < nrOfAdditionalFrames; i++) { std::string parentLink = iDynTree::getRandomLinkOfModel(model); std::string frameName = "additionalFrame" + customInt2string(i); - iDynTree::addRandomAdditionalFrameToModel(model,parentLink,frameName); + iDynTree::addRandomAdditionalFrameToModel(model, parentLink, frameName); } return model; } - TEST_CASE("QP-IK") { auto kinDyn = std::make_shared(); @@ -365,7 +367,10 @@ TEST_CASE("QP-IK") // create the model size_t nrOfAdditionalFrames = 10; bool onlyRevoluteJoints = true; - const iDynTree::Model model = customGetRandomModelWithNoPrismaticJoints(numberOfJoints,nrOfAdditionalFrames,onlyRevoluteJoints); + const iDynTree::Model model + = customGetRandomModelWithNoPrismaticJoints(numberOfJoints, + nrOfAdditionalFrames, + onlyRevoluteJoints); REQUIRE(kinDyn->loadRobotModel(model)); const auto desiredSetPoints = getDesiredReference(kinDyn, numberOfJoints); @@ -499,7 +504,11 @@ TEST_CASE("QP-IK [With strict limits]") constexpr std::size_t numberOfJoints = 30; // create the model - const iDynTree::Model model = iDynTree::getRandomModel(numberOfJoints); + size_t nrOfAdditionalFrames = 10; + bool onlyRevoluteJoints = true; + const iDynTree::Model model = customGetRandomModelWithNoPrismaticJoints(numberOfJoints, + nrOfAdditionalFrames, + onlyRevoluteJoints); REQUIRE(kinDyn->loadRobotModel(model)); const auto desiredSetPoints = getDesiredReference(kinDyn, numberOfJoints); @@ -629,7 +638,11 @@ TEST_CASE("QP-IK [With builder]") constexpr std::size_t numberOfJoints = 30; // create the model - const iDynTree::Model model = iDynTree::getRandomModel(numberOfJoints); + size_t nrOfAdditionalFrames = 10; + bool onlyRevoluteJoints = true; + const iDynTree::Model model = customGetRandomModelWithNoPrismaticJoints(numberOfJoints, + nrOfAdditionalFrames, + onlyRevoluteJoints); REQUIRE(kinDyn->loadRobotModel(model)); // VariableHandler and IK params @@ -782,7 +795,11 @@ TEST_CASE("QP-IK [Distance and Gravity tasks]") constexpr std::size_t numberOfJoints = 30; // create the model - const iDynTree::Model model = iDynTree::getRandomModel(numberOfJoints); + size_t nrOfAdditionalFrames = 10; + bool onlyRevoluteJoints = true; + const iDynTree::Model model = customGetRandomModelWithNoPrismaticJoints(numberOfJoints, + nrOfAdditionalFrames, + onlyRevoluteJoints); REQUIRE(kinDyn->loadRobotModel(model)); const auto desiredSetPoints = getDesiredReference(kinDyn, numberOfJoints); From e143f5128d292c2cc7700a6cdea565eb5a5582ca Mon Sep 17 00:00:00 2001 From: Giulio Romualdi Date: Fri, 5 Apr 2024 10:36:13 +0200 Subject: [PATCH 10/10] Remove macOS from CI --- .github/workflows/ci.yml | 43 +++------------------------------------- 1 file changed, 3 insertions(+), 40 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index fb35ef93bb..706c98efd0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -58,7 +58,7 @@ jobs: strategy: matrix: build_type: [Release, Debug] - os: [ubuntu-20.04, windows-2019, macos-latest] + os: [ubuntu-20.04, windows-2019] fail-fast: false steps: @@ -92,25 +92,6 @@ jobs: unzip vcpkg-robotology.zip -d C:/ rm vcpkg-robotology.zip - - name: Fixup brew [macOS] - if: matrix.os == 'macos-latest' - run: | - # Unlink and re-link to prevent errors when github mac runner images - # install python outside of brew, for example: - # https://github.com/orgs/Homebrew/discussions/3895 - # https://github.com/actions/setup-python/issues/577 - # https://github.com/actions/runner-images/issues/6459 - # https://github.com/actions/runner-images/issues/6507 - # https://github.com/actions/runner-images/issues/2322 - brew list -1 | grep python | while read formula; do brew unlink $formula; brew link --overwrite $formula; done - - - name: Dependencies [macOS] - if: matrix.os == 'macos-latest' - run: | - brew update - brew install ace boost eigen swig qt5 orocos-kdl qhull ipopt cppad pkg-config pybind11 \ - libmatio spdlog librealsense nlohmann-json numpy assimp - - name: Dependencies [Ubuntu] if: startsWith(matrix.os, 'ubuntu') run: | @@ -143,10 +124,6 @@ jobs: if: startsWith(matrix.os, 'ubuntu') run: echo "NUM_CORES_FOR_CMAKE_BUILD=`nproc --all`" >> $GITHUB_ENV - - name: Get number of cores to speed up cmake build [macOS] - if: matrix.os == 'macos-latest' - run: echo "NUM_CORES_FOR_CMAKE_BUILD=`sysctl -n hw.logicalcpu`" >> $GITHUB_ENV - - name: Cache Source-based Dependencies id: cache-source-deps uses: actions/cache@v3 @@ -339,8 +316,8 @@ jobs: -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install/deps .. cmake --build . --config ${{ matrix.build_type }} --target install -j${{env.NUM_CORES_FOR_CMAKE_BUILD}} - - name: Source-based Dependencies [Ubuntu/macOS] - if: steps.cache-source-deps.outputs.cache-hit != 'true' && (startsWith(matrix.os, 'ubuntu') || matrix.os == 'macos-latest') + - name: Source-based Dependencies [Ubuntu] + if: steps.cache-source-deps.outputs.cache-hit != 'true' && startsWith(matrix.os, 'ubuntu') shell: bash run: | @@ -546,20 +523,6 @@ jobs: -DENABLE_YarpRobotLoggerDevice:BOOL=ON \ -DFRAMEWORK_RUN_Valgrind_tests:BOOL=ON .. - - name: Configure [macOS] - if: matrix.os == 'macos-latest' - shell: bash - run: | - mkdir -p build - cd build - cmake -DCMAKE_PREFIX_PATH=${GITHUB_WORKSPACE}/install/deps \ - -DCMAKE_INSTALL_PREFIX=${GITHUB_WORKSPACE}/install \ - -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \ - -DFRAMEWORK_COMPILE_PYTHON_BINDINGS:BOOL=ON \ - -DPython3_ROOT_DIR=$(python -c "import sys; print(sys.prefix)") -DFRAMEWORK_USE_Python3:BOOL=ON -DFRAMEWORK_USE_pybind11:BOOL=ON \ - -DFRAMEWORK_TEST_PYTHON_BINDINGS:BOOL=OFF \ - -DBUILD_TESTING:BOOL=ON .. - - name: Check build if some dependencies are not enabled [Ubuntu] if: github.event_name != 'push' && github.event_name != 'release' && matrix.os == 'ubuntu-20.04' shell: bash