看板 C_and_CPP 關於我們 聯絡資訊
( *[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)
akasan:把 2d 壓成 1d 然後自己算正確的 offset 11/01 20:18
akasan:去 google "cuda 2d array" 就會有範例 11/01 20:19
doomhammer:我在google上找到一些用cuda處理2維陣列的範例,也看過 11/01 22:46
doomhammer:了,不過我只是想問C的部份有沒有可能像上述那樣傳入指 11/01 22:47
doomhammer:標,不是double pointer確可以像一般處理多維陣列一樣的 11/01 22:48
doomhammer:方法a[i][j]去寫? 11/01 22:48
akasan:那請去請去看第 12 戒吧 11/01 22:49
doomhammer:因為看了那個別人寫的cuda碼突然產生的疑問,他只用指標 11/01 22:51
doomhammer:確用Md[i][j]這樣的用法...我自已寫c code去compile也 11/01 22:52
doomhammer:不過...是只有CUDA才能這樣用嗎?想不透... 11/01 22:53
doomhammer:看了第十二戒後,我得到的結論...還是用一維陣列的觀點 11/01 22:58
doomhammer:去看二維陣列(用算的算出他的位置*(m+col*i+j))這樣去 11/01 22:59
doomhammer:寫. 11/01 22:59