Вызов кода C ++ из Python с использованием Cython с использованием подхода distutilis
Я пытаюсь вызвать код C ++ из сценария Python, используя Cython. Мне уже удалось поработать с примером изВот но дело в том, что мой код на С ++ содержит нестандартные библиотеки из opencv. Я считаю, что я не связываю их правильно, поэтому мне нужен кто-то, чтобы посмотреть на моиsetup.py и мойcpp_rect.h а такжеcpp_rect.cpp файлы.
Ошибка, которую я получаю, связана с жирной линией в файле * .cpp:cv :: Mat img1 (7,7, CV_32FC2, Scalar (1,3)); Когда я пытаюсь проверить библиотеку, я получаю ошибку включения при выполнении$ python userect.py
:
Traceback (most recent call last):
File "userect.py", line 2, in <module>
from rectangle import Rectangle
ImportError: dlopen(/Users/marcelosalloum/Desktop/python_cpp_interface/rectangle.so, 2): Symbol not found: __ZN2cv3Mat10deallocateEv
Referenced from: /Users/marcelosalloum/Desktop/python_cpp_interface/rectangle.so
Expected in: flat namespace
in /Users/marcelosalloum/Desktop/python_cpp_interface/rectangle.so
Символ не найден (__ZN2cv3Mat10deallocateEv) как-то связан сcv::Mat::deallocate()
функция, которая указывает, что мой импорт не работает должным образом.
Есть идеи?
Мои другие занятия следующие:
Это моеsetup.py файл. Обратите внимание, что я уже включил 2 каталога, хотя не уверен, что сделал правильно:
from distutils.core import setup
from distutils.extension import Extension
from Cython.Distutils import build_ext
setup(
name = 'Demos',
ext_modules=[
Extension("rectangle",
sources=["rectangle.pyx", "cpp_rect.cpp"], # Note, you can link against a c++ library instead of including the source
include_dirs=[".", "/usr/local/include/opencv/", "/usr/local/include/"],
language="c++"),
],
cmdclass = {'build_ext': build_ext},
)
мойcpp_rect.h Файл включает в себя cv.h и пространство имен cv, как показано ниже:
#include "source/AntiShake.h"
#include <iostream>
#include "cv.h"
using namespace cv;
class Rectangle {
public:
int x0, y0, x1, y1;
Rectangle();
Rectangle(int x0, int y0, int x1, int y1);
~Rectangle();
int getLength();
int getHeight();
int getArea();
void move(int dx, int dy);
**void openCV();**
Rectangle operator+(const Rectangle& other);
};
и моя функция openCV () просто создает экземпляр cv :: Mat из opencv (файлcpp_rect.cpp):
#include "cpp_rect.h"
Rectangle::Rectangle() {
x0 = y0 = x1 = y1 = 0;
}
Rectangle::Rectangle(int a, int b, int c, int d) {
x0 = a;
y0 = b;
x1 = c;
y1 = d;
}
Rectangle::~Rectangle() {
}
void Rectangle::openCV(){
**cv::Mat img1(7,7,CV_32FC2,Scalar(1,3));**
}
...
Я могу скомпилировать файл с помощью следующей команды:$ python setup.py build_ext --inplace
, который предоставляет мне файл * .so. Но когда я запускаю свой сценарий userect.py, я получаю ошибку включения, описанную вначале в этом вопросе.
Есть идеи?