Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • Data Integration (Not yet available)
  • Metrics (Not yet available)
  • Machine Learning (Not yet available)

Terminology

To best understand the C3 AI Suite and this guide, we're going to introduce some terminology used throughout the suite.

  • Type: Everything within the C3 AI Suite is stored and accessed through Types. These are objects akin to a Java class which contain 'fields' and 'methods'. Some are persisted to internal databases, and others are not. Nearly every aspect of the C3 AI Suite is accessed through Types.
  • Field: A field of a C3 Type. This contains data associated with the Type.
  • Method: A method defined on a C3 Type.
  • Vanity Url: The URL at which a specific tenant/tag of a C3 Cluster can be accessed. The C3 Cluster itself has a URL as well, however most interaction with the C3 AI Suite is done through the vanity url.
  • Cluster: A deployment of the C3 AI Suite. This can exist in the cloud or in a container. The C3 AI Suite is capable of running on top of numerous tehnologies such as different cloud providers, or virtualization strategies.
  • Tenant: A logical partition of a C3 Cluster. While internally, some data between Tenants may be stored on the same database, this access is not extended to Users of the C3 AI Suite. Users on one tenant can't see data stored on another Tenant.
  • Tag: A slot on which a C3 package is run. Tags sit within a Tenant.
  • Package: The code which the C3 AI Suite runs on a Tag. This is what the developer edits.
  • Provisioning: The loading a Package onto a C3 Tenant/Tag.
  • Static Console: The main method C3 developers use to interact with their C3 Tag. You can access the static console at the url 'https://<vanity_url>/static/console' (Replace <vanity_url> with your vanity url.)
  • Metric: A data analysis object which turns timeseries-like data into a timeseries.

C3 Cluster Overview

The C3 AI Suite is a Platform as a Service (PaaS) system which can exist on top of a number of virtualization technologies and platforms. Generally, A C3 Cluster consists of one or more master nodes which orchestrate jobs which need to be completed, worker nodes that carry out scheduled tasks, and finally some nodes dedicated to technologies on which the platform is based such as postgres and cassandra. On top of this physical computational structure sits a logical software structure which is starts at the top level of Cluster, then Tenant, then Tag. Each cluster contains Tenants which are logically separated from each other (e.g., Packages run on separate Tenants cannot view data from eachother), and each Tenant contains Tags. Tags house C3 Packages which are the actual code that C3 developers provision to the platform. A typical Multi-user Multi-tenant C3 Cluster is shown in a logical diagram below:

...

Provision a C3 Package

Provision your C3 package to your C3 cluster/tenant/tag following the instructions available at the DTI Provisioning Guide. DTI members wishing to execute the examples in this guide should provision the 'baseCovidDataLake' following the directions under the heading 'COVID-19 DataLake Provisioning'.

...

Connecting to a C3.ai cluster

The static console is the main location from which C3 developers typically configure and interact with the C3 AI Suite. We anticipate however, that most DTI researchers will use Python for data analysis. That said, the static console is an essential component of working with the C3 AI Suite, and you will use it frequently. For example, the static console is the best place to find documentation tailored directly to your C3 Package. Its also a great place to quickly test some queries since no specialized environments need to be set up to use it. It's ready to go in your browser.

Accessing the Static Console

Once your C3 package has been provisioned to your Tenant/Tag, Navigate to the static console page. This is at 'https://<vanity_url>/static/console' (Replace <vanity_url> with your vanity url., e.g., https://dti-mkrafczyk.c3dti.ai/static/console). The static console page looks like this:

...

Additionally, most tools are also accessible in the upper right hand corner with a series of Icons:

Using the Static Console

Once you're at the static console, the primary method of interaction is through the JavaScript console of your browser. When the static console page loads (or when you run the c3ImportAll() command), JavaScript methods associated with all of your Package's defined Types are populated. This allows you to run JavaScript code right in the console to interact with your C3 Package.

...

Finally, we can enter some JavaScript code to see the console in action!

Console Commands

We review here several highly used JavaScript console commands which are available on the static console page.

  • c3ImportAll: A console command which loads the API of the current C3 Package. This is necessary after provisioning a new Pacakge if you haven't refreshed your static console page.
  • c3Grid: A console command to display a table of data contained within a C3 Type. (e.g., data returned from a fetch operation, or an evaluate operation among many others).
  • c3Viz: A console command which can produce quick visualizations of some C3 Types. (e.g., timeseries data like EvalMetricsResult)
  • c3ShowType: A console command which produces documentation about a given type. (e.g., c3ShowType(OutbreakLocation))

Official C3.ai Documentation For Static Console

Using Python with the C3 AI Suite

We anticipate most DTI researchers will want to use Python for data analysis. There are two options to connect to a C3.ai Cluster via Python. Please follow the links below for detailed information about each.

...

Fetching Instances of Types

All data in the C3 AI Suite are stored in C3.ai Types.Users can access data from a C3.ai Type with the 'fetch' method. Behind the scenes, the 'fetch' method submits a query directly to the database underlying a C3.ai Type, and retrieves and presents query results to C3 AI Suite users.

...

Note: Please see this C3.ai Developer Documentation for full list of FetchSpec parameters: https://developer.c3.ai/docs/7.12.17/type/FetchSpec

Examples of Fetch Calls

The OutbreakLocation Type contains information various locations for which the Covid-19 DataLake has virus-related information. We can fetch OutbreakLocation records, for which the 'latestTotalPopulation' field exists (i.e., is not null). We can also retrieve these records in descending order by their 'countryArea'.

...

The fetchCount Method

Another useful fetch command is fetchCount. This function is nearly identical to the fetch commands above, but it just returns the number of records which match the fetch filter. This is useful when trying to determine whether a given search is refined enough.

...

To learn more about the 'fetchCount' method, please see the fetchCount method definition in the Persistable Type documentation: https://developer.c3.ai/docs/7.12.17/type/Persistable

Converting Fetch results to usable forms in Jupyter Notebook

When using a Jupyter Notebook, C3.ai developers typically modify FetchResults for data analysis. This section shows a couple ways to convert FetchResults into easy-to-analyze forms.

Python

In python, first, retrieve the 'objs' field from the FetchResults object, and then call the toJson() function. The toJson() function returns an array of dictionaries each with keys equal to the requested fields of the fetched C3.ai Type. Using the Pandas library, this array can be turned into an analysis-ready DataFrame, as the below example shows.

...

Users can then manipulate the resulting DataFrame, using common programming libraries and frameworks.

ExpressionEngineFunctions

The C3 AI Suite also provides a pre-built library of "ExpressionEngineFunctions". Expression EngineFunctions take a variety of arguments and perform various data processing tasks. For example, the function 'contains' takes two strings as arguments, and checks whether the first argument contains the second argument. The function 'lowerCase' takes as input a string, and returns that same string with all lowercase letters. In addition to these string processing functions, the C3 AI Suite's ExpressionEngine includes many math functions such as 'log', 'avg', and 'abs', which operate on a various input data types (e.g. int, double, float).

...

Simple Expressions on Types using Evaluate

The C3 AI Suite provides the 'evaluate' method to compute simple expressions on the data stored within a C3 Type. (e.g., compute the average area of all OutbreakLocations which are countries and for which we have area information)

...

Developing Metrics on Timeseries data

The C3 AI Suite also offers several features to handle timseries data. To interact with timeseries C3.ai developers typically use simple and compound metrics. These metrics are used in several places in the C3 AI Suite such as:

  • Alerts and Application Logic
  • Machine Learning Features
  • User Interface (to Visualize Data)

Simple Metrics

Simple metrics allow C3.ai developers to produce timeseries from raw data, and are often used to construct more advanced metrics (i.e., Compound Metrics), in practice. Simple metrics are linked to a specific C3.ai Type and reference the timeseries data stored within that C3.ai Type. To declare a simple metric, users should specify the following fields:

...

Compound Metrics

Compound metrics allow C3.ai developers to manipulate or combine existing metrics into more complex timeseries. Compound metrics are built on top of one or many existing Simple or Compound metrics. Please note, to evaluate a Compound metric on a C3.ai Type, all Simple metrics, used in that Compound metric, must be defined on that C3.ai Type, as well. Otherwise, an error is returned.

...

Finding, Evaluating, and Visualizing Metrics

Users can evaluate & visualize metrics built in the C3 AI Suite, via the JavaScript console or a hosted Jupyter notebook.

Finding Metrics

All metrics that users build and deploy in the C3 AI Suite are also stored in C3.ai Types. To view a list of all the simple and compound metrics applicable to a C3.ai Type, run the 'listMetrics' method, as shown below:

...

After finding a metric, the next step is to evaluate on data in a C3.ai Type.

Evaluating Metrics

Metrics are evaluated with either the 'evalMetrics' or 'evalMetricsWithMetadata' methods. Behind the scenes, 'evalMetrics' and 'evalMetricsWithMetadata', fetch and transform raw data from a C3.ai Type into easy-to-analyze timeseries data. 'evalMetrics' is used to evaluate metrics provisioned (deployed) to a C3.ai tenant/tag. 'evalMetricsWithMetadata' allows users to evaluate metrics either provisioned to a C3.ai tenant/tag or defined on-the-fly in JavaScript console or a hosted Jupyter notebook (typically for debugging).

...

Note: Metrics can only be evaluated on C3.ai Types that mix in the 'MetricEvaluatable' Type.

Conclusion

Official C3.ai Developer Documentation:

Review and Next Steps


In most data analysis, C3.ai developers run the 'fetch' and 'evalMetrics' methods. This C3.ai DTI Quickstart guide provides an introduction to these methods, in which the C3 AI Suite is used as a read-only database, accessed via APIs. In the following guides, you will learn how to run 'write' operations on the C3 AI Suite such as:

...