《GPU高性能编程CUDA实战》第四章中的julia_gpu程序编译不通过,改了几次还是不行,代码如下:
#include "book.h"
#include "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(r*a.r - i*a.i, i*a.r + r*a.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[offset*4 + 0] = 255 * juliaValue;
   ptr[offset*4 + 1] = 0;
   ptr[offset*4 + 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();
}
这是书中源代码,提示错误是:Error	16	error : calling a host function(“cuComplex::cuComplex”) from a device function(“julia”) is not allowed	E:\CUDA\TestCUDA\Julia\Julia_GPU.cu	35
对应语句是:cuComplex c(-0.8, 0.156);
请高手帮忙,看看该如何改写?谢谢!