Prerequisites
Before proceeding, ensure the following prerequisites are met:- Install MindsDB on your system or obtain access to cloud options.
- To use Twelve Labs with MindsDB, install the required dependencies following this instruction.
- Copy your Twelve Labs API Key by navigating to the Dashboard page.
AI Engine
The first step to use this handler is to create an ML Engine. The required argument to create the engine is:twelve_labs_api_key- The TweleveLabs api key.
AI Model
Now, you can use this ML Engine to create Models for the different tasks supported by the handler. When executing theCREATE MODEL statement, the following parameters are supported in the USING clause of the query:
engine: The name of the ML Engine to use. This is a required parameter.twelve_labs_api_key: The Twelve Labs API key to use for authentication, if the ML Engine is not provided.base_url: The base URL of the Twelve Labs API. This is an optional parameter and defaults tohttps://api.twelvelabs.io/v1.2.task: The task to perform. This is a required parameter and must be one ofsearchorsummarization.engine_id: The ID of the Twelve Labs engine to use. This is an optional parameter and defaults tomarengo2.5. However, certain tasks may require a different engine ID; for instance, thesummarizationtask runs only on the Pegasus family of engines. More information about the different engines can be found here.index_name: The name of the index to use; if it does not exist, it will be created. This is a required parameter. More information about indexes can be found here.index_options: A list of the types of information within the video that will be processed by the video understanding engine. This is a required parameter and can be any combination ofvisual,conversation,text_in_videoandlogo. More information about index options can be found here. Certain engines support only a subset of these options; for instance, the Pegasus family of engines only support thevisualandconversationoptions. More information about the about these configurations can be found here.video_urls: A list of URLs to the videos to be indexed. This is an optional parameter, but if not specified, one ofvideo_files,video_urls_columnorvideo_files_columnmust be specified instead.video_files: A list of local paths to the videos to be indexed. This is an optional parameter, but if not specified, one ofvideo_urls,video_urls_columnorvideo_files_columnmust be specified instead.video_urls_column: The name of the column containing the URLs to the videos to be indexed. This is an optional parameter, but if not specified, one ofvideo_urls,video_filesorvideo_files_columnmust be specified instead.video_files_column: The name of the column containing the local paths to the videos to be indexed. This is an optional parameter, but if not specified, one ofvideo_urls,video_filesorvideo_urls_columnmust be specified instead.search_options: A list of the sources of information to use when performing a search. This parameter is required if thetaskissearchand it should be a subset ofindex_options. More information about search options can be found here.search_query_column: The name of the column containing the search queries. This parameter is required if thetaskissearch.summarization_type: The type of summarization to perform. This parameter is required if thetaskissummarizationand it should be one ofsummary,chapterorhighlight.prompt- Provide context for the summarization task, such as the target audience, style, tone of voice, and purpose. This is an optional parameter.
Search
search_options parameter is specific to the search task and should be a subset of index_options.
Summarization
Making Predictions
Given below are examples of using Models created for each of the supported tasks.Search
query column is the name of the column containing the search queries as specified in the query_column parameter of the CREATE MODEL statement.
Note: At the moment, only a single query can be specified in the WHERE clause of the query. The JOIN clause for making multiple predictions will be added in a future release.
Summarization
DESCRIBE statement on the it. The URL or file path of the video will be available in the video_reference column. The following is an example of how to run such a DESCRIBE statement,
| video_id | created_at | updated_at | duration | engine_ids | filename | fps | height | size | video_reference | width |
|---|---|---|---|---|---|---|---|---|---|---|
| 66c8425e35db9fa680cd4195 | 2024-02-23T03:39:10Z | 2024-02-23T03:39:12Z | 43.733333 | pegasus1 | test.mp4 | 30 | 1280 | 3737394 | /path/to/Videos/test.mp4 | 720 |
index_name parameter of the CREATE MODEL statement. If the same index is used for multiple models, the indexed_videos table will contain all of the videos indexed by all of the models that use that index.