This custom step populates a Chroma vector database collection with documents and embeddings contained in a SAS Cloud Analytics Services (CAS) table.
Vector databases facilitate many Generative AI applications, particularly in providing context to a Large Language Model (LLM). Examples of other applications include recommendation engines, similarity search and time series forecasting.
Chroma is an open-source vector database used in Generative AI pipelines. It shares many similar constructs and concepts with other vector store offerings.
Here's a quick overview video (click on the image below):
- Assumptions
- Requirements
- Parameters
- Run-time Control
- Documentation
- SAS Program
- Installation and Usage
- Created/Contact
- Change Log
-
For this initial version, your input data requires a text variable, a set of document embeddings (columns) and optionally, an additional categorical variable for metadata. We plan to accommodate additional variables in future versions.
-
Chroma DB follows client / server architecture. This step implicitly considers the client and server to be on the same machine (see comments in code). Users are free to modify the step for persistent, remote/external, or alternatively orchestrated (e.g. Docker container) servers based on their requirement. Chroma DB documentation provides some examples (refer Documentation).
-
While embeddings are typically created using either SAS Visual Text Analytics (VTA) or Visual Data Mining and Machine Learning (VDMML), this custom step does not strictly require a VTA/VDMML license since it only makes use of the output from those applications.
-
This custom step runs on data loaded to a SAS Cloud Analytics Services (CAS) library (known as a caslib). Ensure you are connected to CAS before running this step.
-
Proc Python is required. Details on Python packages in prerequisites section below. Also, consider build and install of Python and required packages through the SAS Configurator for Open Source.
-
Many vector databases (Chroma included), can auto-generate embeddings on ingested text data (documents), using either proprietary or open-source embedding models. This custom step highlights the integration of SAS Viya-generated embeddings (from VTA / VDMML) with vector databases and therefore requires embeddings to be provided as part of input data. A future version will examine how to auto-generate embeddings through the step.
-
A SAS Viya 4 environment version 2023.12 or later.
-
Python packages to be installed:
-
Suggested Python version is 3.10.x due to dependency on sqlite version >= 3.35.0 (refer documentation). However, a workaround suggested by Chroma has been followed in the code.
-
Optional components, based on site-specific architecture, are to have a separate Chroma DB server for persistence and scale. Refer Chroma documentation for details.
-
Input table containing a text column (input port, required): attach a CAS table to this port.
-
Text column (column selector, required, maximum 1): select a text column which your embeddings represent.
-
Document identifier (column selector, required, maximum 1): select a column which serves as a unique identifier for your observation.
-
Embedding pattern (text column, required): document embeddings tend to be long series involving 100s or sometimes 1000s of columns. To avoid having to select them individually, provide a text pattern which applies to all embedding column names. For example, Col_ represents Col_1, Col_2..... Col_n.
-
Metadata column (optional, column selector, maximum 1): select a column which contains additional metadata (for example, a category, sentiment or star rating) which is also ingested into the vector database collection.
-
Location for Chroma database (folder selector, required): select a location to persist the Chroma database. Note this needs to be on the filesystem (SAS Server) and not SAS Content. In case no value is provided, the path defaults to /tmp. Note that /tmp gets cleared upon termination of the SAS compute session.
-
CAS server (text field, default entered): change this only if you need a CAS server name different from a typical Viya 4 installation.
-
CAS port (numeric field, default entered): change this only if you know that the CAS server runs on a different port than the default.
- Name of collection (text column, required): provide a name for your collection. A vector database collection can be viewed as similar to a table in a relational database.
Upon successful completion, an informational message is written to the log indicating number of records loaded.
Note: Run-time control is optional. You may choose whether to execute the main code of this step or not, based on upstream conditions set by earlier SAS programs. This includes nodes run prior to this custom step earlier in a SAS Studio Flow, or a previous program in the same session.
Refer this blog (https://communities.sas.com/t5/SAS-Communities-Library/Switch-on-switch-off-run-time-control-of-SAS-Studio-Custom-Steps/ta-p/885526) for more details on the concept.
The following macro variable,
_hcdc_run_trigger
will initialize with a value of 1 by default, indicating an "enabled" status and allowing the custom step to run.
If you wish to control execution of this custom step, include code in an upstream SAS program to set this variable to 0. This "disables" execution of the custom step.
To "disable" this step, run the following code upstream:
%global _hcdc_run_trigger;
%let _hcdc_run_trigger =0;
To "enable" this step again, run the following (it's assumed that this has already been set as a global variable):
%let _hcdc_run_trigger =1;
IMPORTANT: Be aware that disabling this step means that none of its main execution code will run, and any downstream code which was dependent on this code may fail. Change this setting only if it aligns with the objective of your SAS Studio program.
-
Documentation for the chromadb Python package and Chroma DB
-
SAS Communities article on configuring Viya for Python integration
-
The SAS Viya Platform Deployment Guide (refer to SAS Configurator for Open Source within)
-
Options for persistent clients and client connections in Chroma
-
Every custom step is a learning opportunity for SAS programming! I revisited the venerable but still powerful DATALINES (DATALINES4) statement and it proved helpful in negotiating a design challenge in the SAS program.
-
SAS Communities article on connecting to CAS using the SWAT package in SAS Studio
Refer here for the SAS program used by the step. You'd find this useful for situations where you wish to execute this step through non-SAS Studio Custom Step interfaces such as the SAS Extension for Visual Studio Code, with minor modifications.
- Refer to the steps listed here.
- Sundaresh Sankaran (sundaresh.sankaran@sas.com)
- Version 1.0 (24JAN2024)
- Initial version