私の目標は、ctypes を使用して、Python 内から個別に作成している C++ ライブラリを呼び出すことです。そこでは、numpy ベクトルをポインターを介して C++ ルーチンに渡します。したがって、Python はメモリを割り当ててアドレスを渡すだけで、C++ ルーチンがデータにアクセスして計算を実行し、結果を返します。
私は ctypes を初めて使用するので、現在、動作するおもちゃの例を徐々に作成しています。C++ コードの作成と、Python ラッパー コードが使用する C extern インターフェイスの作成から始めています。私はまだ Python ラッパー コードに着手していませんが、その側面についてはすでにある程度の経験があります。
これは、コンストラクターと単純な合計関数を含む私の例です。
// foo.cpp //
#include <iostream>
#include <string>
#include <vector>
using namespace std;
class Data {
public:
Data(vector<double>*);
void PrintTotal(void);
private:
vector<double>* myContents;
};
Data::Data(vector<double>* input) {
std::cout << "Entered constructor in C++" << std::endl;
myContents = input;
}
void Data::PrintTotal(void) {
double total = 0;
for (int i=0; i<myContents->size(); i++){
total += (*myContents)[i];
}
std::cout << "Hello, my total is " << total << std::endl;
}
extern "C" {
Data* Data_new(double (**input)) {return new Data(input);}
void Print_Total(Data* pData) {pData->PrintTotal();}
}
特に、STL の vector クラスを使用していることに注意してください。これは、以下で説明する問題の一部である可能性があります。クラスData
はデータへのポインタを保持し、データを複製しないという考え方です。
コマンドを使用してこれをコンパイルしようとすると
g++ -c -fPIC foo.cpp -o foo.o
Linux マシンでは、次のエラーが表示されます。
foo.cpp: In function âData* Data_new(double**)â:
foo.cpp:26: error: no matching function for call to âData::Data(double**&)â
foo.cpp:13: note: candidates are: Data::Data(std::vector<double, std::allocator<double> >*)
foo.cpp:6: note: Data::Data(const Data&)
これは、私にはかなり明確に思えます: 最後の行から 3 行目 (#26) で Data コンストラクターを呼び出す方法foo.cpp
が、コードの C++ 部分に記述したコンストラクターと一致しないということです。C++ コードと C extern コードの両方で、入力が double のベクトル/配列へのポインターであると言おうとしています。36 行目で他のオプションを試しましたが、まだコンパイルできません。
vector
C++ 部分でクラス (実際のアルゴリズムをコーディングするときに役立つ) を使用しながら、extern C 部分を作成するにはどうすればよいですか? vector
extern C ではうまく動作しない STL の一部であるため、問題が発生していますか?
前もって感謝します。