返回c++双精度给Python
Return C++ double to Python?
所以我使用python调用共享c++库中的方法。我有一个问题返回双从c++到python。我创建了一个玩具示例来展示这个问题。请随意编译并试用。
以下是python代码(soexample.py):# Python imports
from ctypes import CDLL
import numpy as np
# Open shared CPP library:
cpplib=CDLL('./libsoexample.so')
cppobj = cpplib.CPPClass_py()
# Stuck on converting to short**?
x = cpplib.func_py(cppobj)
print 'x =', x
下面是c++ (soexample.cpp):
#include <iostream>
using namespace std;
class CPPClass
{
public:
CPPClass(){}
void func(double& x)
{
x = 1.0;
}
};
// For use with python:
extern "C" {
CPPClass* CPPClass_py(){ return new CPPClass(); }
double func_py(CPPClass* myClass)
{
double x;
myClass->func(x);
return x;
}
}
编译:g++ -fPIC -Wall -Wextra -shared -o libsoexample.so soexample.cpp
当我运行时,我得到:
$ python soexample.py
x = 0
所以结果是一个值为0的类型整数。这是怎么呢
我也很好奇通过引用填充数组
From ctypes documentation:
默认情况下,假设函数返回C
int
类型。其他属性的restype
属性可以指定返回类型函数对象。
如果您将func_py
的使用更改为以下内容,则可以工作:
import ctypes
func_py = cpplib.func_py
func_py.restype = ctypes.c_double
x = func_py(cppobj)
print 'x =', x
虽然它可能适用于这个简单的情况,但您也应该指定CPPClass_py.restype
。
相关文章:
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 正在将csv文件读取为双精度矢量
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 如何在C++中的同一函数中使用字符串和双精度
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 检查是否以特定精度给出双精度
- 转换函数,将 std::数组的双精度作为参数或双精度作为参数单独转换
- C 字符串返回字符串的整数/双精度/长整型值
- 为什么将双精度转换为 int 似乎在第 16 位数字之后将其四舍五入?
- 如何使双精度值的 C++ 和 C# 中的结果相同
- 使用浮点数和双精度数的非常小数字的数学
- 使用 Xcode 将双精度存储在数组C++中
- 在 C++ 中将双精度变量写入二进制文件
- 如何从字符串转换为双精度*
- python使用BOOST浮点到c++双精度
- 返回c++双精度给Python
- 打印Python和c++双精度值时的精度差异
- 如何调用从Python返回双精度向量的c++函数
- 解析普通的python双精度列表
- 从 Python 浮点数转换为双精度C++时的精度损失