- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试通过 SWIG 和 Python 重用一些旧的 C 代码。现在我很困惑。我得到的错误可以用一个小例子来证明:
bsp.h:
extern void add(int a[], int b[], int c[]);
bsp.c:
#include "bsp.h"
void add(int a[], int b[], int c[])
{
c[0] = a[0] + b[0];
c[1] = a[1] + b[1];
}
bsp.i
%module bsp
%{
#include "bsp.h";
%}
%include "bsp.h";
设置.py:
#!/usr/bin/env python
from distutils.core import setup, Extension
bsp_module = Extension('_bsp',
sources = ['bsp_wrap.c', 'bsp.c']
)
setup(name = 'bsp',
ext_modules = [bsp_module],
py_modules = ["bsp"]
)
示例 Python 文件“pybsp.py”:
import bsp
a = [1, 1]
b = [1, 1]
c = []
bsp.add(a, b, c)
print(c)
我得到了错误:
Traceback (most recent call last):
File "pybsp.py", line 31, in <module>
bsp.add(a, b, c)
TypeError: in method 'add', argument 1 of type 'int []'
现在,我感到困惑的是 SWIG Documentation说:“SWIG 完全支持 C/C++ 指针。此外,SWIG 可以处理不完整的类型信息。”
我也试过添加
%apply int * INPUT { int *a}
%apply int * INPUT { int *b}
%apply int * OUTPUT { int *c}
我的 .i 文件,在这种情况下被推荐,但没有成功。我的猜测是,我必须在 Python 中创建一个类似于对象的指针才能传递,但我不知道它是如何工作的,但我也希望有一种更简单的方法。
非常感谢您的帮助!
P.S.:如您所料,这是我第一次接触 SWIG,因此很遗憾,我无法从看似相似的问题的解决方案中推导出解决方案。
编辑:我发现对于具有给定维度的数组,如上所述,NumPy 似乎是避免手动包装的好选择。给出了基本的例子here.因此,我将函数定义更改为
void add(int* a, int dim_a, int *b, int dim_b, int *c, int dim_c)
现在包装器似乎有机会将 NumPy 数组转换为 C 数组。
i-文件
%module bsp
%{
#define SWIG_FILE_WITH_INIT
#include "bsp.h"
%}
%include "numpy.i"
%init %{
import_array();
%}
%apply (int* IN_ARRAY1, int DIM1){(int* a, int dim_a), (int* b, int dim_b)}
%apply (int* ARGOUT_ARRAY1, int DIM1){(int* c, int dim_c)}
%include "bsp.h"
setup.py
#!/usr/bin/env python
from distutils.core import setup, Extension
import numpy
try:
numpy_include = numpy.get_include()
except AttributeError:
numpy_include = numpy.get_numpy_include()
bsp_module = Extension('_bsp',
sources=['bsp_wrap.c', 'bsp.c'],
include_dirs=[numpy_include]
)
setup(name='bsp',
ext_modules=[bsp_module],
py_modules=["_bsp"]
)
最后是 python 脚本,我想在其中使用 int32 来避免来自 NumPy 的类型转换错误(int64 -> int32)
import bsp
import numpy as np
a = np.array([1, 1], dtype=np.int32)
b = np.array([1, 1], dtype=np.int32)
c = np.array([1, 1], dtype=np.int32)
bsp.add(a, b, c)
print(c)
现在我摆脱了以前的错误,但我有一个新错误:
File "pybsp.py", line 10, in <module>
bsp.add(a, b, c)
TypeError: Int dimension expected. 'unknown type' given.
有什么建议吗?
最佳答案
好的,现在我知道了。正如上面编辑中所写,使用 numpy.i 可以很舒服地包装数组。我没有看到的是,ARGOUT 数组不需要数组作为输入,就像在 C 中一样。只需要维度。因此,使用上面的代码,脚本
import bsp
import numpy as np
a = np.array([1, 1], dtype=np.int32)
b = np.array([1, 1], dtype=np.int32)
c = bsp.add(a, b, np.shape(a)[0])
print(c)
给出想要的输出
[2 2]
关于python - SWIG+c+Python : Passing and receiving c arrays,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36222455/
我正在制作一个 C++ 库的包装器,以便它可以从 Java 中使用,我正在用 Swig 做这个。 我面临的是我有一个类(class) SomeClass ,它有一些重载的方法( someMethod
我有许多要在 SWIG 中重命名的类。我的大部分类(class)看起来像这样some_class ,我想将其重命名为 SomeClass .这很简单: %replace("%(camelcase)s"
PyPy 有一些 compatibility limitations ,尤其是关于 CPython C API。 我用 QuickFix预编译的 SWIG 绑定(bind)附带的包,我正在考虑将它与
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
使用 SWIG 生成接口(interface)模块时,生成的 C/C++ 文件包含大量静态样板函数。因此,如果想通过在同一个应用程序中使用许多单独编译的小接口(interface)来模块化 SWIG
我正在应用 SWIG 手册中有关嵌套类的解决方法,该部分使用全局内部类。在这里,我将向您展示一个类似于手册中的版本,但为您尽可能地简化了。我还必须将内联定义 {} 添加到 method(),因为没有它
我有一个现有的库 (JPhysX),它是原生 C++ 库 (PhysX) 的 Java 包装器。 Java 库使用 SWIG 生成的类型,例如 com.jphysx.SWIGTYPE_p_NxStre
有没有办法动态向下转换 swig 对象的 swig 代理? 这样做的原因是为了模拟 C++ 向下转换,但纯粹来自 python。例如,典型的 C++ 用法是 MyBase* obj = new MyB
我在远程服务器上工作,所以我在本地安装了 swig,使用 -prefix=/home/user/directory。 我有一个来自同事的 makefile,其中包含以下命令: swig $(SWIG_
据我所知,在用于将 c++ 文件编译为 python 扩展模块的 .i 文件中,我们可以添加一些 python 代码,如下所示(来自 example for adding additional pyt
我的 Swig 文件 (.i) 中有以下代码: %extend vgSofa::handler::VertexShape { vgd::Shp createVSWithNode( so
我有一个用 swig 包装的类的 C++ 代码。我无法修改代码或包装。在 python 中,我使用 ctypes 拥有一个指向所述 C++ 类的实例的指针。如何围绕该指针创建一个 swig 包装器?
我开始掌握 SWIG 的窍门,SWIG 的最新版本 (v3.0) 似乎可以处理我开箱即用所需的一切,包括 C++11 功能,但我遇到了麻烦开始在我的导演类(class)中使用 shared_ptr。
我正在使用 javacode 类型映射来添加一些附加函数来代替 SWIG 生成的函数。我想删除 SWIG 为 unsigned char mac[6]; 生成的默认 getter 和 setter(p
我正在使用 SWIG 为我的 C 库生成 Python 语言绑定(bind)。我已经设法构建了绑定(bind)和导出的数据结构,但在使用该库时我不得不跳过一些障碍。 例如,C 头文件的数据类型和函数原
我最近在node-js应用程序中从jade模板引擎切换到了swig。在使用jade时我使用了命令 jade.render('/sample.jade',{obj:object});渲染模板并传递对象。
我在我的 python 代码中发现了瓶颈,尝试了 Psycho 等。然后决定编写一个 c/c++ 扩展来提高性能。 在 swig 的帮助下,您几乎不需要关心参数等。一切正常。 现在我的问题是:swig
由于 SWIG 无法解析 __attribute__((packed))在我想包装的一些 C 结构上,我通过放置一个 #define __attribute__(x) 在我的.i文件。 这什么时候会来
我有一个包含 C++ header 的 SWIG 文件。 痛饮文件: %module my_module %{ #include "my_c_file.h" %} %include "my_c_fil
我正在尝试学习如何使用 SWIG,并且想知道我是否正在执行一些不需要执行的额外步骤。我目前有文件 Dog.cpp、Dog.h 和 Dog.i。我正在尝试使用 SWIG 包装 Dog.cpp 以便在 P
我是一名优秀的程序员,十分优秀!