Heterogeneous Parallel Programming | CUDA Programming | GPU Acceleration

Coursera

Explore the power of GPU-accelerated computing with this comprehensive Coursera course on heterogeneous parallel programming using CUDA.

University CoursesCudaGPU Programming

Introduction

This Coursera course provides an introduction to heterogeneous parallel programming, focusing on the use of CUDA for programming NVIDIA GPUs. The course covers fundamental concepts of parallel computing, CUDA programming model, and optimization techniques for achieving high performance on GPU-accelerated applications.

screenshot

Highlights

  • Introduction to heterogeneous parallel computing and CUDA programming model
  • Hands-on experience with CUDA data parallelism, memory management, and kernel-based parallel programming
  • Exploration of optimization techniques such as thread scheduling, control divergence, and tiled algorithms
  • Coverage of parallel computation patterns like convolution and reduction

Recommendation

This course is recommended for software developers, computer scientists, and researchers interested in leveraging the computational power of GPUs for parallel programming. It provides a solid foundation in heterogeneous parallel programming and equips learners with the skills to develop high-performance GPU-accelerated applications.

How GetVM Works

Learn by Doing from Your Browser Sidebar

Access from Browser Sidebar

Access from Browser Sidebar

Simply install the browser extension and click to launch GetVM directly from your sidebar.

Select Your Playground

Select Your Playground

Choose your OS, IDE, or app from our playground library and launch it instantly.

Learn and Practice Side-by-Side

Learn and Practice Side-by-Side

Practice within the VM while following tutorials or videos side-by-side. Save your work with Pro for easy continuity.

Explore Similar Hands-on Tutorials

Great Ideas in Computer Architecture | Machine Structures | UC Berkeley

22
University CoursesC
Explore fundamental concepts in computer architecture, including C and assembly programming, caches, performance measurement, and parallelism. Gain valuable skills for computer science and engineering.

Computation Structures | Digital Systems Design | Hardware-Software Intersection

28
University CoursesComputer Architecture
Explore the fundamentals of computation structures with MIT's 6.004 course, covering digital system architecture, hardware-software integration, and contemporary software structures.

Introduction to the Internet: Architecture and Protocols | CS 168 - UC Berkeley

28
University Courses
Comprehensive course on the fundamental design principles and architecture of the Internet, covering key protocols and technologies. Ideal for students interested in networking and internet infrastructure.

Systems Programming | C Language | UNIX/Linux

13
University CoursesC
Gain a deep understanding of system programming and develop skills to write high-performance, low-level software like web servers and multiplayer internet games.

Distributed Systems | CS 425 - Univ of Illinois, Urbana-Champaign

3
University CoursesComputer ScienceDistributed Systems
Comprehensive course covering fundamental concepts in distributed systems, including vector clocks, consensus, and Paxos. Taught by experienced professor Indranil Gupta.

Cloud Computing | Cornell University CS 5412

12
University CoursesCloud ComputingDistributed Systems
Explore the technology of cloud computing, including cloud architecture, scalability, and security. Taught by industry expert Ken Birman.

Computer Architecture | CSCI 360 | CUNY Hunter College

22
University CoursesComputer ArchitectureGPU Programming
Dive into advanced computer architecture topics like cache design, memory hierarchies, and multiprocessors, including in-depth coverage of GPUs and hands-on CUDA programming.

Parallel Computing | CSCI 493.75 - CUNY Hunter College

25
University CoursesCC++
Dive into parallel algorithms and programming with C/C++, MPI, and OpenMP. Gain hands-on experience and understand the principles of high-performance computing.

Programming for Performance | ECE 459 - University of Waterloo

21
University CoursesC++GPU Programming
Learn advanced techniques for profiling, rearchitecting, and implementing high-performance software systems, including parallelization, multithreading, async I/O, and distributed computing.