3

私は基本クラスを持っています:

  template <class T> 
  class A{
         public:
           // some data
           T data;
           //some functions like constructs etc.
            ...
           // one virtual function
           virtual void evaluate() = 0;

   }

および派生クラス:

 template <class T> 
 class B:public A<T>{
          public:
          // some functions like constructors etc.
          virtual void evaluate();
          __global__ void function2();   // **** error message

 } 

また、私は持っています

 template <class T> void
 B<T>::evaluate()
 { 
    dim3 grid(1);dim3 block(1);  
    void function2<<<grid,block>>>();
 }

template <class T>  __global__ void B<T>::function2() // **** error message 
{
   // computation here
}

基本的に、デバイス上で並列に実行したい派生クラスのメンバー関数があります。

残念ながら、次のエラーが表示されます。

error : illegal combination of memory qualifiers on the lines :

1> __global__ void function2();   // **** error message

2> template <class T>  __global__ void B<T>::function2() // **** error message

私はCUDAが初めてです。誰かが私の間違いを指摘してくれたらとても親切です。Visual Studio 2010 で開発しています。

4

1 に答える 1

3

最初のコード スニペットのテンプレート クラス定義は、__global__ 関数 (CUDA カーネル) が含まれているため、無効です。言語ドキュメントに従って、__global__ 関数は静的クラス メンバー関数にすることはできません。2 番目のテンプレート化されたクラス メンバー関数は、同じ理由で不正です。

于 2013-07-09T08:28:46.803 に答える