10个使用Numba CUDA进行编程的例子

以下是10个使用Numba CUDA进行编程的例子,这些例子涵盖了基本的向量加法、矩阵乘法以及其他一些常见操作:

  1. 向量加法
from numba import cuda
import numpy as np
@cuda.jit
def vector_add(a, b, c):
    i = cuda.grid(1)
    if i < len(a):
        c[i] = a[i] + b[i]
a = np.array([1, 2, 3], dtype=np.float32)
b = np.array([4, 5, 6], dtype=np.float32)
c = np.zeros_like(a)
threads_per_block = 32
blocks_per_grid = (len(a) + (threads_per_block - 1)) // threads_per_block
vector_add[blocks_per_grid, threads_per_block](a, b, c)
print(c)
  1. 矩阵乘法
@cuda.jit
def matmul(A, B, C):
    i, j = cuda.grid(2)
    if i < C.shape[0] and j < C.shape[1]:
        tmp = 0.
        for k in range(A.shape[1]):
            tmp += A[i, k] * B[k, j]
        C[i, j] = tmp
A = np.array([[1, 2], [3, 4]], dtype=np.float32)
B = np.array([[5, 6], [7, 8]], dtype=np.float32)
C = np.zeros((2, 2), dtype=np.float32)
threads_per_block = (16, 16)
blocks_per_grid_x = math.ceil(A.shape[0] / threads_per_block[0])
blocks_per_grid_y = math.ceil(B.shape[1] / threads_per_block[1])
blocks_per_grid = (blocks_per_grid_x, blocks_per_grid_y)
matmul[blocks_per_grid, threads_per_block](A, B, C)
print(C)
  1. 向量点乘
@cuda.jit
def dot_product(a, b, result):
    i = cuda.grid(1)
    tmp = 0.0
    if i < a.shape[0]:
        tmp = a[i] * b[i]
    cuda.atomic.add(result, 0, tmp)
a = np.array([1, 2, 3], dtype=np.float32)
b = np.array([4, 5, 6], dtype=np.float32)
result = np.zeros(1, dtype=np.float32)
threads_per_block = 32
blocks_per_grid = (len(a) + (threads_per_block - 1)) // threads_per_block
dot_product[blocks_per_grid, threads_per_block](a, b, result)
print(result[0])
  1. 向量乘法
@cuda.jit
def vector_multiply(a, b, c):
    i = cuda.grid(1)
    if i < len(a):
        c[i] = a[i] * b[i]
# 同向量加法示例中的初始化和调用方式
  1. 向量除法
@cuda.jit
def vector_divide(a, b, c):
    i = cuda.grid(1)
    if i < len(a):
        c[i] = a[i] / b[i]
# 同向量加法示例中的初始化和调用方式
  1. 向量求和
@cuda.jit
def vector_sum(a, result):
    i = cuda.grid(1)
    tmp = 0.0
    if i < a.shape[0]:
        tmp = a[i]
    cuda.atomic.add(result, 0, tmp)
# 同向量点乘示例中的初始化和调用方式
  1. 向量求最大值
@cuda.jit
def vector_max(a, result):
    i = cuda.grid(1)
    if i < a.shape[0]:
        cuda.atomic.max(result, 0, a[i])
# 同向量点乘示例中的初始化和调用方式
  1. 向量求最小值
@cuda.jit
def vector_min(a, result):
    i = cuda.grid(1)
    if i < a.shape[0]:
        cuda.atomic.min(result, 0, a[i])
# 同向量点乘示例中的初始化和调用方式
  1. 向量排序(冒泡排序)
@cuda.jit
def bubble_sort(arr):
    i = cuda.grid(1)
    n = arr.shape[0]
    if i < n:
        for j in range(n - 1):
            if arr[i] > arr[j]:
                arr[i], arr[j] = arr[j], arr[i]
# 同向量加法示例中的初始化

相关推荐

  1. 10使用Numba CUDA进行编程例子

    2024-07-15 22:52:02       19 阅读
  2. 10 c++ cuda 编程例子

    2024-07-15 22:52:02       24 阅读
  3. pandas行选择10例子

    2024-07-15 22:52:02       30 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 22:52:02       70 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 22:52:02       74 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 22:52:02       62 阅读
  4. Python语言-面向对象

    2024-07-15 22:52:02       72 阅读

热门阅读

  1. OSINT技术情报精选·2024年7月第2周

    2024-07-15 22:52:02       16 阅读
  2. 第一个AI应用(文心智能体平台)

    2024-07-15 22:52:02       16 阅读
  3. pytorch学习--使用m1 进行训练

    2024-07-15 22:52:02       19 阅读
  4. Halcon与C++之间的数据转换

    2024-07-15 22:52:02       19 阅读
  5. QT 报错C2872: “byte“: 不明确的符号

    2024-07-15 22:52:02       19 阅读
  6. 【linux 100条命令】

    2024-07-15 22:52:02       20 阅读
  7. setContentView 流程

    2024-07-15 22:52:02       24 阅读
  8. HTTP——GET请求

    2024-07-15 22:52:02       23 阅读
  9. linux系统php开机自启动 phpfpm

    2024-07-15 22:52:02       19 阅读