GPU Programming with CUDA and Python 培训
CUDA (Compute Unified Device Architecture)是由Nvidia创建的平行计算平台和API。
本课程为讲师指导的培训(线上或线下),适合中级开发者,他们希望使用CUDA来构建Python应用程式,这些应用程式可以在NVIDIA GPU上平行运行。
在本研讨会结束后,参与者将能够:
- 使用Numba编译器加速在NVIDIA GPU上运行的Python应用程式。
- 创建、编译并启动自定义的CUDA核心。
- 管理GPU记忆体。
- 将基于CPU的应用程式转换为GPU加速的应用程式。
课程格式
- 互动式讲座与讨论。
- 大量的练习与实践。
- 在即时实验室环境中进行实作。
课程定制选项
- 如需为本课程定制培训,请联系我们进行安排。
课程大纲
介绍
- 什么是GPU编程?
- 为什么要在Python中使用CUDA?
- 关键概念:线程、区块、网格
CUDA功能与架构概述
- GPU与CPU架构的比较
- 理解SIMT(单指令多线程)
- CUDA编程模型
设置开发环境
- 安装CUDA工具包与驱动程序
- 安装Python与Numba
- 设置与验证环境
并行Programming基础
- 并行执行介绍
- 理解线程与线程层次结构
- 处理warp与同步
使用Numba编译器
- Numba介绍
- 使用Numba编写CUDA核心
- 理解@cuda.jit装饰器
构建自定义CUDA核心
- 编写与启动基本核心
- 使用线程进行逐元素操作
- 管理网格与区块维度
记忆体Management
- GPU记忆体类型(全局、共享、本地、常量)
- 主机与设备之间的记忆体传输
- 优化记忆体使用与避免瓶颈
GPU加速的高级主题
- 共享记忆体与同步
- 使用流进行异步执行
- 多GPU编程基础
将基于CPU的应用程式转换为GPU
- 分析CPU代码
- 识别可并行化的部分
- 将逻辑移植到CUDA核心
疑难排解
- 调试CUDA应用程式
- 常见错误与解决方法
- 测试与验证的工具与技巧
总结与下一步
- 关键概念回顾
- GPU编程的最佳实践
- 持续学习的资源
要求
- Python 程式设计经验
- 具备 NumPy 使用经验(如 ndarrays、ufuncs 等)
观众
- 开发者
需要帮助选择合适的课程吗?
GPU Programming with CUDA and Python 培训 - Enquiry
GPU Programming with CUDA and Python - 问询
问询
客户评论 (1)
与各种示例非常互动,在培训开始和结束之间的复杂性进展良好。
Jenny - Andheo
课程 - GPU Programming with CUDA and Python
机器翻译
即将举行的公开课程
相关课程
Scaling Data Analysis with Python and Dask
14 小时这种以讲师为主导的中国现场培训(现场或远程)针对的是希望将Dask与Python生态系统一起使用以构建,扩展和分析大型数据集的数据科学家和软件工程师。
在培训结束时,参与者将能够:
- 设置环境以开始使用 Dask 和 Python 构建大数据处理。
- 探索 Dask 中提供的功能、库、工具和 API。
- 了解 Dask 如何在 Python 中加速并行计算。
- 了解如何使用 Dask 扩展 Python 生态系统(Numpy、SciPy 和 Pandas)。
- 优化 Dask 环境,以保持处理大型数据集的高性能。
Data Analysis with Python, Pandas and Numpy
14 小时This instructor-led, live training in 中国 (online or onsite) is aimed at intermediate-level Python developers and data analysts who wish to enhance their skills in data analysis and manipulation using Pandas and NumPy.
By the end of this training, participants will be able to:
- Set up a development environment that includes Python, Pandas, and NumPy.
- Create a data analysis application using Pandas and NumPy.
- Perform advanced data wrangling, sorting, and filtering operations.
- Conduct aggregate operations and analyze time series data.
- Visualize data using Matplotlib and other visualization libraries.
- Debug and optimize their data analysis code.
Web Development with Django
21 小时Django是一个高级Python Web框架,鼓励快速开发和干净,实用的设计。
听众
本课程面向寻求将Django纳入其项目的开发人员和工程师
Monax: Build a Smart Contract Application
7 小时在这个由 <lo> 讲师指导的现场培训中,参与者将学习如何使用 Monax 构建智慧合约区块链应用程式。
在本次培训结束时,参与者将能够:
- 使用区块链和智慧合约技术开发和部署分散式应用程式。
- 了解“智能合约”的设计和功能以及如何创建智能合约。
- 实施安全区块链应用程序开发的最佳实践。
- 利用 Monax 工具简化分散式应用程式开发。
FARM (FastAPI, React, and MongoDB) Full Stack Development
14 小时这种以讲师为主导的现场培训(现场或远程)面向希望使用FARM(FastAPI,React和MongoDB)堆栈构建动态,高性能和可扩展Web应用程序的开发人员。
在培训结束时,参与者将能够:
-
设置集成 FastAPI、React 和 MongoDB 的必要开发环境。
了解 FARM 堆栈的关键概念、功能和优势。
了解如何使用 FastAPI 构建 REST API。
了解如何使用 React 设计交互式应用程序。
使用 FARM 堆栈开发、测试和部署应用程序(前端和后端)。
Developing APIs with Python and FastAPI
14 小时这种以讲师为主导的中国现场培训(现场或远端)面向希望将FastAPI与Python一起使用以更轻松,更快速地构建,测试和部署RESTful API的开发人员。
在培训结束时,参与者将能够:
- 设置必要的开发环境,以使用Python和FastAPI开发API。
- 使用FastAPI库更快速、更轻松地创建API。
- 学习如何基于Pydantic和OpenAPI创建数据模型和模式。
- 使用SQLAlchemy将API连接到数据库。
- 使用FastAPI工具在API中实现安全性和身份验证。
- 构建容器镜像并将Web API部署到云端伺服器。
Web Application Development with Flask
14 小时本实践课程面向希望创建和维护其第一个Web应用程序的Python开发人员。它也适用于已经熟悉其他Web框架(如Django或Web2py ,并希望了解如何使用微框架(即将第三方库粘合在一起而不是提供自包含的通用解决方案的框架)更改这个过程。
本课程的一个重要部分不是专注于Flask本身(它很小),而是专注于Flask项目中经常使用的第三方库和工具。
Advanced Flask
14 小时这种由讲师指导的中国现场培训(现场或远程)针对的是希望使用Flask的高级功能在MongoDB之上构建可扩展Web应用程序的开发人员。
在培训结束时,参与者将能够:
- 设置必要的开发环境以开始使用 Flask 开发 Web 应用程序。
- 了解实际 Flask 项目的高级概念和技术。
- 在 MongoDB 之上构建一个 RESTful API 服务器。
- 了解如何使用 Flask、Docker 和 Amazon EC2 容器化、测试和部署微服务。
- 深入了解用于扩展 Web 应用程序的高级 Flask 集成。
Kivy: Building Android Apps with Python
7 小时Kivy是一个用Python编写的开源跨平台图形用户界面库,它允许为多种设备进行多点触摸应用程序开发。
在这个由讲师指导的实时培训参与者将学习如何在不同平台上安装和部署Kivy ,自定义和操作小部件,安排,触发和响应事件,通过多点触摸修改图形,调整屏幕大小,打包Android应用程序,和更多。
在培训结束时,参与者将能够
- 将Python代码与Kivy语言相关联。
- 深入理解Kivy的工作原理,并充分利用其最重要的元素,如小部件、事件、属性、图形等。
- 根据不同的业务和设计需求,无缝开发和部署Android应用程序。
课程形式
- 部分讲授、部分讨论、练习和大量动手实践
Accelerating Python Pandas Workflows with Modin
14 小时这种由 讲师指导的 中国 现场现场培训(在线或现场)面向希望使用 Modin 构建和实施并行计算的数据科学家和开发人员 Pandas 以加快数据分析速度。
在本次培训结束时,参与者将能够:
- 设置必要的环境,开始使用 Modin 大规模开发 Pandas 工作流。
- 了解 Modin 的功能、架构和优势。
- 了解 Modin、Dask 和 Ray 之间的区别。
- 使用 Modin 更快地执行 Pandas 操作。
- 实现整个 Pandas API 和函数。
Game Development with PyGame
7 小时此讲师指导的现场培训在 中国(在线或现场)面向希望使用 PyGame 使用 Python 程式设计创建和构建游戏的开发人员。
在本次培训结束时,参与者将能够:
- 设置必要的开发环境,开始使用 PyGame 和 Python 建立游戏应用程式。
- 了解如何创建与动画和多媒体功能集成的互动式 PyGame 应用程式。
- 使用 PyGame 测试套件运行和测试游戏程式,并将其转换为可执行档。
Developing GUI Python Applications with PyQt
21 小时这种以讲师为主导的中国现场现场培训(现场或远程)针对的是希望使用Python和Qt UI框架编写具有视觉吸引力的软件应用程序的人。
在培训结束时,参与者将能够:
- 设置一个包含所有需要的库、包和框架的开发环境。
- 创建一个桌面或服务器应用程序,其用户界面运行流畅且具有视觉吸引力。
- 实现各种UI元素和效果,包括小部件、图表、图层等,以达到可用性的最大效果。
- 在设计和开发阶段实施良好的UI设计和代码组织。
- 测试和调试应用程序。
Build REST APIs with Python and Flask
14 小时这是一个由讲师指导的现场培训,在 中国(线上或现场)进行,旨在帮助后端开发人员使用 Python 和 Flask 构建 REST API。
在培训结束时,参与者将能够:
- 实作一个 REST API,使 Flask 网页应用程式能够在后端读取和写入资料库。
- 开发进阶的身份验证功能,如刷新令牌。
- 为未来的 Python 专案构建可重复使用的后端。
- 使用 SQLAlchemy 简化资料存储。
- 将 REST API 部署到云端伺服器上。
Scientific Computing with Python SciPy
7 小时这种以讲师为主导的中国现场现场培训面向希望使用SciPy使用Python创建高级科学计算功能的开发人员。
在培训结束时,参与者将能够:
- 设置必要的开发环境,以开始创建科学计算功能。
- 通过执行复杂操作的实际范例,充分利用SciPy的功能。
- 实现并优化数学算法和函数,以解决科学问题。
- 设计数据结构和插值方法,用于可视化、处理和分析。
Web Development with Web2Py
28 小时Web2py是一个基于python的免费开源全栈框架,用于快速开发快速,可扩展,安全和可移植的数据库驱动的基于Web的应用程序。
听众
本课程面向工程师和开发人员,使用web2py作为Web开发框架