Cython:Python类包装器中的模板

Cython:Python类包装器中的模板,第1张

Cython:Python类包装器中的模板

正如您所说,Cython并不真正支持这一点。

我认为到目前为止,最简单的方法就是使用字符串替换手动生成一堆Cython文件。从“ foowrapper.pxi.src”文件(您想要的名称…)开始:

cdef class PyFoo_{T}:  cdef Foo[{T}] *thisptr  def __cinit__(self, param):    self.thisptr = new Foo[{T}](param)    # etc

接下来,通过一个简单的程序(也可能是Python)运行它以加载文件,进行字符串替换并以新名称再次保存文件。关键是:

output = pre.format(T=T) # where T is a string with a C++ class name    # e.g. "int" or "std::vector<double>"

(显然,有一些关于加载和保存的代码已被我懒洋洋地跳过了)

然后,在您的Cython文件中,您只需“包括”每个类的生成文件。Cython中的“
include”命令是文字文本包含(如C预处理程序),并且需要一个.pxi文件:

cdef extern from "header.h":    cdef cppclass Foo[T]:        Foo(T param)        # ...include "foowrapper_int.pxi"include "foowrapper_vectordouble.pxi# etc

您必须选择在编译时生成的类,但这是不可避免的(模板是编译时功能),因此您将永远无法从Python脚本环境动态生成它们,因为赢得了相应的C ++类无法生成。

其他选择

其他几个选项值得简要考虑。首先,您可以继承不依赖于模板参数

Foo<T>
的基类(例如
Foobase
)。然后
Foobase
,您需要包装Cython(为您关心的情况生成类似构造函数的函数)。仅当要调用的函数没有依赖于模板类型的参数时,这才真正可行。显然,这还涉及更改C
++代码。

section选项用于查看另一种包装方式。Boost Python肯定会对此提供本地支持(但有其自身的缺点)。我想SIP /
SWIG也可以应付(但我不知道)。必要时,您可以将它们与Cython完美地混合搭配(通过导入包含模板类的生成模块)。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5645466.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存