Use Cases for Linode GPU Instances

Updated by Linode Written by Linode

Contribute on GitHub

Report an Issue | View File | Edit File

What are GPUs?

GPUs (Graphical Processing Units) are specialized hardware originally created to manipulate computer graphics and image processing. GPUs are designed to process large blocks of data in parallel making them excellent for compute intensive tasks that require thousands of simultaneous threads. Because a GPU has significantly more logical cores than a standard CPU, it can perform computations that process large amounts of data in parallel, more efficiently. This means GPUs accelerate the large calculations that are required by big data, video encoding, AI, and machine learning.

The Linode GPU Instance

Linode GPU Instances include NVIDIA Quadro RTX 6000 GPU cards with Tensor, ray tracing (RT), and CUDA cores. Read more about the NVIDIA RTX 6000 here.

Use Cases

Machine Learning and AI

Machine learning is a powerful approach to data science that uses large sets of data to build prediction algorithms. These prediction algorithms are commonly used in “recommendation” features on many popular music and video applications, online shops, and search engines. When you receive intelligent recommendations tailored to your own tastes, machine learning is often responsible. Other areas where you might find machine learning being used is in self-driving cars, process automation, security, marketing analytics, and health care.

AI (Artificial Intelligence) is a broad concept that describes technology designed to behave intelligently and mimic the cognitive functions of humans, like learning, decision making, and speech recognition. AI uses large sets of data to learn and adapt in order to achieve a specific goal. GPUs provide the processing power needed for common AI and machine learning tasks like input data preprocessing and model building.

Below is a list of common tools used for machine learning and AI that can be installed on a Linode GPU instance:

  • TensorFlow - a free, open-source, machine learning framework, and deep learning library. Tensorflow was originally developed by Google for internal use and later fully released to the public under the Apache License.

  • PyTorch - a machine learning library for Python that uses the popular GPU optimized Torch framework.

  • Apache Mahout - a scalable library of machine learning algorithms, and a distributed linear algebra framework designed to let mathematicians, statisticians, and data scientists quickly implement their own algorithms.

Big Data

Big data is a discipline that analyzes and extracts meaningful insights from large and complex data sets. These sets are so large and complex that they require specialized software and hardware to appropriately capture, manage, and process the data. When thinking of big data and whether or not the term applies to you, it often helps to visualize the “three Vs”:

  • Volume: Generally, if you are working with terabytes, exabytes, petabytes, or more amounts of information you are in the realm of big data.

  • Velocity: With Big Data, you’re using data that is being created, called, moved, and interacted with at a high velocity. One example is the real time data generated on social media platforms by its users.

  • Variety: Variety refers to the many different types of data formats with which you may need to interact. Photos, video, audio, and documents can all be written and saved in a number of different formats. It is important to consider the variety of data that you will collect in order to appropriately categorize it.

GPUs can help give Big Data systems the additional computational capabilities they need for ideal performance. Below are a few examples of tools which you can use for your own big data solutions:

  • Hadoop - an Apache project that allows the creation of parallel processing applications on large data sets, distributed across networked nodes.

  • Apache Spark - a unified analytics engine for large-scale data processing designed with speed and ease of use in mind.

  • Apache Storm - a distributed computation system that processes streaming data in real time.

Video Encoding

Video Encoding is the process of taking a video file’s original source format and converting it to another format that is viewable on a different device or using a different tool. This resource intensive task can be greatly accelerated using the power of GPUs.

  • FFmpeg - a popular open-source multimedia manipulation framework that supports a large number of video formats.

General Purpose Computing using CUDA

CUDA (Compute Unified Device Architecture) is a parallel computing platform and API that allows you to interact more directly with the GPU for general purpose computing. In practice, this means that a developer can write code in C, C++, or many other supported languages utilizing their GPU to create their own tools and programs.

If you’re interested in using CUDA on your GPU Linode, see the following resources:

Graphics Processing

One of the most traditional use cases for a GPU is graphics processing. Transforming a large set of pixels or vertices with a shader or simulating realistic lighting via ray tracing are massive parallel processing tasks. Ray tracing is a computationally intensive process that simulates lights in a scene and renders the reflections, refractions, shadows, and indirect lighting. It’s impossible to do on GPUs in real-time without hardware-based ray tracing acceleration. The Linode GPU Instances offers real-time ray tracing capabilities using a single GPU.

New to the NVIDIA RTX 6000 are the following shading enhancements:

  • Mesh shading models for vertex, tessellation, and geometry stages in the graphics pipeline
  • Variable Rate Shading to dynamically control shading rate
  • Texture-Space Shading which utilizes a private memory held texture space
  • Multi-View Rendering allowing for rendering multiple views in a single pass.

Where to Go from Here

If you are ready to get started with Linode GPU, our Getting Started with Linode GPU Instances guide walks you through deploying a Linode GPU Instance and installing the GPU drivers so that you can best utilize the use cases you’ve read in this guide.

To see the extensive array of Docker container applications available, check out NVIDIA’s site. Note: To access some of these projects you need an NGC account.

Join our Community

Find answers, ask questions, and help others.

This guide is published under a CC BY-ND 4.0 license.