UTAustinX: LAFF-On Programming for High Performance
|
Learn to squeeze high performance out of modern CPUs.
About this course
Is my code fast? Can it be faster? Scientific computing, machine learning, and data science are about solving problems that are compute intensive. Choosing the right algorithm, extracting parallelism at various levels, and amortizing the cost of data movement are vital to achieving scalable speedup and high performance.
In this course, the simple but important example of matrix-matrix multiplication is used to illustrate fundamental techniques for attaining high-performance on modern CPUs. A carefully designed and scaffolded sequence of exercises leads the learner from a naive implementation to one that effectively utilizes instruction level parallelism and culminates in a high-performance multithreaded implementation. Along the way, it is discovered that careful attention to data movement is key to efficient computing.
Prerequisites for this course are a basic understanding of matrix computations (roughly equivalent toWeeks 1-5 of Linear Algebra: Foundations to Frontiers on edX) and an exposure to programming. Hands-on exercises start with skeletal code in the C programming language that is progressively modified, so that extensive experience with C is not required. Access to a relatively recent x86 processor such as Intel Haswell or AMD Ryzen (or newer) running Linux is required.
MATLAB Online licenses will be made available to the participants free of charge for the duration of the course.
Join us to satisfy your need for speed!
At a Glance:
Institution: UTAustinX
Subject: Computer Science
Level: Intermediate
Prerequisites:
Exposure to programming and Linux. Basic understanding of matrix-matrix multiplication.
Language: English
Video Transcript: English
Associated skills:Linear Algebra, Machine Learning, Extract Transform Load (ETL), Matrix Multiplication, Algorithms, Amortization, Scientific Computing, Scalability, Data Science, Linux, C (Programming Language), X86 Architecture
User Reviews
Be the first to review “UTAustinX: LAFF-On Programming for High Performance” Cancel reply
Related Products
IBM: Operating Systems and Security
This course focuses on the foundational concepts common to all operating systems and the unique aspects of Windows, Linux, and macOS.
HarvardX: Data Science: R Basics
Build a foundation in R and learn how to wrangle, analyze, and visualize data.
Linux 2
The second in a 2-course series preparing you for the Linux Professional Institute LPIC-1 certification. Elevate your Linux skills.
LinuxFoundationX: Introduction to Cloud Infrastructure Technologies
Learn the fundamentals of building and managing cloud technologies directly from The Linux Foundation, the leader in open source.
LinuxFoundationX: Introduction to Open Source Networking Technologies
Learn technical fundamentals needed to adopt SDN, NFV, disaggregation, orchestration, network automation, and modern networking. Discover use cases and technical options for open networking. Plus: learn more about The Linux Foundation networking projects.
LinuxFoundationX: Git for Distributed Software Development
Get a thorough introduction to Git, the source control system that arose out of the Linux kernel community, that enables widely distributed software development to operate efficiently.
There are no reviews yet.