-
Notifications
You must be signed in to change notification settings - Fork 107
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enable qpOASES on Windows and fix Windows build #327
Enable qpOASES on Windows and fix Windows build #327
Conversation
Two tests are failing with segfaults on Windows:
This doesn't happen locally so I am not sure exactly what is going on. I suspect there is a subtle memory error somewhere that happens on all machines, but only in certain circumstances causes a problem. Maybe analyze with valgrind to make sure there isn't a problem in the core libraries? |
Why is this case? |
The unit tests filter out OSQP here:
I disabled the filter and osqp does fail the test. |
Why is OSQP failing on windows but not on linux? |
Linux has other solvers so it doesn’t use osqp. Windows only had osqp so these tests were failing because no solvers were available after osqp was filtered out. |
|
I tested it and this also works on Linux (with some minor changes). I use Jammy/Humble, where qpOASES is not available, so this is a great PR, thanks. |
@rjoomen Thanks for testing on Linux and the review! |
Okay, so I tested this locally and the unit test is failing because ipopt also uses qpOASES and it looks like it is using the new qpOASES which must not be the same version. |
On windows the segfault in numerical_ik_unit and sphere collision appears to be coming from the logger. I disabled logging and it seems to fix the issue, I am testing the numerical ik now. |
Yea, the segfault for the ipopt is occurring on the Ubuntu builds. |
Can you rework the link libraries to the trajopt_ifopt module doesn't see qpoases? I can disable qpoases on Linux again to avoid this problem for now since it isn't important for Linux. |
If you replace the trajopt_sqp/test/CMakeLists.txt with the contents below it solve the issue. find_package(GTest REQUIRED)
find_package(trajopt REQUIRED)
if(NOT TARGET GTest::GTest)
add_library(GTest::GTest INTERFACE IMPORTED)
set_target_properties(GTest::GTest PROPERTIES INTERFACE_INCLUDE_DIRECTORIES "${GTEST_INCLUDE_DIRS}")
if(${GTEST_LIBRARIES})
set_target_properties(GTest::GTest PROPERTIES INTERFACE_LINK_LIBRARIES "${GTEST_LIBRARIES}")
else()
if(MSVC)
set_target_properties(GTest::GTest PROPERTIES INTERFACE_LINK_LIBRARIES "gtest.lib")
else()
set_target_properties(GTest::GTest PROPERTIES INTERFACE_LINK_LIBRARIES "libgtest.so")
endif()
endif()
endif()
if(NOT TARGET GTest::Main)
add_library(GTest::Main INTERFACE IMPORTED)
set_target_properties(GTest::Main PROPERTIES INTERFACE_INCLUDE_DIRECTORIES "${GTEST_INCLUDE_DIRS}")
if(${GTEST_MAIN_LIBRARIES})
set_target_properties(GTest::Main PROPERTIES INTERFACE_LINK_LIBRARIES "${GTEST_MAIN_LIBRARIES}")
else()
if(MSVC)
set_target_properties(GTest::Main PROPERTIES INTERFACE_LINK_LIBRARIES "gtest_main.lib")
else()
set_target_properties(GTest::Main PROPERTIES INTERFACE_LINK_LIBRARIES "libgtest_main.so")
endif()
endif()
endif()
include(GoogleTest)
macro(add_gtest test_name test_file)
add_executable(${test_name} ${test_file})
target_compile_options(${test_name} PRIVATE ${TRAJOPT_COMPILE_OPTIONS_PRIVATE} ${TRAJOPT_COMPILE_OPTIONS_PUBLIC})
target_compile_definitions(${test_name} PRIVATE ${TRAJOPT_COMPILE_DEFINITIONS}
TRAJOPT_IFOPT_DIR="${CMAKE_SOURCE_DIR}")
target_cxx_version(${test_name} PRIVATE VERSION ${TRAJOPT_CXX_VERSION})
target_clang_tidy(${test_name} ENABLE ${TRAJOPT_ENABLE_CLANG_TIDY})
target_link_libraries(
${test_name}
${PROJECT_NAME}
console_bridge
ifopt::ifopt_ipopt
trajopt::trajopt_ifopt
trajopt::trajopt_test_data
GTest::GTest
GTest::Main)
target_include_directories(${test_name} PRIVATE "$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>"
${GTEST_INCLUDE_DIRS})
target_include_directories(${test_name} SYSTEM PRIVATE ${PCL_INCLUDE_DIRS})
add_gtest_discover_tests(${test_name})
add_dependencies(${test_name} ${PROJECT_NAME})
add_dependencies(run_tests ${test_name})
endmacro()
add_gtest(${PROJECT_NAME}_expressions_unit expressions_unit.cpp)
add_gtest(${PROJECT_NAME}_joint_position_optimization_unit joint_position_optimization_unit.cpp)
add_gtest(${PROJECT_NAME}_joint_velocity_optimization_unit joint_velocity_optimization_unit.cpp)
add_gtest(${PROJECT_NAME}_joint_acceleration_optimization_unit joint_acceleration_optimization_unit.cpp)
add_gtest(${PROJECT_NAME}_joint_jerk_optimization_unit joint_jerk_optimization_unit.cpp)
add_gtest(${PROJECT_NAME}_cast_cost_attached_unit cast_cost_attached_unit.cpp)
add_gtest(${PROJECT_NAME}_cast_cost_octomap_unit cast_cost_octomap_unit.cpp)
add_gtest(${PROJECT_NAME}_cast_cost_unit cast_cost_unit.cpp)
add_gtest(${PROJECT_NAME}_cast_cost_world_unit cast_cost_world_unit.cpp)
add_gtest(${PROJECT_NAME}_numerical_ik_unit numerical_ik_unit.cpp)
add_gtest(${PROJECT_NAME}_planning_unit planning_unit.cpp)
add_gtest(${PROJECT_NAME}_simple_collision_unit simple_collision_unit.cpp)
add_gtest(${PROJECT_NAME}_cart_position_optimization_unit cart_position_optimization_unit.cpp)
# This is for comparison and should be moved to trajopt
add_executable(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit cart_position_optimization_trajopt_sco_unit.cpp)
target_compile_options(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit PRIVATE ${TRAJOPT_COMPILE_OPTIONS_PRIVATE} ${TRAJOPT_COMPILE_OPTIONS_PUBLIC})
target_compile_definitions(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit PRIVATE ${TRAJOPT_COMPILE_DEFINITIONS}
TRAJOPT_IFOPT_DIR="${CMAKE_SOURCE_DIR}")
target_cxx_version(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit PRIVATE VERSION ${TRAJOPT_CXX_VERSION})
target_clang_tidy(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit ENABLE ${TRAJOPT_ENABLE_CLANG_TIDY})
target_link_libraries(
${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit
${PROJECT_NAME}
console_bridge
ifopt::ifopt_ipopt
trajopt::trajopt_ifopt
trajopt::trajopt_test_data
trajopt::trajopt
GTest::GTest
GTest::Main)
target_include_directories(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit PRIVATE "$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>"
${GTEST_INCLUDE_DIRS})
target_include_directories(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit SYSTEM PRIVATE ${PCL_INCLUDE_DIRS})
add_gtest_discover_tests(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit)
add_dependencies(${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit ${PROJECT_NAME})
add_dependencies(run_tests ${PROJECT_NAME}_cart_position_optimization_trajopt_sco_unit)
|
The issue was all of the trajopt_sqp unit tests where linking against trajopt when it was not needed causing the issue. |
Does tesseract planning still work or does it have similar issues? |
Nope, just ran a few trajopt_ifopt examples without any issues though we do not use ipopt for motion planning just testing in trajopt_sqp. |
Issue #331 created for logger problem. |
All checks are passing |
This PR adds qpOAESES as an external package on windows. The tests were failing because OSQP is not a great solver for trajopt. The Windows action is updated to use vcpkg master to avoid an error in the most recent release of vcpkg.