Visualize data

Once you have used the data management service to capture data, you can visualize your data with either the Viam app’s TELEOP page or a variety of third-party tools, including Grafana, Tableau, Google’s Looker Studio, and more.

Teleop

Visualize sensor data on a widget with the Viam app’s TELEOP page.

Prerequisites

A configured machine with sensor components

Make sure your machine has at least one of the following:

  • A movement sensor or sensor

See configure a machine for more information.

Configure a workplace with a sensor widget

1. Create a workspace in the Viam app

Log in to the Viam app.

Navigate to the FLEET page’s TELEOP tab. Create a workspace by clicking + Create workspace. Give it a name.

Blank teleop page.

2. Add widgets

Click Add widget and select the appropriate widget for your machine. Repeat as many times as necessary.

Click Add widget and add a GPS widget for a movement sensor and a time series or stat widget for a sensor.

3. Select a machine

Now, select a machine with which to make your teleop workspace come to life. Select Monitor in the top right corner to leave editing mode. Click Select machine and select your configured machine.

Your dashboard now shows the configured widget for the data from your machine. For example, a time series graph measuring noise over time:

Time series widget measuring noise over time.

Third party tools

Configure data query and use a third-party visualization tool like Grafana to visualize your sensor data.

Prerequisites

Captured sensor data. Click to see instructions.
Follow the docs to capture data from a sensor.
The Viam CLI to set up data query. Click to see instructions.

You must have the Viam CLI installed to configure querying with third-party tools.

To download the Viam CLI on a macOS computer, install brew and run the following commands:

brew tap viamrobotics/brews
brew install viam

To download the Viam CLI on a Linux computer with the aarch64 architecture, run the following commands:

sudo curl -o /usr/local/bin/viam https://storage.googleapis.com/packages.viam.com/apps/viam-cli/viam-cli-stable-linux-arm64
sudo chmod a+rx /usr/local/bin/viam

To download the Viam CLI on a Linux computer with the amd64 (Intel x86_64) architecture, run the following commands:

sudo curl -o /usr/local/bin/viam https://storage.googleapis.com/packages.viam.com/apps/viam-cli/viam-cli-stable-linux-amd64
sudo chmod a+rx /usr/local/bin/viam

You can also install the Viam CLI using brew on Linux amd64 (Intel x86_64):

brew tap viamrobotics/brews
brew install viam

If you have Go installed, you can build the Viam CLI directly from source using the go install command:

go install go.viam.com/rdk/cli/viam@latest

To confirm viam is installed and ready to use, issue the viam command from your terminal. If you see help instructions, everything is correctly installed. If you do not see help instructions, add your local go/bin/* directory to your PATH variable. If you use bash as your shell, you can use the following command:

echo 'export PATH="$HOME/go/bin:$PATH"' >> ~/.bashrc

For more information see install the Viam CLI.

Configure data query

If you want to query data from third party tools, you have to configure data query to obtain the credentials you need to connect to the third party service.

1. Authenticate with the CLI

Authenticate using a personal access token:

viam login

2. Find your organization ID

To create a database user allowing you to access your data, find your organization ID:

viam organizations list

3. Configure a new database user

Configure a new database user for the Viam organization’s MongoDB Atlas Data Federation instance, which is where your machine’s synced data is stored.

Provide your organization’s org-id from step 2, and a password for your database user.

viam data database configure --org-id=<YOUR-ORGANIZATION-ID> --password=<NEW-DBUSER-PASSWORD>

This command configures a database user for your organization for use with data query, and sets the password. If you have run this command before, this command instead updates the password to the new value you set.

4. Determine the connection URI

Determine the connection URI (also known as a connection string) for your organization’s MongoDB Atlas Data Federation instance by running the following command with the organization’s org-id from step 2:

viam data database hostname --org-id=abcd1e2f-a1b2-3c45-de6f-ab123456c123
# Example output
MongoDB Atlas Data Federation instance hostname: data-federation-abcd1e2f-a1b2-3c45-de6f-ab123456c123-0z9yx.a.query.mongodb.net
MongoDB Atlas Data Federation instance connection URI: mongodb://db-user-abcd1e2f-a1b2-3c45-de6f-ab123456c123:YOUR-PASSWORD-HERE@data-federation-abcd1e2f-a1b2-3c45-de6f-ab123456c123-0z9yx.a.query.mongodb.net/?ssl=true&authSource=admin

This command returns:

  • hostname: the MongoDB Atlas Data Federation instance hostname

  • connection URI: the MongoDB Atlas Data Federation instance connection uniform resource indicator. This is the connection URI to your organization’s MongoDB Atlas Data Federation instance, which is of the form:

    mongodb://<USERNAME>:<YOUR-PASSWORD>@<HOSTNAME>/?ssl=true&authSource=admin
    

Most MQL-compatible database clients require the connection URI, along with your user credentials, to connect to this server.

Some MQL-compatible database client instead require a hostname and database name, along with your user credentials, to connect to this server.

You will need the connection URI to query your data in the next section.

Visualize data with third-party tools

When you sync captured data to Viam, that data is stored in the Viam organization’s MongoDB Atlas Data Federation instance. You can use third-party visualization tools, such as Grafana, to visualize your data. Your chosen third-party visualization tool must be able to connect to a MongoDB Atlas Data Federation instance as its data store.

Select a tab below to learn how to configure your visualization tool for use with Viam:

Grafana

1. Choose Grafana instance

Install or set up Grafana. You can use either a local instance of Grafana Enterprise or Grafana Cloud, and can use the free trial version of Grafana Cloud if desired.

2. Install connector to MongoDB data source

Navigate to your Grafana web UI. Go to Connections > Add new connection and add the Grafana MongoDB data source plugin to your Grafana instance.

The Grafana plugin search interface showing the results for a search for mongodb

Install the datasource plugin.

3. Configure a data connection

Navigate to the Grafana MongoDB data source that you just installed. Select Add new data source.

Enter the following information in the configuration UI for the plugin:

  • Connection string: Enter the following connection string, and replace <MONGODB-ATLAS-DF-HOSTNAME> with your database hostname as configured with the viam data database configure command, and replace <DATABASE-NAME> with the desired database name to query. For most use cases with Viam, this database name will be sensorData:

    mongodb://<MONGODB-ATLAS-DF-HOSTNAME>/<DATABASE-NAME>?directConnection=true&authSource=admin&tls=true
    
  • User: Enter the following username, substituting your organization ID as determined earlier, for <YOUR-ORG-ID>:

    db-user-<YOUR-ORG-ID>
    
  • Password: Enter the password you provided earlier.

    The Grafana data source plugin configuration page, showing the connection string and username filled in with the configuration determined from the previous steps

4. Use Grafana for dashboards

With your data connection established, you can then build dashboards that provide insight into your data.

Grafana additionally supports the ability to directly query and transform your data within a dashboard to generate more granular visualizations of specific data. You might use this functionality to visualize only a single day’s metrics, limit the visualization to a select machine or component, or to isolate an outlier in your reported data, for example.

You can query your captured data within a Grafana dashboard using either SQL or MQL.

For example, try the following query to obtain readings from a sensor, replacing sensor-1 with the name of your component:

sensorData.readings.aggregate([
            {$match: {
              component_name: "sensor-1",
              time_received: {$gte: ISODate(${__from})}
              }},
            {$limit: 1000}
            ]
          )

See the guide on querying data for more information.

Other visualization tools

1. Install connector to MongoDB data source

Some visualization clients are able to connect to the Viam MongoDB Atlas Data Federation instance natively, while others require that you install and configure an additional plugin or connector. For example, Tableau requires both the Atlas SQL JDBC Driver as well as the Tableau Connector in order to successfully connect and access data.

Check with the documentation for your third-party visualization tool to be sure you have the required additional software installed to connect to a MongoDB Atlas Data Federation instance.

2. Configure a data connection

Most third-party visualization tools require the connection URI (also called the connection string) to that database server, and the credentials to authenticate to that server in order to visualize your data. Some third-party tools instead require a hostname and database name of the database server. This is what they look like:

If your client supports a connection URI, use the following format and replace YOUR-PASSWORD-HERE with your database password as configured with the viam data database configure command:

mongodb://db-user-abcdef12-abcd-abcd-abcd-abcdef123456:YOUR-PASSWORD-HERE@data-federation-abcdef12-abcd-abcd-abcd-abcdef123456-e4irv.a.query.mongodb.net/?ssl=true&authSource=admin

You can also specify a desired database name in your connection URI, if desired. For example, to use the sensorData database, the default database name for uploaded sensor data, your connection string would resemble:

mongodb://db-user-abcdef12-abcd-abcd-abcd-abcdef123456:YOUR-PASSWORD-HERE@data-federation-abcdef12-abcd-abcd-abcd-abcdef123456-e4irv.a.query.mongodb.net/sensorData?ssl=true&authSource=admin

If you client doesn’t use a connection URI, you can supply the hostname and database name of the database server instead. Substitute the hostname returned from the viam data database hostname command for <MONGODB-ATLAS-DF-HOSTNAME> and the desired database name to query for <DATABASE-NAME>:

mongodb://<MONGODB-ATLAS-DF-HOSTNAME>/<DATABASE-NAME>?directConnection=true&authSource=admin&tls=true

For example, to use the sensorData database, the default name for uploaded data, your connection string would resemble:

mongodb://data-federation-abcdef12-abcd-abcd-abcd-abcdef123456-e4irv.a.query.mongodb.net/sensorData?directConnection=true&authSource=admin&tls=true

If you are using a connection URI, the hostname and database name are already included in the URI string.

You database user name is of the following form:

db-user-<YOUR-ORG-ID>

Substitute your organization ID for <YOUR-ORG-ID>.

3. Use visualization tools for dashboards

Some third-party visualization tools support the ability to directly query your data within their platform to generate more granular visualizations of specific data. You might use this functionality to visualize only a single day’s metrics, limit the visualization to a select machine or component, or to isolate an outlier in your reported data, for example.

While every third-party tool is different, you would generally query your data using either SQL or MQL. See the guide on querying data for more information.

Error

For more detailed instructions on using Grafana, including a full step-by-step configuration walkthrough, see visualizing data with Grafana.

On top of visualizing sensor data with third-party tools, you can also query it with the Python SDK or query it with the Viam app.

To see full projects using visualization, check out these resources: