CUDA <<< X,X >>>给出预期的表达式错误

如何解决CUDA <<< X,X >>>给出预期的表达式错误

我正在尝试编译并运行以下名为test.cu的程序:

#include <iostream>
#include <math.h>
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
// Kernel function to add the elements of two arrays
__global__
void add(int n,float* x,float* y)
{
    int index = threadIdx.x;
    int stride = blockDim.x;
    for (int i = index; i < n; i += stride)
        y[i] = x[i] + y[i];
}

int main(void)
{
    int N = 1 << 20;
    float* x,* y;

    // Allocate Unified Memory – accessible from CPU or GPU
    cudaMallocManaged(&x,N * sizeof(float));
    cudaMallocManaged(&y,N * sizeof(float));

    // initialize x and y arrays on the host
    for (int i = 0; i < N; i++) {
        x[i] = 2.0f;
        y[i] = 1.0f;
    }

    // Run kernel on 1M elements on the GPU
    add <<<1,256>>> (N,x,y);

    // Wait for GPU to finish before accessing on host
    cudaDeviceSynchronize();

    // Check for errors (all values should be 3.0f)
    for (int i = 0; i < 10; i++)
        std::cout << y[i] << std::endl;

    // Free memory
    cudaFree(x);
    cudaFree(y);

    return 0;
}

我正在使用Visual Studio社区2019,它标记为“添加>>(N,x,y);”预期表达错误。我尝试编译它,并且以某种方式正确编译,但是运行.exe文件时,它输出一堆“ 1”而不是预期的“ 3”。

我也尝试使用“ nvcc test.cu”进行编译,但是最初它说“ nvcc fatal : Cannot find compiler 'cl.exe' in PATH”,所以我添加了“ C:\ Program Files(x86)\ Microsoft Visual Studio \ 2019 \ Community \ VC \ Tools \ MSVC \ 14.27.29110 \ bin \ Hostx64 \ x64“移至路径,现在使用nvcc进行编译与使用Visual Studio进行编译时会出现相同的错误。

在两种情况下,程序都不会输入“添加”功能。

我非常确定代码正确,并且问题与安装有关,但是我已经尝试过重新安装cuda工具包并修复MCVS,但这没有用。

在Visual Studio中使用cuda启动新项目时出现的kernel.cu示例也不起作用。运行时,输出“没有可用的内核映像在设备上执行”。

如何解决这个问题?

nvcc版本,如果有帮助的话:

nvcc -V
nvcc: NVIDIA (R) Cuda compiler driver
Copyright (c) 2005-2020 NVIDIA Corporation
Built on Wed_Jul_22_19:09:35_Pacific_Daylight_Time_2020
Cuda compilation tools,release 11.0,V11.0.221
Build cuda_11.0_bu.relgpu_drvr445TC445_37.28845127_0

解决方法

Visual Studio提供了IntelliSense C ++。在C ++语言中,尖括号的正确解析很麻烦。对于模板,您要<<<>>>。这使Intellisense难以正常工作。在CUDA中获取完整IntelliSense的方法是从运行时API切换到驱动程序API。 C ++只是C ++,而CUDA仍然是C ++(某种),对于语言解析而言,不必费劲>>。

您可以看一下matrixMul和matrixMulDrv之间的区别。 <<<>>>语法实际上是由编译器处理的,只是吐出了调用Driver API调用的代码。您将链接到cuda.lib而不是cudart.lib,并且如果仅使用CUDA-RT库,则可能必须处理“混合模式”程序。您可以参考此link以获得更多信息。

此外,此link还介绍了如何在VS中为CUDA添加Intellisense。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-