- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在尝试使用 Numpy ndarray 将链接到 OpenCV 并使用 OpenCV 的 Mat 数据类型的动态 C++ 库函数公开给 Python 2.7 时遇到了问题.
我想出了一个类似于 lightalchemist's solution here 的解决方案我也尝试过使用 boost::python 和 boost::numpy(也链接到 Python 2.7)described in this SO question.
现在我坚持使用前者。我已经到了可以在 iPython 中加载模块的地步,并且我看到了一个我正在尝试使用 inspect 模块移植的函数,我什至可以调用它甚至执行它。但是,当我尝试使用 NumpyAllocator ( see lightalchemist's solution ) 类将 Mat 对象转换回 ndarray 时,问题就会出现。首先,当我尝试从外部 C++ 可执行文件调用 pyopencv_from 函数时,它在编码时使用 NumpyAllocator,它在
PyEnsureGIL gil;
,每次都没有消息。 Lightalchemist 的解决方案没有在 pyopencv_to 中使用它(编辑:如果传入的 ndarray 已经分配),它似乎可以工作。但是,官方 OpenCV cv2.cpp 也确实在其中使用了分配器,因此如果我尝试使用该函数甚至无法将输入 ndarray 转换为 Mat。
当我尝试使用 iPython 中的模块时,它看到了函数。同样,它会正确执行它(将进度打印到控制台),但是当它到达 pyopencv_from 时,它会出现段错误并终止 iPython shell。
编辑:我使用与 lightalchemist 完全相同的来源,除了我公开一个函数,与官方 OpenCV 端口相同:
static PyMethodDef methods[] = {
{"findEdgesCGTG", (PyCFunction)pycvex_findEdgesCGTG, METH_KEYWORDS, "findEdgesCGTG(source) -> edgeGradient, edgeOrientations"},
{NULL, NULL}
};
extern "C"
#if defined WIN32 || defined _WIN32
__declspec(dllexport)
#endif
void initcvex()
{
import_array();
PyObject* m = Py_InitModule(MODULESTR, methods);
PyObject* d = PyModule_GetDict(m);
opencv_error = PyErr_NewException((char*)MODULESTR".error", NULL, NULL);
PyDict_SetItemString(d, "error", opencv_error);
}
有人知道如何解决这个转换问题吗?
最佳答案
问题不是
PyEnsureGIL gil;
声明。只有在我尝试使用外部 C++ 函数时才行不通。当我在这里尝试将两个输出值打包成一个时,问题实际上发生了:
return Py_BuildValue("(NN)", pyopencv_from(edgeGrad), pyopencv_from(edgeOri));
临时解决方法是使用以下语句:
return pyopencv_from(edgeGrad);
编辑:对不起,我又搞砸了。 Py_BuildValue 工作得很好。刚刚再次测试了我的功能,它运行良好。一定是我上次测试的时候忘记放return关键字了,所以报了“error return without exception set”。
这是完整的功能代码(我希望它对任何将 OpenCV 的东西移植到 python 的人有用)
static PyObject* pycvex_findEdgesCGTG(PyObject* , PyObject* args, PyObject* kw)
{
PyObject* pyobj_source = NULL;
Mat source;
Mat edgeGrad;
Mat edgeOri;
const char* keywords[] = { "src", NULL };
if( PyArg_ParseTupleAndKeywords(args, kw, "O:findEdgesCGTG", (char**)keywords, &pyobj_source) &&
pyopencv_to(pyobj_source, source));
{
ERRWRAP2(findEdgesCGTG(source,edgeGrad,edgeOri));
return Py_BuildValue("(NN)", pyopencv_from(edgeGrad), pyopencv_from(edgeOri));
}
return NULL;
}
更新:
这是 github repo使用我为使用 OpenCV 的 Mat 类公开代码而编写的开放 C++ 代码,尽可能减少痛苦。这适用于 OpenCV 3.X。
对于 OpenCV 2.X,您可以使用 this code/Yati Sagade 的例子。如果您想使用 opencv Mat 类公开函数而不用担心显式转换,可以很容易地将我的代码中的 Booost 转换器与 Yati 代码中的转换函数相适应。
关于python - 将基于 OpenCV 的 C++ 函数与 Mat/Numpy 转换为 Python 公开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13745265/
我正在尝试将一个字符串逐个字符地复制到另一个字符串中。目的不是复制整个字符串,而是复制其中的一部分(我稍后会为此做一些条件......) 但我不知道如何使用迭代器。 你能帮帮我吗? std::stri
我想将 void 指针转换为结构引用。 结构的最小示例: #include "Interface.h" class Foo { public: Foo() : mAddress((uint
这有点烦人:我有一个 div,它从窗口的左上角开始过渡,即使它位于文档的其他任何位置。我试过 usign -webkit-transform-origin 但没有成功,也许我用错了。有人可以帮助我吗?
假设,如果将 CSS3 转换/转换/动画分配给 DOM 元素,我是否可以检测到该过程的状态? 我想这样做的原因是因为我正在寻找类似过渡链的东西,例如,在前一个过渡之后运行一个过渡。 最佳答案 我在 h
最近我遇到了“不稳定”屏幕,这很可能是由 CSS 转换引起的。事实上,它只发生在 Chrome 浏览器 上(可能还有 Safari,因为一些人也报告了它)。知道如何让它看起来光滑吗?此外,您可能会注意
我正在开发一个简单的 slider ,它使用 CSS 过渡来为幻灯片设置动画。我用一些基本样式和一些 javascript 创建了一支笔 here .注意:由于 Codepen 使用 Prefixfr
我正在使用以下代码返回 IList: public IList FindCodesByCountry(string country) { var query =
如何设计像这样的操作: 计算 转化 翻译 例如:从“EUR”转换为“CNY”金额“100”。 这是 /convert?from=EUR&to=CNY&amount=100 RESTful 吗? 最佳答
我使用 jquery 组合了一个图像滚动器,如下所示 function rotateImages(whichHolder, start) { var images = $('#' +which
如何使用 CSS (-moz-transform) 更改一个如下所示的 div: 最佳答案 你可以看看Mozilla Developer Center .甚至还有例子。 但是,在我看来,您的具体示例不
我需要帮助我正在尝试在选中和未选中的汉堡菜单上实现动画。我能够为菜单设置动画,但我不知道如何在转换为 0 时为左菜单动画设置动画 &__menu { transform: translateX(
我正在为字典格式之间的转换而苦苦挣扎:我正在尝试将下面的项目数组转换为下面的结果数组。本质上是通过在项目第一个元素中查找重复项,然后仅在第一个参数不同时才将文件添加到结果集中。 var items:[
如果我有两个定义相同的结构,那么在它们之间进行转换的最佳方式是什么? struct A { int i; float f; }; struct B { int i; float f; }; void
我编写了一个 javascript 代码,可以将视口(viewport)从一个链接滑动到另一个链接。基本上一切正常,你怎么能在那里看到http://jsfiddle.net/DruwJ/8/ 我现在的
我需要将文件上传到 meteor ,对其进行一些图像处理(必要时进行图像转换,从图像生成缩略图),然后将其存储在外部图像存储服务器(s3)中。这应该尽可能快。 您对 nodejs 图像处理库有什么建议
刚开始接触KDB+,有一些问题很难从Q for Mortals中得到。 说,这里 http://code.kx.com/wiki/JB:QforMortals2/casting_and_enumera
我在这里的一个项目中使用 JSF 1.2 和 IceFaces 1.8。 我有一个页面,它基本上是一大堆浮点数字段的大编辑网格。这是通过 inputText 实现的页面上的字段指向具有原始值的值对象
ScnMatrix4 是一个 4x4 矩阵。我的问题是什么矩阵行对应于位置(ScnVector3),旋转(ScnVector4),比例(ScnVector3)。第 4 行是空的吗? 编辑: 我玩弄了
恐怕我是 Scala 新手: 我正在尝试根据一些简单的逻辑将 Map 转换为新 Map: val postVals = Map("test" -> "testing1", "test2" -> "te
输入: This is sample 1 This is sample 2 输出: ~COLOR~[Green]This is sample 1~COLOR~[Red]This is sam
我是一名优秀的程序员,十分优秀!