Glossary
API
API stands for application programming interface. An API defines the methods and data structures that allow different software components or systems to communicate with each other.
In the Viam platform, APIs are used extensively to:
- Control hardware components (motors, cameras, sensors, etc.)
- Access services (vision, motion, navigation, etc.)
- Manage machines and organizations
- Process and analyze data
These APIs are accessible through various SDKs in languages like Python, Go, and TypeScript.
API Namespace Triplet
Every Viam resource implements an application programming interface (API) that describes how you can interact with that resource.
These APIs are organized by colon-delimited-triplet identifiers, in the form of namespace:type:subtype.
The namespace for built-in Viam resources is rdk, while the type is component or service.
subtype refers to a specific component or service, like a camera or vision.
One API can have various models, custom or built-in, but they all must conform to the same API definition. This requirement ensures that when a resource of that model is deployed, you can interface with it using the same client API methods you would when programming resources of the same API with a different model.
Each resource implements one and only one API.
For example:
Attribute
A configuration parameter of a resource.
Base
A physical, mobile platform that the other parts of a mobile robot attach to. For example, a wheeled rover, boat, or flying drone.
For more information see Base Component.
Blob storage
A cheap but slow storage medium.
Board
A board is the signal wire hub of a machine that provides access to GPIO pins.
Examples of boards include Jetson, Raspberry Pi, or Numato.
For more information see Board Component.
Captive web portal
A captive portal is a web page that is automatically displayed to users often as a landing or log-in page when connecting to a network.
For more information see captive portal.
Client Application
Client applications run business logic to operate your machine.
You can run a client application on the same part that runs viam-server, or on a separate device.
Client applications typically use an SDK to talk to their machine.
Component
A resource that often represents a physical piece of hardware in a machine which a computer controls; for example, a servo, a camera, or an arm.
Each component is typed by a proto API, such as the component proto definitions.
For more information, see Components.
Flash
Flashed or flashing refers to the process of writing an operating system, firmware, or other software directly to a device’s non-volatile storage medium, such as an SD card, eMMC storage, or flash memory.
In the context of robotics and the Viam platform, flashing is commonly performed when:
- Setting up a new Raspberry Pi with an operating system
- Installing the Viam Micro-RDK on supported microcontrollers
The flashing process typically involves:
- Downloading an image file (OS or firmware)
- Using specialized software to write the image to the target device
- Verifying the write was successful
- Booting or resetting the device to load the new software
For example, when setting up a Raspberry Pi for use with Viam, you would “flash” Raspberry Pi OS to an SD card using the Raspberry Pi Imager or similar software.
Flashing is different from regular software installation because it involves writing directly to storage at a low level, often replacing everything on the target storage medium.
Fragment
A reusable configuration block that you can share across multiple machines. For example, if you are deploying a specific mobile machine that is always physically connected the same way, you can create a fragment to make managing your fleet easy.
For more information, see Fragments.
Frame
A frame represents a coordinate system that describes the position and orientation of an object. See also frame system.
The location of a frame is described in relation to its parent frame using rigid transformations rather than in absolute terms.
Frame System
The frame system holds reference frame information for the relative position of components in space.
Gantry
A mechanical system that only uses linear motion to carry out a task; for example, the scaffolding of a 3D printer, which moves the print head around on motorized linear rails.
gRPC
An open source, cross-platform, high performance Remote Procedure Call (RPC) framework initially developed at Google in 2015. With gRPC, a client application can communicate directly with a server application on a different machine. This framework can run in any environment and efficiently connect distributed applications and services.
For more information see grpc.io.
Jobs
Jobs are automated tasks that run on machines at specified intervals to perform routine operations such as a task based on sensor readings, maintenance operations, and system checks.
The job scheduler is built into viam-server and executes configured jobs according to their specified schedules.
Each job targets a specific resource on your machine and calls a designated method at the scheduled intervals.
For more information, see Schedule automated jobs.
Location
A location is a virtual grouping of machines that allows you to organize machines and manage access to your fleet.
For more information, see Manage Locations and Sub-Locations.
Machine
A smart machine is an organizational concept, consisting of either one part, or multiple parts working closely together to complete tasks.
For more information, see Machines.
Machine Config
The complete configuration of a single machine part, including components, services, and scheduled jobs.
For more information, see Configuration.
Machine FQDN
The fully qualified domain name (FQDN) of a machine in the Viam platform, typically in the format <machine-name>.<location-id>.viam.cloud.
Used to uniquely identify and access a machine through Viam cloud infrastructure.
Machine ID
A Machine ID is a unique identifier assigned to each machine in the Viam platform. This ID is used to identify and reference a specific machine within the Viam ecosystem.
Machine IDs are automatically generated when a new machine is created on Viam. You can get it using the web UI and the Fleet management API.
ML
ML stands for machine learning, a field of artificial intelligence that focuses on building systems that can learn from and make decisions based on data.
Viam provides tools for training ML models, deploying them to machines, running inference, and interpret visual data from cameras to enable intelligent behavior in robotic systems.
Model
A particular implementation of a resource API.
Models allow you to control hardware or software of a similar category, such as motors, with a consistent set of methods as an interface, even if the underlying implementation differs.
For example, some models of DC motors communicate using GPIO, while other DC motors use serial protocols like the SPI bus.
Regardless, you can power any motor model that implements the rdk:component:motor API with the SetPower() method.
Models are either included with viam-server or provided through modules.
All models are uniquely namespaced as colon-delimited-triplets.
Built-in model names have the form rdk:builtin:name.
Modular resource model names have the form namespace:module-name:model-name.
See Write your module for more information.
Model Namespace Triplet
Models are uniquely namespaced as colon-delimited-triplets.
Modular resource model names have the form namespace:module-name:model-name, for example esmeraldaLabs:sensors:moisture.
Built-in model names have the form rdk:builtin:name, for example rdk:builtin:gpio.
See Write your module for more information.
Modular Resource
A modular resource is a model of a component or service provided by a module.
A modular resource runs in a module process.
This differs from built-in resources, which run as part of viam-server.
For more information see the Create a module.
Module
A module is a code package which provides one or more modular resources, which add resource types or models, integrations, or control logic for your machines.
Modules run alongside viam-server as separate process, communicating with viam-server over UNIX sockets.
You can create your own module or add existing modules from the registry.
MQL
MQL is the MongoDB query language, similar to SQL but specific to the MongoDB document model.
You can use MQL to query data that you have synced to Viam using the data management service.
Organization
An organization or org is the highest level grouping in the Viam platform, which generally represents a company, or other institution. Every location is grouped into an organization. You can also have organizations for departments or other entities, or for personal use.
For more information, see Organize your machines.
Origin frame
The origin frame is the frame at the base of an arm, gantry, or other component. This is typically the point at the center of where the component is mounted to a table or stand.
Every component that has a kinematics chain has an origin frame and an end effector frame, for example my_arm_origin and my_arm.
If you parent a gripper to the arm’s my_arm frame, the frame system will know the gripper is at the end of the arm.
If you mistakenly parent the gripper to the arm’s my_arm_origin frame, the frame system will think the gripper is at the base of the arm, and the gripper will not move when you move the arm.
For more information, see How the frame system works.
Package
A package is an archive, module, ML model, SLAM map, or other bundle of binary code.
Packages are used to deploy software to machines.
Part
Smart machines are organized into parts, where each part represents a computer (a single-board computer, desktop, laptop, or other computer) running viam-server, the hardware components attached to it, and any services or other resources running on it.
For more information, see Machine Architecture: Parts.
Pi
Pi is short for Raspberry Pi, a series of small, affordable single-board computers developed by the Raspberry Pi Foundation. These credit card-sized computers are widely used in robotics, IoT projects, education, and DIY electronics.
Viam supports many different devices including Raspberry Pis as host computers for running viam-server.
To set up a Raspberry Pi, see the Raspberry Pi setup instructions.
Pin Number
A pin number is the physical index of a pin on a board.
This number is distinct from the GPIO number assigned to general purpose input/output (GPIO) pins. For example, pin number “11” on a NVIDIA Jetson Nano is GPIO “50”, and pin number “11” on a Raspberry Pi 4 is GPIO “17”. When Viam documentation refers to pin number, it will always mean the pin’s physical index and not GPIO number.
Pin numbers are found on a board’s pinout diagram and datasheet.
Protocol Buffers (Protobuf)
A free and open-source, language-neutral, cross-platform data format for serializing structured data.
Protocol Buffers are useful in developing programs that communicate with each other over a network or for storing data.
RDK (Robot Development Kit)
Viam’s Robot Development Kit (RDK) is the open-source, on-machine portion of the Viam platform, that provides viam-server and the Go SDK.
Remote part
A machine part which is controlled by another machine part.
For more information, see Machine Architecture: Parts.
Resource
Resources are individual, addressable elements of a machine.
Parts can operate multiple types of resources:
- physical components
- software services
- modular resources provided by modules
Each part has local resources and can also have resources from another remote machine part. The capabilities of each resource are exposed through the part’s API.
Each resource on your machine implements either one of the existing Viam APIs, or a custom interface.
SDK (Software Development Kit)
Viam provides software development kits (SDKs) to help you write client applications and create support for custom component types.
The SDKs wrap the viam-server gRPC Viam Robot API and streamline connection, authentication, and encryption.
For more information, see Interact with Resources with Viam’s Client SDKs.
Service
Services are built-in software packages for complex capabilities such as simultaneous localization and mapping (SLAM), computer vision, motion planning, and data collection.
Each service is typed by a proto API, such as the service proto definitions.
For more information, see Service APIs.
SLAM
SLAM (Simultaneous Localization and Mapping) algorithms use data from a machine’s sensors, like LiDARs, cameras, and movement sensors, to generate a map of the environment and determine the machine’s position within it.
For more information, see SLAM.
Smart Machine
A machine or device that lives in the real world and has some ability to perceive the world (with a sensor, for example) and perform actions like operating a motor. The machine might also interact with other systems, with the cloud, or with users.
SQL
SQL (structured query language) is the widely-used, industry-standard query language popular with relational databases.
You can use SQL to query data that you have synced to Viam using the data management service.
Subtype
A category within a type of resource. Resource models belonging to a subtype share the same API. Models implement that subtype’s API protocol with different drivers.
For example, an arm is a subtype of the component resource type, while the ur5e is a model of the arm subtype’s API.
The Vision Service is a subtype of the service resource type.
The subtype string is the third part of the API namespace triplet.
Trigger
A trigger is a mechanism that sends alerts by email or webhook when specific events occur in your machine or data.
Triggers can alert you when the following events occur:
- Machine telemetry data syncs from your local device to the Viam cloud
- Data syncs from a machine
- A service detects a specified object or classifies a specified label
For more information, see Trigger configuration.
Type
In the RDK architecture’s namespace triplet for resource APIs, type refers to the distinction between component or service.
Viam Agent
The Viam Agent is a provisioning application for deploying and managing viam-server across a fleet of machines.
You can use the Viam Agent to provision a machine as it first comes online with a pre-defined configuration, including WiFi networks or additional build or provision steps.
See Provision Machines for more information.
Viam Robot API
The specification for communication with resources.
- The SDKs implement the Viam Robot API server-side.
- The SDKs use the Viam Robot API to act as clients.
Currently, the Viam Robot API is defined in a collection of Protocol Buffer files.
All SDKs written by Viam use gRPC but the Viam Robot API itself does not mandate gRPC as the transport mechanism.
viam-micro-server
The lightweight version of viam-server, built for microcontrollers.
viam-micro-server is a set of open-source utilities which run on your microcontroller and provides Viam functionality to your machine.
viam-micro-server is built from the Micro-RDK.
For more information see Architecture.
viam-server
The open-source executable binary that runs on your machine’s computer (such as a single-board computer or a server) and provides most Viam functionality.
viam-server is built from the RDK.
For more information see Architecture.
View setup instructions
Before configuring a machine part, you must follow the correct setup instructions for your machine’s architecture. You can view the setup instructions by clicking on the part status dropdown next to your machine’s name in the top left corner of the page and clicking View setup instructions.
Vision service
The vision service is a service in the Viam platform that enables machines to interpret visual data captured by camera using computer vision and machine learning techniques. Vision services can use various models, including pre-trained models or custom models trained on your own data using the Viam platform.
For more information, see the Vision service documentation or Alert on inferences.
WebRTC
An open source project which provides applications with real-time communication (RTC) using application programming interfaces (API) allowing powerful voice and video integration.
For more information see webrtc.org.
Websockets
A computer communications protocol that provides full-duplex communication channels over a single Transmission Control Protocol (TCP) connection.
World frame
The world reference frame is the fixed, global coordinate system that serves as the reference point for all other coordinate frames in a robotic system. It provides a consistent basis for describing the position and orientation of robots, components, and objects in the physical space. All other coordinate frames (such as machine frames and component frames) are defined relative to this world frame, either directly or through a chain of transformations.
The user chooses the world frame, and defines it implicitly. For example, if you have a robot arm mounted on a table and you define the arm’s origin frame as having no translation or orientation relative to the world frame, then the arm’s origin frame is the origin of the world frame.