当前位置: 首页 > wzjs >正文

交互式网站设计小程序开发 深圳

交互式网站设计,小程序开发 深圳,哪里有做手机壳的的,潍坊高端网站设计运行效果 由于cuda进行运算是非常快的。本文介绍通过C调用自定义的cuda类接口,将耗时运算操作交由cuda进行计算。 正问 1、打开vs2017,创建C空项目,并创建main.cpp写入部分代码 2、创建cuda文件与头文件 (1)、右键项目名称 - 添加 - 新建项 -…
运行效果

     由于cuda进行运算是非常快的。本文介绍通过C++调用自定义的cuda类接口,将耗时运算操作交由cuda进行计算。

在这里插入图片描述


正问

     1、打开vs2017,创建C++空项目,并创建main.cpp写入部分代码

在这里插入图片描述
在这里插入图片描述

     2、创建cuda文件与头文件

          (1)、右键项目名称 - 添加 - 新建项 - Visual C++,分两次分别创建"CUDA 11.4 C/C++ File"与"CUDA 11.4 C/C++ Header"

在这里插入图片描述

          (2)、将如下代码分别写入3个代码文件

               main.cpp

#include <iostream>#include "main.cuh"int main()
{CudaTest TEST;TEST.RunCalc();system("pause");return 0;
}

               CudaTest.cuh

#ifndef MAIN_CUH
#define MAIN_CUH#include "cuda_runtime.h"
#include "device_launch_parameters.h"#include <stdio.h>class CudaTest
{
public:CudaTest();int RunCalc();
};#endif

               CudaTest.cu


#include "main.cuh"#include <Windows.h>CudaTest::CudaTest()
{}cudaError_t addWithCuda(int *c, const int *a, const int *b, unsigned int size);__global__ void addKernel(int *c, const int *a, const int *b)
{int i = threadIdx.x;c[i] = a[i] + b[i];
}int CudaTest::RunCalc()
{const int arraySize = 5;const int a[arraySize] = { 1, 2, 3, 4, 5 };const int b[arraySize] = { 10, 20, 30, 40, 50 };int c[arraySize] = { 0 };cudaError_t cudaStatus = cudaSuccess;for (unsigned short index = 0; index < 3000; ++index){// Add vectors in parallel.cudaStatus = addWithCuda(c, a, b, arraySize);if (cudaStatus != cudaSuccess) { fprintf(stderr, "addWithCuda failed!"); return 1; }printf("%d --- {1,2,3,4,5} + {10,20,30,40,50} = {%d,%d,%d,%d,%d}\n", index,c[0], c[1], c[2], c[3], c[4]);Sleep(1);}// cudaDeviceReset must be called before exiting in order for profiling and// tracing tools such as Nsight and Visual Profiler to show complete traces.cudaStatus = cudaDeviceReset();if (cudaStatus != cudaSuccess) { fprintf(stderr, "cudaDeviceReset failed!"); return 1; }return 0;
}// Helper function for using CUDA to add vectors in parallel.
cudaError_t addWithCuda(int *c, const int *a, const int *b, unsigned int size)
{int *dev_a = 0;int *dev_b = 0;int *dev_c = 0;cudaError_t cudaStatus;// Choose which GPU to run on, change this on a multi-GPU system.cudaStatus = cudaSetDevice(0);if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaSetDevice failed!  Do you have a CUDA-capable GPU installed?");goto Error;}// Allocate GPU buffers for three vectors (two input, one output)    .cudaStatus = cudaMalloc((void**)&dev_c, size * sizeof(int));if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMalloc failed!");goto Error;}cudaStatus = cudaMalloc((void**)&dev_a, size * sizeof(int));if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMalloc failed!");goto Error;}cudaStatus = cudaMalloc((void**)&dev_b, size * sizeof(int));if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMalloc failed!");goto Error;}// Copy input vectors from host memory to GPU buffers.cudaStatus = cudaMemcpy(dev_a, a, size * sizeof(int), cudaMemcpyHostToDevice);if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMemcpy failed!");goto Error;}cudaStatus = cudaMemcpy(dev_b, b, size * sizeof(int), cudaMemcpyHostToDevice);if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMemcpy failed!");goto Error;}// Launch a kernel on the GPU with one thread for each element.addKernel << <1, size >> > (dev_c, dev_a, dev_b);// Check for any errors launching the kernelcudaStatus = cudaGetLastError();if (cudaStatus != cudaSuccess) {fprintf(stderr, "addKernel launch failed: %s\n", cudaGetErrorString(cudaStatus));goto Error;}// cudaDeviceSynchronize waits for the kernel to finish, and returns// any errors encountered during the launch.cudaStatus = cudaDeviceSynchronize();if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaDeviceSynchronize returned error code %d after launching addKernel!\n", cudaStatus);goto Error;}// Copy output vector from GPU buffer to host memory.cudaStatus = cudaMemcpy(c, dev_c, size * sizeof(int), cudaMemcpyDeviceToHost);if (cudaStatus != cudaSuccess) {fprintf(stderr, "cudaMemcpy failed!");goto Error;}Error:cudaFree(dev_c);cudaFree(dev_a);cudaFree(dev_b);return cudaStatus;
}


     3、【重要】工程配置修改,用以识别支持CUDA

          3.1、右键项目名称 - 生成依赖项 - 生成自定义 - 勾选CUDA 11.4

在这里插入图片描述

          3.2、分别右键.cu与.cuh文件,选择: 属性 - 配置属性 - 常规 - 项类型 - 选择"CUDA C/C++"

在这里插入图片描述


          3.3、工具 - 选项 - 文本编辑器 - 文件扩展名,添加cu和cuh两个文件拓展名

在这里插入图片描述


     4、项目配置cuda头文件/库(其实若按照 前篇文章 配置环境变量后,则此第4步骤可不做)

          4.1、【加入头文件】具体如下图加入cuda头文件

在这里插入图片描述

          4.2、【加入库文件】具体如下两图加入cuda库路径及文件

在这里插入图片描述
在这里插入图片描述


     5、编译运行

在这里插入图片描述

关注

笔者 - 东旭


文章转载自:

http://uhV2gwAa.rcsbz.cn
http://7FAu0GhY.rcsbz.cn
http://cVa7obqz.rcsbz.cn
http://vn5jvxfn.rcsbz.cn
http://XUSJzAMg.rcsbz.cn
http://Oagdzg1o.rcsbz.cn
http://kfd04jnu.rcsbz.cn
http://tcUdLzl1.rcsbz.cn
http://PUVoNWLo.rcsbz.cn
http://To8ZxcJv.rcsbz.cn
http://v3VwMyFX.rcsbz.cn
http://GBtYgNdw.rcsbz.cn
http://EFnc6uFf.rcsbz.cn
http://FMKO1Tai.rcsbz.cn
http://RgVqhDPW.rcsbz.cn
http://lBfwuJUu.rcsbz.cn
http://LvzOZSKC.rcsbz.cn
http://gKBB7mmH.rcsbz.cn
http://xttUgxCT.rcsbz.cn
http://n919bZHi.rcsbz.cn
http://kzzvvIht.rcsbz.cn
http://U2yA8NBX.rcsbz.cn
http://ZsWB2dXf.rcsbz.cn
http://bjeX3CHW.rcsbz.cn
http://oCFFTOl0.rcsbz.cn
http://ZsVKspOX.rcsbz.cn
http://J6FMhpJM.rcsbz.cn
http://TLLOXyL9.rcsbz.cn
http://v0qaM5au.rcsbz.cn
http://9qHHkTUV.rcsbz.cn
http://www.dtcms.com/wzjs/687364.html

相关文章:

  • 安徽省住建厅网站官网山西省网站建设备案表
  • 谁有好的网站推荐一个做汤的网站有哪些
  • 哈尔滨市建设工程质量安全站广州最新通告
  • 贵阳专业网站建设公司哪家好济南正规的网站制作
  • 外贸开发模板网站模板企业的所得税费用怎么算
  • 小说网站模板哈尔滨网站制作前景
  • 外贸营销网站制作公司沈阳好的互联网设计
  • 上海 网站制作网站模板文件不存在
  • 邯郸医疗网站建设网站怎么描述
  • 我有网站 怎么做淘宝推广微商怎么引流被别人加
  • 万能建站网站php做网站完整视频
  • wordpress 收费模板江西网站优化
  • 网站开发培训班 上地营销导向的网站建设的主要流程
  • 招聘网站做销售怎么样生鲜网站制作
  • 网站seo诊断分析和优化方案怎么进行网络营销
  • 怎么做一个网站云南上海装潢设计
  • 建设银行此网站的安全证书有问题.公众号seo排名
  • 网站更新 缓存大连网站建设企业
  • 官方购物网站正品free wordpress theme
  • wordpress设置站点地址建设网站坪山
  • 专业外贸网站建设 诚信 青岛重庆网站建设推广公司哪家好
  • 濮阳建站推广哪家好wordpress添加轮播
  • 毕业设计答辩网站开发原理东营公共资源交易信息网
  • 南岸网站建设重庆互联网企业
  • 网站开发人员招募费用外贸建站 台州
  • 夸克作文网站创建一个网页多少钱
  • 如何做旅游网站自适应网站建设专家
  • 网站开发的工作环境wap网站 趋势分析
  • 贵州铁路建设网站微官网和手机网站一样吗
  • 做网站的网络非要专线吗西安工程网站建设