CUDA 數學函數

C.1  數學函數

C.1.1  atomicAdd()

int atomicAdd(int* address, int val);

unsigned int atomicAdd(unsigned int* address,

                           unsigned int val);

unsigned long long int atomicAdd(unsigned long long int* address,

                                        unsigned long long int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位或 64 位字 old,計算 (old + val),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

只有全局存儲器支持 64 位字。

C.1.2  atomicSub()

int atomicSub(int* address, int val);

unsigned int atomicSub(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 (old - val),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.1.3  atomicExch()

int atomicExch(int* address, int val);

unsigned int atomicExch(unsigned int* address,

                            unsigned int val);

unsigned long long int atomicExch(unsigned long long int* address,

                                        unsigned long long int val);

float atomicExch(float* address, float val);

讀取位於全局或共享存儲器中地址 address 處的 32 位或 64 位字 old,並將 val 存儲在存儲器的同一地址中。這兩項操作在一次原子事務中執行。該函數將返回 old。

只有全局存儲器支持 64 位字。

C.1.4  atomicMin()

int atomicMin(int* address, int val);

unsigned int atomicMin(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 old 和 val 的最小值,並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.1.5  atomicMax()

int atomicMax(int* address, int val);

unsigned int atomicMax(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 old 和 val 的最大值,並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.1.6  atomicInc()

unsigned int atomicInc(unsigned int* address,

                       unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 ((old >= val) ? 0 : (old+1)),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.1.7  atomicDec()

unsigned int atomicDec(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 (((old == 0) | (old > val)) ? val : (old-1)),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.1.8  atomicCAS()

int atomicCAS(int* address, int compare, int val);

unsigned int atomicCAS(unsigned int* address,

                           unsigned int compare,

                           unsigned int val);

unsigned long long int atomicCAS(unsigned long long int* address,

                                       unsigned long long int compare,

                                       unsigned long long int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位或 64 位字 old,計算 (old == compare ? val : old),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old(比較並交換)。

只有全局存儲器支持 64 位字。

C.2  位邏輯函數

C.2.1  atomicAnd()

int atomicAnd(int* address, int val);

unsigned int atomicAnd(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 (old & val),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.2.2  atomicOr()

int atomicOr(int* address, int val);

unsigned int atomicOr(unsigned int* address,

                          unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 (old | val),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

C.2.3  atomicXor()

int atomicXor(int* address, int val);

unsigned int atomicXor(unsigned int* address,

                           unsigned int val);

讀取位於全局或共享存儲器中地址 address 處的 32 位字 old,計算 (old ^ val),並將結果存儲在存儲器的同一地址中。這三項操作在一次原子事務中執行。該函數將返回 old。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章