2016-10-10 79 views
11

我试图剖析在Ubuntu上有Cuda的8.0 16.04 CUDA代码,但它返回“无法剖析应用。统一存储分析失败”。我尝试从终端和Nisght Eclipe进行分析。代码正在编译并运行,但无法获取配置文件。统一内存分析失败

代码 -

cusparseHandle_t handle; 
cusparseCreate(&handle); 
cusparseSafeCall(cusparseCreate(&handle)); 

//set the parameters 
const int n_i = 10; 
const int d = 18; 
const int n_t = 40; 
const int n_tau = 2; 
const int n_k = 10; 

float *data = generate_matrix3_1(d, n_i, n_t); 
//float* data = get_data1(d, n_i,n_t); 
float* a = generate_matrix3_1(n_i,n_k,n_tau); 
float* b = sparse_generate_matrix1(n_k,d,0.5); 
float* c = sparse_generate_matrix1(n_k,d,0.5); 

float* previous_a = generate_matrix3_1(n_i,n_k,n_tau); 
float* previous_b = sparse_generate_matrix1(n_k,d,0.1); 
float* previous_c = sparse_generate_matrix1(n_k,d,0.1); 

// calculate norm of data 
float norm_data = 0; 
for (int i = 0; i < n_i; i++) 
{ 
    for (int t = n_tau; t < n_t; t++) 
    { 
     for (int p = 0; p < d; p++) 
     { 
      norm_data = norm_data + ((data[p*n_i*n_t + i*n_t + t])*(data[p*n_i*n_t + i*n_t + t])); 
     } 
    } 
} 

// set lambda and gamma parameter 
float lambda = 0.0001; 
float gamma_a = 2; 
float gamma_b = 3; 
float gamma_c = 4; 

float updated_t = 1; 
float updated_t1 = 0; 

float rel_error = 0; 
int loop = 1; 
float objective = 0; 

// create sparse format for the data 
float **h_data = new float*[1]; 
int **h_data_RowIndices = new int*[1]; 
int **h_data_ColIndices = new int*[1]; 
int nnz_data = create_sparse_MY(data,d,n_i*n_t,h_data,h_data_RowIndices,h_data_ColIndices); 

// transfer sparse data to device memory 
int *d_data_RowIndices; (cudaMalloc(&d_data_RowIndices, (d+1) * sizeof(int))); 
(cudaMemcpy(d_data_RowIndices, h_data_RowIndices[0], (d+1) * sizeof(int), cudaMemcpyHostToDevice)); 
int *d_data_ColIndices; (cudaMalloc(&d_data_ColIndices, nnz_data * sizeof(int))); 
(cudaMemcpy(d_data_ColIndices, h_data_ColIndices[0], (nnz_data) * sizeof(int), cudaMemcpyHostToDevice)); 

命令编译代码 -

NVCC -lcusparse main.cu -o文件hello.out

Profiling-

nvprof -o教授./文件hello.out

错误 -

== == 13621是NVPROF剖析过程13621,命令:./hello.out ========错误:统一内存分析失败。

有人可以帮我吗?

+0

请提供一个简短的完整测试用例。您试图分析的程序,如何编译它,用于分析它的完整命令以及完整的输出消息。 –

+0

更新 –

回答

20

具有相同的误导性错误,只能以root权限运行探查器,例如, sudo nvprof或sudo nvvp。

5

我遭受同样的错误。但是,即使我添加了sudo权限,该错误依然存在。终端返回sudo: nvprof: command not found

试试这个命令,它适用于我。 nvprof --unified-memory-profiling off /hello.out

+1

你应该须藤之后添加CUDA路径PATH根或给出确切的路径问题像=“须藤/usr/local/cuda-8.0/bin/nvprof” –

+0

一些用户建议:*如果你从这个错误终端:sudo:nvprof:命令未找到您可以尝试sudo -su。 * – GhostCat