文档章节

ubuntu 17.04 cuda

MtrS
 MtrS
发布于 2017/09/01 09:12
字数 342
阅读 35
收藏 0

Install NVIDIA CUDA on Ubuntu 17.04

The official download page only have package for 16.04 and 14.04, but actually Ubuntu 17.04 can install CUDA via apt directly. https://launchpad.net/ubuntu/zesty/+source/nvidia-cuda-toolkit Install

Assume you already have NVIDIA graphic driver installed and just need CUDA. Only the following command is needed.

sudo apt-get install nvidia-cuda-dev nvidia-cuda-toolkit nvidia-nsight

NOTE: Ubuntu 17.04 use GCC6, which is not supported by nvcc , the package will install clang-3.8 (the default clang version for 17.04 is clang 4.0, they can co-exist). Compile

Compile cuda code using nvcc -ccbin clang-3.8 hello-world.cu , remember to use cu as suffix instead of c other wise you will have error like the following

nvcc warning : The ‘compute_20’, ‘sm_20’, and ‘sm_21’ architectures are deprecated, and may be removed in a future release (Use -Wno-deprecated-gpu-targets to suppress warning).
square.c:6:1: error: unknown type name ‘__global__’
__global__ void cube(float * d_out, float * d_in){

You can use the following code to test if you have correct installation


/*
* Example from Udacity Intro to Parallel Programming https://www.udacity.com/course/intro-to-parallel-programming--cs344
* nvcc -ccbin clang-3.8 cube.cu
*/
#include <stdio.h>

__global__ void cube(float * d_out, float * d_in){
	int idx = threadIdx.x;
	float f = d_in[idx];
	d_out[idx] = f * f * f;
}

int main(int argc, char ** argv) {
	const int ARRAY_SIZE = 64;
	const int ARRAY_BYTES = ARRAY_SIZE * sizeof(float);

	// generate the input array on the host
	float h_in[ARRAY_SIZE];
	for (int i = 0; i < ARRAY_SIZE; i++) {
		h_in[i] = float(i);
	}
	float h_out[ARRAY_SIZE];

	// declare GPU memory pointers
	float * d_in;
	float * d_out;

	// allocate GPU memory
	cudaMalloc((void**) &d_in, ARRAY_BYTES);
	cudaMalloc((void**) &d_out, ARRAY_BYTES);

	// transfer the array to the GPU
	cudaMemcpy(d_in, h_in, ARRAY_BYTES, cudaMemcpyHostToDevice);

	// launch the kernel
	cube<<<1, ARRAY_SIZE>>>(d_out, d_in);

	// copy back the result array to the CPU
	cudaMemcpy(h_out, d_out, ARRAY_BYTES, cudaMemcpyDeviceToHost);

	// print out the resulting array
	for (int i =0; i < ARRAY_SIZE; i++) {
		printf("%f", h_out[i]);
		printf(((i % 4) != 3) ? "\t" : "\n");
	}

	cudaFree(d_in);
	cudaFree(d_out);

	return 0;
}

Reference

https://www.udacity.com/course/intro-to-parallel-programming--cs344

https://medium.com/@at15/install-nvidia-cuda-on-ubuntu-17-04-823300ab7bcc

© 著作权归作者所有

共有 人打赏支持
下一篇: IPC
MtrS
粉丝 32
博文 555
码字总数 352764
作品 0
榆林
私信 提问
Ubuntu 17.04 Alpha 2 发布,现可下载

Ubuntu 17.04 Alpha 2 发布了。 Ubuntu GNOME 17.04 Alpha 2 Ubuntu GNOME 17.04 Alpha 2 附带了 GNOME 3.22,虽然几个应用程序(特别是 Nautilus 和 GNOME 终端)仍停留在 3.20 版本。 除了...

局长
2017/01/29
4K
5
Ubuntu 17.04 Beta 2 发布,现可下载

Ubuntu 17.04 Beta 2 发布了,该版本是 Ubuntu 17.04 桌面、服务器和云产品的最终 Beta 版。Ubuntu 17.04 稳定版将于 2017 年 4 月 13 日发布。 这次发布的 Beta 版不仅包括 Ubuntu 桌面、服...

局长
2017/03/24
3.1K
9
Ubuntu Budgie 17.04 每日构建 ISO 开放下载

Ubuntu Budgie 17.04 每日构建 ISO 开放下载 系统截图抢先看 兑现 2016 年底的承诺,Ubuntu Budgie 17.04 每日构建 ISO 镜像已经于今天开放下载,感兴趣的用户可以通过 Canonical 的服务器来...

局长
2017/01/06
3.6K
23
Ubuntu 17.04 公布,代号为“Zesty Zapus”

就在几分钟前,Canonical和Ubuntu创始人Mark Shuttleworth非常高兴地宣布了流行的Ubuntu Linux操作系统下一个主要版本的代号。这个版本是Ubuntu 17.04,其代号将是“Zesty Zapus”。虽然它们...

达尔文
2016/10/18
10.9K
33
Ubuntu 17.04 Beta 1 发布,现可下载

Ubuntu 17.04 Beta 1 发布了。 Ubuntu Budgie,Ubuntu GNOME 和 Xubuntu 是参与这次测试的社区风格之一。 Ubuntu 的常规版本,即大家希望看到的版本将会参加第二个 beta 版。 要详细了解测试...

局长
2017/02/24
4K
16

没有更多内容

加载失败,请刷新页面

加载更多

小白带你认识netty(三)之NioEventLoop的线程(或者reactor线程)启动(一)

在第一章中,我们看关于NioEventLoopGroup的初始化,我们知道了NioEventLoopGroup对象中有一组EventLoop数组,并且数组中的每个EventLoop对象都对应一个线程FastThreadLocalThread,那么这个...

天空小小
今天
3
0
PHP动态扩展Redis模块

查看已有模块 [root@test-a ~]# /usr/local/php/bin/php -m[PHP Modules]bz2Core...zlib[Zend Modules] 下载包,解压,生成configure文件 [root@test-a ~]# cd /usr/local/src/[ro......

野雪球
今天
4
0
在Ignite中使用线性回归算法

在本系列前面的文章中,简单介绍了一下Ignite的机器学习网格,下面会趁热打铁,结合一些示例,深入介绍Ignite支持的一些机器学习算法。 如果要找合适的数据集,会发现可用的有很多,但是对于...

李玉珏
今天
5
0
Mybatis应用学习——简单使用示例

1. 传统JDBC程序中存在的问题 1. 一个简单的JDBC程序示例: public class JDBCDemo {public static void main(String[] args) {Connection con=null;PreparedStatement statemen...

江左煤郎
今天
5
0
使用JavaScript编写iOS应用业务逻辑

JSAUIKitCocoa使你可以使用JavaScript编写对性能要求不高但可能变动性很大的iOS应用的业务逻辑部分,View组件、需要多线程支持的Model等则直接使用原生对象。 编写方式与React Native相似,但...

neal01
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部