作者doomhammer (流浪者)
看板C_and_CPP
標題[問題] 關於CUDA/C的問題...
時間Mon Nov 1 13:03:02 2010
( *[1m *[m 為色碼,可以按 Ctrl+V 預覽會顯示的顏色 )
( 未必需要依照此格式,文章條理清楚即可 )
遇到的問題: (題意請描述清楚)
看CUDA程式碼時看到關於Kernel處理陣列的方式有疑問...
希望得到的正確結果:
在kernel能正確執行陣列運算
程式跑出來的錯誤結果:
invalid types 'int[int]' for array subscript(單用pointer function,在function
中用 a[i][j]這樣的宣告)
開發平台: (例: VC++ or gcc/g++ or Dev-C++, Windows or Linux)
Windows 7 + Dev C++ V4.9.9.2 不過我寫的是c code.
有問題的code: (請善用置底文標色功能)
__global__ void MatrixMulKernel(float* Md, float* Nd, float* Pd, intWidth)
{
// Calculate the row index of the Pd element and M
int Row = blockId.y * TILE_WIDTH + threadId.y;
// Calculate the column idenx of Pd and N
Int Col = blockId.x * TILE_WIDTH + threadId.x;
Pvalue = 0;
// each thread computes one element of the block sub-matrix
for (int k = 0; k < Width; ++k)
Pvalue += Md[Row][k] * Nd[k][Col]; //單看程式碼產生的問題
Pd[Row][Col] = Pvalue; //這一行也是
}
補充說明:
在看CUDA的程式碼的時候產生的問題...他在設計kernel的時候傳入的是pointer,確能在
裡面以一般二維陣列的方式使用?!
一般的c function我試過下列的寫法:
宣告一二維陣列 m[3][3];
int* a;
a=&m[0][0]; //a指向m陣列的第一個位置
void f( int t[][] , int row , int col) //compile不過,會要求你指定後面index
void f( int* a , int row , int col) //單用pointer,沒有問題
{
int i,j;
for(i=0;i<row;i++ )
{
for(j=0; j<col; j++)
printf("%d ", *(a+col*i+j));
}
}
//用double pointer的話:
pt_a = (int**) malloc(4 * sizeof(int*));
int i;
for( i=0 ; i<4 ; i++)
{
pt_a[i]= (int* )malloc( 4 * sizeof(int));
}
void f(int** a , int row, int col) //這樣我也試過.可以!
{
for(int i=0 ; i<row; i++)
{
for(int j=0; j<col)
printf("%d ", a[i][j]);
}
}
不過這就表示要傳2d陣列進function裡要用double pointer,有任何可能用pointer就
做到嗎(當然除了我上面的例子之外)?有可能用
f(int a[][], int row , int col)這種方式做到嗎?
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 72.229.53.41
※ 編輯: doomhammer 來自: 72.229.53.41 (11/01 13:06)
1F:→ akasan:把 2d 壓成 1d 然後自己算正確的 offset 11/01 20:18
2F:→ akasan:去 google "cuda 2d array" 就會有範例 11/01 20:19
3F:→ doomhammer:我在google上找到一些用cuda處理2維陣列的範例,也看過 11/01 22:46
4F:→ doomhammer:了,不過我只是想問C的部份有沒有可能像上述那樣傳入指 11/01 22:47
5F:→ doomhammer:標,不是double pointer確可以像一般處理多維陣列一樣的 11/01 22:48
6F:→ doomhammer:方法a[i][j]去寫? 11/01 22:48
7F:→ akasan:那請去請去看第 12 戒吧 11/01 22:49
8F:→ doomhammer:因為看了那個別人寫的cuda碼突然產生的疑問,他只用指標 11/01 22:51
9F:→ doomhammer:確用Md[i][j]這樣的用法...我自已寫c code去compile也 11/01 22:52
10F:→ doomhammer:不過...是只有CUDA才能這樣用嗎?想不透... 11/01 22:53
11F:→ doomhammer:看了第十二戒後,我得到的結論...還是用一維陣列的觀點 11/01 22:58
12F:→ doomhammer:去看二維陣列(用算的算出他的位置*(m+col*i+j))這樣去 11/01 22:59
13F:→ doomhammer:寫. 11/01 22:59