Encontrando máximo e mínimo com CUBLAS
Estou tendo problemas para compreender por que minha função que encontra o máximo e o mínimo em um intervalo de duplas usando o CUBLAS não funciona corretamente.
O código é o seguinte:
<code>void findMaxAndMinGPU(double* values, int* max_idx, int* min_idx, int n) { double* d_values; cublasHandle_t handle; cublasStatus_t stat; safecall( cudaMalloc((void**) &d_values, sizeof(double) * n), "cudaMalloc (d_values) in findMaxAndMinGPU"); safecall( cudaMemcpy(d_values, values, sizeof(double) * n, cudaMemcpyHostToDevice), "cudaMemcpy (h_values > d_values) in findMaxAndMinGPU"); cublasCreate(&handle); stat = cublasIdamax(handle, n, d_values, sizeof(double), max_idx); if (stat != CUBLAS_STATUS_SUCCESS) printf("Max failed\n"); stat = cublasIdamin(handle, n, d_values, sizeof(double), min_idx); if (stat != CUBLAS_STATUS_SUCCESS) printf("min failed\n"); cudaFree(d_values); cublasDestroy(handle); } </code>
Onde valores são os valores para pesquisar dentro. Max_idx e min_idx são o índice dos números encontrados nos valores. Os resultados das chamadas CUBLAS parecem bastante aleatórios e geram índices errados.
Alguém com uma boa resposta para o meu problema? Estou um pouco triste no momento :(