欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python寫CUDA程序的方法

 更新時間:2017年03月27日 10:09:06   投稿:jingxian  
下面小編就為大家?guī)硪黄褂肞ython寫CUDA程序的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

使用Python寫CUDA程序有兩種方式:

* Numba
* PyCUDA

numbapro現(xiàn)在已經(jīng)不推薦使用了,功能被拆分并分別被集成到accelerate和Numba了。

例子

numba

Numba通過及時編譯機制(JIT)優(yōu)化Python代碼,Numba可以針對本機的硬件環(huán)境進(jìn)行優(yōu)化,同時支持CPU和GPU的優(yōu)化,并且可以和Numpy集成,使Python代碼可以在GPU上運行,只需在函數(shù)上方加上相關(guān)的指令標(biāo)記,

如下所示:

import numpy as np 
from timeit import default_timer as timer
from numba import vectorize

@vectorize(["float32(float32, float32)"], target='cuda')
def vectorAdd(a, b):
  return a + b

def main():
  N = 320000000

  A = np.ones(N, dtype=np.float32 )
  B = np.ones(N, dtype=np.float32 )
  C = np.zeros(N, dtype=np.float32 )

  start = timer()
  C = vectorAdd(A, B)
  vectorAdd_time = timer() - start

  print("c[:5] = " + str(C[:5]))
  print("c[-5:] = " + str(C[-5:]))

  print("vectorAdd took %f seconds " % vectorAdd_time)

if __name__ == '__main__':
  main()


PyCUDA

PyCUDA的內(nèi)核函數(shù)(kernel)其實就是使用C/C++編寫的,通過動態(tài)編譯為GPU微碼,Python代碼與GPU代碼進(jìn)行交互,如下所示:

import pycuda.autoinit
import pycuda.driver as drv
import numpy as np
from timeit import default_timer as timer

from pycuda.compiler import SourceModule
mod = SourceModule("""
__global__ void func(float *a, float *b, size_t N)
{
 const int i = blockIdx.x * blockDim.x + threadIdx.x;
 if (i >= N)
 {
  return;
 }
 float temp_a = a[i];
 float temp_b = b[i];
 a[i] = (temp_a * 10 + 2 ) * ((temp_b + 2) * 10 - 5 ) * 5;
 // a[i] = a[i] + b[i];
}
""")

func = mod.get_function("func")  

def test(N):
  # N = 1024 * 1024 * 90  # float: 4M = 1024 * 1024

  print("N = %d" % N)

  N = np.int32(N)

  a = np.random.randn(N).astype(np.float32)
  b = np.random.randn(N).astype(np.float32)  
  # copy a to aa
  aa = np.empty_like(a)
  aa[:] = a
  # GPU run
  nTheads = 256
  nBlocks = int( ( N + nTheads - 1 ) / nTheads )
  start = timer()
  func(
      drv.InOut(a), drv.In(b), N,
      block=( nTheads, 1, 1 ), grid=( nBlocks, 1 ) )
  run_time = timer() - start 
  print("gpu run time %f seconds " % run_time)  
  # cpu run
  start = timer()
  aa = (aa * 10 + 2 ) * ((b + 2) * 10 - 5 ) * 5
  run_time = timer() - start 

  print("cpu run time %f seconds " % run_time) 

  # check result
  r = a - aa
  print( min(r), max(r) )

def main():
 for n in range(1, 10):
  N = 1024 * 1024 * (n * 10)
  print("------------%d---------------" % n)
  test(N)

if __name__ == '__main__':
  main()

對比

numba使用一些指令標(biāo)記某些函數(shù)進(jìn)行加速(也可以使用Python編寫內(nèi)核函數(shù)),這一點類似于OpenACC,而PyCUDA需要自己寫kernel,在運行時進(jìn)行編譯,底層是基于C/C++實現(xiàn)的。通過測試,這兩種方式的加速比基本差不多。但是,numba更像是一個黑盒,不知道內(nèi)部到底做了什么,而PyCUDA就顯得很直觀。因此,這兩種方式具有不同的應(yīng)用:

* 如果只是為了加速自己的算法而不關(guān)心CUDA編程,那么直接使用numba會更好。

* 如果為了學(xué)習(xí)、研究CUDA編程或者實驗?zāi)骋粋€算法在CUDA下的可行性,那么使用PyCUDA。

* 如果寫的程序?qū)硪浦驳紺/C++,那么就一定要使用PyCUDA了,因為使用PyCUDA寫的kernel本身就是用CUDA C/C++寫的。

以上這篇使用Python寫CUDA程序的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python requests庫用法實例詳解

    Python requests庫用法實例詳解

    這篇文章主要介紹了Python requests庫用法,結(jié)合實例形式分析了Request庫的功能、安裝、請求創(chuàng)建、響應(yīng)等相關(guān)操作技巧,需要的朋友可以參考下
    2018-08-08
  • Python使用回溯法子集樹模板獲取最長公共子序列(LCS)的方法

    Python使用回溯法子集樹模板獲取最長公共子序列(LCS)的方法

    這篇文章主要介紹了Python使用回溯法子集樹模板獲取最長公共子序列(LCS)的方法,簡單描述了最長公共子序列問題并結(jié)合實例形式分析了Python基于回溯法子集樹模板獲取最長公共子序列的操作步驟與相關(guān)注意事項,需要的朋友可以參考下
    2017-09-09
  • Python中的lambda和apply用法及說明

    Python中的lambda和apply用法及說明

    這篇文章主要介紹了Python中的lambda和apply用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Django+Celery實現(xiàn)定時任務(wù)的示例

    Django+Celery實現(xiàn)定時任務(wù)的示例

    Celery是一個基于python開發(fā)的分布式任務(wù)隊列,而做python WEB開發(fā)最為流行的框架莫屬Django,本示例使用主要依賴包Django+Celery實現(xiàn)定時任務(wù),感興趣的朋友一起看看吧
    2021-06-06
  • python中的逆序遍歷實例

    python中的逆序遍歷實例

    今天小編就為大家分享一篇python中的逆序遍歷實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 關(guān)于Pytorch中模型的保存與遷移問題

    關(guān)于Pytorch中模型的保存與遷移問題

    在本篇文章中,筆者首先介紹了模型復(fù)用的幾種典型場景;然后介紹了如何查看Pytorch模型中的相關(guān)參數(shù)信息;接著介紹了如何載入模型、如何進(jìn)行追加訓(xùn)練以及進(jìn)行模型的遷移學(xué)習(xí)等,需要的朋友可以參考下
    2021-10-10
  • Python重新加載模塊的實現(xiàn)方法

    Python重新加載模塊的實現(xiàn)方法

    今天小編就為大家分享一篇Python重新加載模塊的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • 基于python的selenium兩種文件上傳操作實現(xiàn)詳解

    基于python的selenium兩種文件上傳操作實現(xiàn)詳解

    這篇文章主要介紹了基于python的selenium兩種文件上傳操作實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • Python操作列表常用方法實例小結(jié)【創(chuàng)建、遍歷、統(tǒng)計、切片等】

    Python操作列表常用方法實例小結(jié)【創(chuàng)建、遍歷、統(tǒng)計、切片等】

    這篇文章主要介紹了Python操作列表常用方法,結(jié)合實例形式總結(jié)分析了Python列表常見的創(chuàng)建、遍歷、統(tǒng)計、切片等操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2019-10-10
  • 詳解Python中各種運算符的使用

    詳解Python中各種運算符的使用

    在?Python?編程中,運算符是用于執(zhí)行各種數(shù)學(xué)和邏輯操作的特殊符號,本文我們就深入探討?Python?中的常見運算符,并通過豐富的案例來說明它們的用法和功能吧
    2023-07-07

最新評論