Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> CUDA - суммирование чисел, Нулевой результат сложения 
V
    Опции темы
Wisdom
Дата 19.4.2012, 20:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 39
Регистрация: 12.9.2008

Репутация: нет
Всего: нет



Здравствуйте.
Пробую реализовать сложение двух массивов с помощью CUDA в Visual Studio 2010.
Тулкит поставил, драйвера стоят.
Файл Cuda.cu:
Код

#include <iostream>
#include <cuda_runtime.h>

__global__ void sum(float *A, float *B, float *C) 
{
    int n = blockDim.x * blockIdx.x + threadIdx.x;
    C[n] = A[n] + B[n];
}

void StartSum(float *A, float *B, float *C, int N)
{
    sum<<< N/64, 64 >>>(A, B, C) ;
}

Файл с инициализацией массивов и вызовом функции суммирования:
Код

#include <windows.h>
#include <cuda.h>
#include <cuda_runtime.h>
#include <cuda_runtime_api.h>
#include <iostream>

#define N 5

void StartSum(float *A, float *B, float *C, int n);

int main() 
{
    float a[N] = {1,2,3,4,5}, b[N]={-2,-4,5,7,1}, c[N] = {0,0,0,0,0};
    cudaError_t err;
    float *dev_a , *dev_b , *dev_c ;
    cudaSetDevice(0);
    cudaMalloc((void**)&dev_a , sizeof (float)*N);
    cudaMalloc((void**)&dev_b , sizeof (float)*N);
    cudaMalloc((void**)&dev_c , sizeof (float)*N);

    err = cudaMemcpy(dev_a, a, sizeof(float)*N, cudaMemcpyHostToDevice);
    err = cudaMemcpy(dev_b, b, sizeof(float)*N, cudaMemcpyHostToDevice);
    err = cudaMemcpy(dev_c, c, sizeof(float)*N, cudaMemcpyHostToDevice);

    StartSum(dev_a, dev_b, dev_c, N);
    err = cudaMemcpy(c, dev_c, sizeof(float), cudaMemcpyDeviceToHost);

    for (int i = 0; i<N; i++)
        std::cout<<c[i]<<" ";

    std::cout<<std::endl;

    system("PAUSE");
}

Вопрос в следующем: почему в массиве c всегда нули? По идее, там должна была аккумулироваться сумма..
Бьюсь уже часа два, кто чем может, помогите.
Спасибо. 
PM MAIL   Вверх
Wisdom
Дата 20.4.2012, 06:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 39
Регистрация: 12.9.2008

Репутация: нет
Всего: нет



Друзья, неужели никто не может помочь ? 
Хотя бы намекните, в какую сторону копать..
PM MAIL   Вверх
Wisdom
Дата 20.4.2012, 16:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 39
Регистрация: 12.9.2008

Репутация: нет
Всего: нет



Решил проблему.
N/64 == 0 (целая часть). А это значение блоков ГПУ, которое должно быть отличным от нуля.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1055 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.