cv_bridge和openCV不兼容问题

1. cv_bridge不兼容问题

问题:NumPy 升级到 2.0+ 后与 ROS Noetic 的 cv_bridge 模块不兼容,但我又必须在conda环境下运行

A module that was compiled using NumPy 1.x cannot be run in NumPy 2.0.2 as it may crash. To support both 1.x and 2.x versions of NumPy, modules must be compiled with NumPy 2.0. Some module may need to rebuild instead e.g. with 'pybind11>=2.12'.

If you are a user of the module, the easiest solution will be to downgrade to 'numpy<2' or try to upgrade the affected module. We expect that some modules will need time to support NumPy 2.

解决:不用ros noetic的cv_bridge,自己编译cv_bridge与conda环境的NumPy兼容

1)激活 Conda 环境

bash 复制代码
conda activate env_xxx
bash 复制代码
mkdir /cv_ws/src
cd ~/cv_ws/src
git clone https://github.com/ros-perception/vision_opencv.git
cd vision_opencv
git checkout noetic

确认 Python 和 NumPy 都是 Conda 的:

bash 复制代码
which python
python -c "import numpy; print(numpy.__version__)"

2)安装必要依赖

bash 复制代码
sudo apt install python3-dev python3-numpy
sudo apt install ros-noetic-cv-bridge ros-noetic-vision-opencv

3)克隆源码

bash 复制代码
mkdir -p /cv_ws/src
cd ~/cv_ws/src
git clone https://github.com/ros-perception/vision_opencv.git
cd vision_opencv
git checkout noetic

4)修改编译配置

进入 cv_bridge 目录:

bash 复制代码
cd cv_bridge

修改CMakeLists.txt(~/cv_ws/src/vision_opencv/cv_bridge/CMakeLists.txt)

bash 复制代码
cmake_minimum_required(VERSION 3.0.2)
project(cv_bridge)

# 手动指定 Conda Python 环境路径
set(PYTHON_EXECUTABLE "/home/username/miniconda3/envs/CTSAC/bin/python")
set(PYTHON_INCLUDE_DIR "/home/username/miniconda3/envs/CTSAC/include/python3.9")
set(PYTHON_INCLUDE_DIRS "/home/username/miniconda3/envs/CTSAC/include/python3.9")
set(PYTHON_LIBRARY "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")
set(PYTHON_LIBRARIES "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")

# 指定 Boost 的搜索路径到 conda 环境
set(BOOST_ROOT "/home/username/miniconda3/envs/CTSAC")
set(Boost_NO_SYSTEM_PATHS TRUE)
set(Boost_INCLUDE_DIR "${BOOST_ROOT}/include")
set(Boost_LIBRARY_DIR "${BOOST_ROOT}/lib")

find_package(catkin REQUIRED COMPONENTS rosconsole sensor_msgs)

# 强制使用预设的 Python 变量,防止 find_package 覆盖
set(PYTHONLIBS_FOUND TRUE)
set(PythonLibs_FOUND TRUE)
find_package(PythonLibs REQUIRED)

# 再次确保变量设置正确(防止被 find_package 覆盖)
set(PYTHON_LIBRARY "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")
set(PYTHON_LIBRARIES "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")

if(NOT ANDROID)
  find_package(Boost REQUIRED COMPONENTS python)
else()
  find_package(Boost REQUIRED)
endif()

# 尝试找到 OpenCV
set(_opencv_version 4)
find_package(OpenCV 4 QUIET)
if(NOT OpenCV_FOUND)
  message(STATUS "Did not find OpenCV 4, trying OpenCV 3")
  set(_opencv_version 3)
endif()

find_package(OpenCV ${_opencv_version} REQUIRED
  COMPONENTS
    opencv_core
    opencv_imgproc
    opencv_imgcodecs
  CONFIG
)

catkin_package(
  INCLUDE_DIRS include
  LIBRARIES ${PROJECT_NAME}
  CATKIN_DEPENDS rosconsole sensor_msgs
  DEPENDS OpenCV
  CFG_EXTRAS cv_bridge-extras.cmake
)

catkin_python_setup()

include_directories(
  include
  ${Boost_INCLUDE_DIRS}
  ${OpenCV_INCLUDE_DIRS}
  ${catkin_INCLUDE_DIRS}
  ${PYTHON_INCLUDE_DIRS}
)
link_directories(${Boost_LIBRARY_DIRS})

if(NOT ANDROID)
  add_subdirectory(python)
endif()

add_subdirectory(src)

if(CATKIN_ENABLE_TESTING)
  add_subdirectory(test)
endif()

install(
  DIRECTORY include/${PROJECT_NAME}/
  DESTINATION ${CATKIN_PACKAGE_INCLUDE_DESTINATION}
)

修改修改 cv_bridge/src/CMakeLists.txt(~/cv_ws/src/vision_opencv/cv_bridge/src/CMakeLists.txt)

bash 复制代码
# 强制设置 Python 变量(必须在 find_package 之前)
set(PYTHON_EXECUTABLE "/home/username/miniconda3/envs/CTSAC/bin/python")
set(PYTHON_INCLUDE_DIR "/home/username/miniconda3/envs/CTSAC/include/python3.9")
set(PYTHON_INCLUDE_DIRS "/home/username/miniconda3/envs/CTSAC/include/python3.9")
set(PYTHON_INCLUDE_PATH "/home/username/miniconda3/envs/CTSAC/include/python3.9")
set(PYTHON_LIBRARY "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")
set(PYTHON_LIBRARIES "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")
set(PYTHONLIBS_FOUND TRUE)
set(PythonLibs_FOUND TRUE)
set(PYTHON_VERSION_MAJOR 3)
set(PYTHON_VERSION_MINOR 9)

# add library
include_directories(./)
add_library(${PROJECT_NAME} cv_bridge.cpp rgb_colors.cpp)
add_dependencies(${PROJECT_NAME} ${catkin_EXPORTED_TARGETS})
target_link_libraries(${PROJECT_NAME} ${OpenCV_LIBRARIES} ${catkin_LIBRARIES})

install(TARGETS ${PROJECT_NAME}
  LIBRARY DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION}
  ARCHIVE DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION}
  RUNTIME DESTINATION ${CATKIN_GLOBAL_BIN_DESTINATION}
)

if(NOT ANDROID)
# add a Boost Python library
find_package(PythonInterp REQUIRED)
find_package(PythonLibs "${PYTHON_VERSION_MAJOR}.${PYTHON_VERSION_MINOR}")

# 再次强制设置(防止被 find_package 覆盖)
set(PYTHON_LIBRARY "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")
set(PYTHON_LIBRARIES "/home/username/miniconda3/envs/CTSAC/lib/libpython3.9.so")

#Get the numpy include directory from its python module
if(NOT PYTHON_NUMPY_INCLUDE_DIR)
    execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "import numpy; print(numpy.get_include())"
                    RESULT_VARIABLE PYTHON_NUMPY_PROCESS
                    OUTPUT_VARIABLE PYTHON_NUMPY_INCLUDE_DIR
                    OUTPUT_STRIP_TRAILING_WHITESPACE)

    if(PYTHON_NUMPY_PROCESS EQUAL 0)
       file(TO_CMAKE_PATH "${PYTHON_NUMPY_INCLUDE_DIR}" PYTHON_NUMPY_INCLUDE_CMAKE_PATH)
       set(PYTHON_NUMPY_INCLUDE_DIR ${PYTHON_NUMPY_INCLUDE_CMAKE_PATH} CACHE PATH "Numpy include directory")
    else(PYTHON_NUMPY_PROCESS EQUAL 0)
        message(SEND_ERROR "Could not determine the NumPy include directory, verify that NumPy was installed correctly.")
    endif(PYTHON_NUMPY_PROCESS EQUAL 0)
 endif(NOT PYTHON_NUMPY_INCLUDE_DIR)

include_directories(${PYTHON_INCLUDE_PATH} ${Boost_INCLUDE_DIRS} ${PYTHON_NUMPY_INCLUDE_DIR})

if (PYTHON_VERSION_MAJOR VERSION_EQUAL 3)
  add_definitions(-DPYTHON3)
endif()

add_library(${PROJECT_NAME}_boost module.cpp module_opencv4.cpp)
target_link_libraries(${PROJECT_NAME}_boost ${Boost_LIBRARIES}
                                            ${catkin_LIBRARIES}
                                            ${PROJECT_NAME}
)

if(NOT APPLE)
  target_link_libraries(${PROJECT_NAME}_boost ${PYTHON_LIBRARIES})
endif()

set_target_properties(${PROJECT_NAME}_boost PROPERTIES
                      LIBRARY_OUTPUT_DIRECTORY ${CATKIN_DEVEL_PREFIX}/${CATKIN_GLOBAL_PYTHON_DESTINATION}/${PROJECT_NAME}/boost/
                      RUNTIME_OUTPUT_DIRECTORY ${CATKIN_DEVEL_PREFIX}/${CATKIN_GLOBAL_PYTHON_DESTINATION}/${PROJECT_NAME}/boost/
                      PREFIX ""
)
if(APPLE)
  set_target_properties(${PROJECT_NAME}_boost PROPERTIES
                        SUFFIX ".so")
  set_target_properties(${PROJECT_NAME}_boost PROPERTIES
                        LINK_FLAGS "-undefined dynamic_lookup")
endif()
if(MSVC)
  set_target_properties(${PROJECT_NAME}_boost PROPERTIES
                        SUFFIX ".pyd")
endif()

install(TARGETS ${PROJECT_NAME}_boost DESTINATION ${CATKIN_PACKAGE_PYTHON_DESTINATION}/boost/)
endif()

5)编译

bash 复制代码
cd ~/cv_ws
rm -rf build devel
catkin_make
# 或者
catkin_make -DPYTHON_EXECUTABLE=/home/username/miniconda3/envs/CTSAC/bin/python

6)source工作空间

bash 复制代码
source ~/cv_ws/devel/setup.bash
python -c "from cv_bridge import CvBridge; print('cv_bridge OK')"

7)cv_ws的工作空间也要source,而scout_ws工作空间也要source

方法一:把编译顺序写入.bashrc文件

bash 复制代码
nano ~/.bashrc
source /opt/ros/noetic/setup.bash
source ~/scout_ws/devel/setup.bash
source ~/cv_ws/devel/setup.bash


# 保存后
source ~/.bashrc

方法二:合并工作空间

如果cv_bridge只是给scout_ws用的,可以直接把cv_bridge的源码放到scout_ws:

bash 复制代码
cp -r ~/cv_ws/src/vision_opencv ~/scout_ws/src/
cd ~/scout_ws
catkin_make

这样只需要一个工作空间。

8)编译成功后验证方法

bash 复制代码
python -c "import cv_bridge; print('cv_bridge OK')"
相关推荐
励志成为糕手1 分钟前
循环神经网络(RNN):时序数据的深度学习模型
人工智能·rnn·深度学习·gru·lstm
前端开发工程师请求出战4 分钟前
Advanced RAG实战:评估闭环与持续优化体系
人工智能·全栈
Nturmoils4 分钟前
基于Rokid CXR-M SDK实现AR智能助手应用:让AI大模型走进AR眼镜
人工智能·aigc
java_logo37 分钟前
LobeHub Docker 容器化部署指南
运维·人工智能·docker·ai·容器·ai编程·ai写作
清云逸仙1 小时前
AI Prompt应用实战:评论审核系统实现
人工智能·经验分享·ai·语言模型·prompt·ai编程
正宗咸豆花1 小时前
Prompt Minder:重塑 AI 时代的提示词工程基础设施
人工智能·prompt
清云逸仙1 小时前
使用AI(GPT-4)实现AI prompt 应用--自动审核评论系统
人工智能·经验分享·ai·语言模型·ai编程
Mintopia2 小时前
Claude Code CLI UI
人工智能·aigc·全栈
Mr.Winter`2 小时前
基于Proto3和单例模式的系统参数配置模块设计(附C++案例实现)
c++·人工智能·单例模式·机器人
Mintopia2 小时前
🌐 动态网络环境下的 WebAIGC 断点续传与容错技术
前端·人工智能·aigc