一个示例程序编译没有通过

编译没有通过,出现了4个同样的问题,代码是书中的示例代码。希望能给我解答一下是什么原因。
/*

  • Copyright 1993-2010 NVIDIA Corporation. All rights reserved.
  • NVIDIA Corporation and its licensors retain all intellectual property and
  • proprietary rights in and to this software and related documentation.
  • Any use, reproduction, disclosure, or distribution of this software
  • and related documentation without an express license agreement from
  • NVIDIA Corporation is strictly prohibited.
  • Please refer to the applicable NVIDIA end user license agreement (EULA)
  • associated with this source code for terms and conditions that govern
  • your use of this NVIDIA software.

*/

#include “…/common/book.h”
#include “…/common/cpu_bitmap.h”

#define DIM 1000

struct cuComplex {
float r;
float i;
cuComplex( float a, float b ) : r(a), i(b) {}
device float magnitude2( void ) {
return r * r + i * i;
}
device cuComplex operator*(const cuComplex& a) {
return cuComplex(ra.r - ia.i, ia.r + ra.i);
}
device cuComplex operator+(const cuComplex& a) {
return cuComplex(r+a.r, i+a.i);
}
};

device int julia( int x, int y ) {
const float scale = 1.5;
float jx = scale * (float)(DIM/2 - x)/(DIM/2);
float jy = scale * (float)(DIM/2 - y)/(DIM/2);

cuComplex c(-0.8, 0.156);
cuComplex a(jx, jy);

int i = 0;
for (i=0; i<200; i++) {
a = a * a + c;
if (a.magnitude2() > 1000)
return 0;
}

return 1;
}

global void kernel( unsigned char *ptr ) {
// map from blockIdx to pixel position
int x = blockIdx.x;
int y = blockIdx.y;
int offset = x + y * gridDim.x;

// now calculate the value at that position
int juliaValue = julia( x, y );
ptr[offset4 + 0] = 255 * juliaValue;
ptr[offset
4 + 1] = 0;
ptr[offset4 + 2] = 0;
ptr[offset
4 + 3] = 255;
}

// globals needed by the update routine
struct DataBlock {
unsigned char *dev_bitmap;
};

int main( void ) {
DataBlock data;
CPUBitmap bitmap( DIM, DIM, &data );
unsigned char *dev_bitmap;

HANDLE_ERROR( cudaMalloc( (void**)&dev_bitmap, bitmap.image_size() ) );
data.dev_bitmap = dev_bitmap;

dim3 grid(DIM,DIM);
kernel<<<grid,1>>>( dev_bitmap );

HANDLE_ERROR( cudaMemcpy( bitmap.get_ptr(), dev_bitmap,
bitmap.image_size(),
cudaMemcpyDeviceToHost ) );

HANDLE_ERROR( cudaFree( dev_bitmap ) );

bitmap.display_and_exit();
}

希望高手能指点一下

[attach]2939[/attach]

cuComplex( float a, float b ) : r(a), i(b) {} 前面也加上__device__ 应该就可以了。设备函数中不能调用host端函数。

谢谢!确实如此,改完就正确了