Deprecation notice
The Classify API will be deprecated on Feb 28, 2025.
Recommended alternative: Update to the 1.3 version of the API and use the Pegasus video understanding model to classify videos.
Resources: Migration guide > Use Pegasus to classify videos.
The Resources.Classify
class provides methods to classify a set of videos or entire indexes.
Methods
Classify a set of videos
Description: This method classifies a set of videos based on the provided parameters and returns the first page of results.
Function signature and example:
async videos(
{ conversationOption = 'semantic', ...restBody }: ClassifyVideosOptions,
options: RequestOptions = {},
): Promise<Models.ClassifyPageResult>
const CLASSES = [
{
name: 'DanceTok',
prompts: ['Dance tutorial', 'Dance group', 'Dance competition'],
},
{
name: 'CookTok',
prompts: ['Cooking tutorial', 'Cooking ustensils review'],
},
];
function printClassifyPageResult(result) {
console.log("Classification results:");
result.data.forEach(videoData => printClassifyVideoData(videoData));
console.log("\nPage information:");
printTokenPageInfo(result.pageInfo);
}
function printClassifyVideoData(videoData) {
console.log(`Video ID: ${videoData.videoId}`);
videoData.classes.forEach(classData => printClassifyClass(classData));
console.log(); // Add a blank line between videos
}
function printClassifyClass(classData) {
console.log(` Class name: ${classData.name}`);
console.log(` Score: ${classData.score}`);
console.log(` Duration ratio: ${classData.durationRatio}`);
if (classData.clips && classData.clips.length > 0) {
console.log(" Clips:");
classData.clips.forEach(clip => printClassifyClip(clip));
}
if (classData.detailedScores) {
printClassifyDetailedScore(classData.detailedScores);
}
}
function printClassifyClip(clip) {
console.log(` Start: ${clip.start}`);
console.log(` End: ${clip.end}`);
console.log(` Score: ${clip.score}`);
console.log(` Option: ${clip.option}`);
console.log(` Prompt: ${clip.prompt}`);
console.log(` Thumbnail URL: ${clip.thumbnailUrl || 'N/A'}`);
}
function printClassifyDetailedScore(detailedScore) {
console.log(" Detailed scores:");
console.log(` Max score: ${detailedScore.maxScore}`);
console.log(` Avg score: ${detailedScore.avgScore}`);
console.log(` Normalized score: ${detailedScore.normalizedScore}`);
}
function printTokenPageInfo(pageInfo) {
console.log(`Limit per page: ${pageInfo.limitPerPage}`);
console.log(`Total results: ${pageInfo.totalResults}`);
console.log(`Page expired at: ${pageInfo.pageExpiredAt}`);
console.log(`Next page token: ${pageInfo.nextPageToken || 'N/A'}`);
console.log(`Previous page token: ${pageInfo.prevPageToken || 'N/A'}`);
}
VIDEO_IDS=["VIDEO_1", "VIDEO_2", "VIDEO_3"];
const result = await client.classify.videos({
videoIds: VIDEO_IDS,
options: ["visual"],
classes: CLASSES,
pageLimit: 2,
// includeClips: true,
showDetailedScore: true,
});
printClassifyPageResult(result);
Parameters:
Name | Type | Required | Description |
---|---|---|---|
params | ClassifyVideosOptions | Yes | Parameters for classifying the videos. |
options | RequestOptions | No | Additional options for the request. Defaults to {} . |
The ClassifyVideosOptions
interface defines the parameters for classifying a set of videos:
Name | Type | Required | Description |
---|---|---|---|
videoIds | string[] | Yes | An array containing the unique identifiers of the videos that you want to classify. |
The following properties are inherited from the ClassifyOptions
interface:
Name | Type | Required | Description |
---|---|---|---|
options | ('visual' | 'conversation' | 'text_in_video')[] | Yes | An array that specifies the sources of information the platform uses when it categorizes a video. |
classes | Array<{ name: string; prompts: string[]; options?: ('visual' | 'conversation' | 'text_in_video')[]; conversationOption?: 'semantic' | 'exact_match' }> | Yes | An array of objects containing the names and the definitions of entities or actions that the platform must identify. |
conversationOption | 'semantic' | 'exact_match' | No | Specifies the type of match the platform will perform. |
pageLimit | number | No | The maximum number of results per page. |
includeClips | boolean | No | Set this parameter to true to retrieve detailed information about each matching video clip. |
threshold | Record<string, any> | No | Thresholds for different classification options. |
showDetailedScore | boolean | No | Whether to show detailed scores in the result. |
Return value: Returns a Promise
that resolves to an Models.ClassifyPageResult
object containing the classification results.
API Reference: For a description of each field in the request and response, see the Classify a set of videos page.
Related guides:
Classify all the videos within an index
Description: This method classifies all the videos within a specific index based on the provided parameters and returns the first page of results.
Function signature and example:
async index(
{ conversationOption = 'semantic', ...restBody }: ClassifyIndexOptions,
options: RequestOptions = {},
): Promise<Models.ClassifyPageResult>
}
const CLASSES = [
{
name: 'DanceTok',
prompts: ['Dance tutorial', 'Dance group', 'Dance competition'],
},
{
name: 'CookTok',
prompts: ['Cooking tutorial', 'Cooking ustensils review'],
},
];
function printClassifyPageResult(result) {
console.log("Classification results:");
result.data.forEach(videoData => printClassifyVideoData(videoData));
console.log("\nPage information:");
printTokenPageInfo(result.pageInfo);
}
function printClassifyVideoData(videoData) {
console.log(`Video ID: ${videoData.videoId}`);
videoData.classes.forEach(classData => printClassifyClass(classData));
console.log(); // Add a blank line between videos
}
function printClassifyClass(classData) {
console.log(` Class name: ${classData.name}`);
console.log(` Score: ${classData.score}`);
console.log(` Duration ratio: ${classData.durationRatio}`);
if (classData.clips && classData.clips.length > 0) {
console.log(" Clips:");
classData.clips.forEach(clip => printClassifyClip(clip));
}
if (classData.detailedScores) {
printClassifyDetailedScore(classData.detailedScores);
}
}
function printClassifyClip(clip) {
console.log(` Start: ${clip.start}`);
console.log(` End: ${clip.end}`);
console.log(` Score: ${clip.score}`);
console.log(` Option: ${clip.option}`);
console.log(` Prompt: ${clip.prompt}`);
console.log(` Thumbnail URL: ${clip.thumbnailUrl || 'N/A'}`);
}
function printClassifyDetailedScore(detailedScore) {
console.log(" Detailed scores:");
console.log(` Max score: ${detailedScore.maxScore}`);
console.log(` Avg score: ${detailedScore.avgScore}`);
console.log(` Normalized score: ${detailedScore.normalizedScore}`);
}
function printTokenPageInfo(pageInfo) {
console.log(`Limit per page: ${pageInfo.limitPerPage}`);
console.log(`Total results: ${pageInfo.totalResults}`);
console.log(`Page expired at: ${pageInfo.pageExpiredAt}`);
console.log(`Next page token: ${pageInfo.nextPageToken || 'N/A'}`);
console.log(`Previous page token: ${pageInfo.prevPageToken || 'N/A'}`);
}
const result = await client.classify.index({
indexId: "<YOUR_INDEX_ID>",
options: ["visual"],
classes: CLASSES,
pageLimit: 2,
// includeClips: true,
showDetailedScore: true,
});
printClassifyPageResult(result);
Parameters:
Name | Type | Required | Description |
---|---|---|---|
params | ClassifyIndexOptions | Yes | Parameters for classifying the videos. |
options | RequestOptions | No | Additional options for the request. Defaults to {} . |
The ClassifyIndexOptions
interface defines the parameters for classifying a set of videos:
Name | Type | Required | Description |
---|---|---|---|
indexId | string | Yes | The unique identifier of the index containing the videos that you want to classify. |
The following properties are inherited from the ClassifyOptions
interface:
Name | Type | Required | Description |
---|---|---|---|
options | ('visual' | 'conversation' | 'text_in_video')[] | Yes | An array that specifies the sources of information the platform uses when it categorizes a video. |
classes | Array<{ name: string; prompts: string[]; options?: ('visual' | 'conversation' | 'text_in_video')[]; conversationOption?: 'semantic' | 'exact_match' }> | Yes | An array of objects containing the names and the definitions of entities or actions that the platform must identify. |
conversationOption | 'semantic' | 'exact_match' | No | Specifies the type of match the platform will perform. |
pageLimit | number | No | The maximum number of results per page. |
includeClips | boolean | No | Set this parameter to true to retrieve detailed information about each matching video clip. |
threshold | Record<string, any> | No | Thresholds for different classification options. |
showDetailedScore | boolean | No | Whether to show detailed scores in the result. |
Return value: Returns a Promise
that resolves to an Models.ClassifyPageResult
object containing the classification results.
API Reference: For a description of each field in the request and response, see the Classify all the videos within an index page.
Related guides:
Retrieve a specific page of results
Description: This method retrieves a specific page of results. This method provides direct pagination. Choose it mainly when the total number of items is manageable, or you must fetch a single page of results.
Function signature and example:
async byPageToken(pageToken: string, options: RequestOptions = {}): Promise<Models.ClassifyPageResult>
function printClassifyPageResult(result) {
console.log("Classification results:");
result.data.forEach(videoData => printClassifyVideoData(videoData));
console.log("\nPage information:");
printTokenPageInfo(result.pageInfo);
}
function printClassifyVideoData(videoData) {
console.log(`Video ID: ${videoData.videoId}`);
videoData.classes.forEach(classData => printClassifyClass(classData));
console.log(); // Add a blank line between videos
}
function printClassifyClass(classData) {
console.log(` Class name: ${classData.name}`);
console.log(` Score: ${classData.score}`);
console.log(` Duration ratio: ${classData.durationRatio}`);
if (classData.clips && classData.clips.length > 0) {
console.log(" Clips:");
classData.clips.forEach(clip => printClassifyClip(clip));
}
if (classData.detailedScores) {
printClassifyDetailedScore(classData.detailedScores);
}
}
function printClassifyClip(clip) {
console.log(` Start: ${clip.start}`);
console.log(` End: ${clip.end}`);
console.log(` Score: ${clip.score}`);
console.log(` Option: ${clip.option}`);
console.log(` Prompt: ${clip.prompt}`);
console.log(` Thumbnail URL: ${clip.thumbnailUrl || 'N/A'}`);
}
function printClassifyDetailedScore(detailedScore) {
console.log(" Detailed scores:");
console.log(` Max score: ${detailedScore.maxScore}`);
console.log(` Avg score: ${detailedScore.avgScore}`);
console.log(` Normalized score: ${detailedScore.normalizedScore}`);
}
function printTokenPageInfo(pageInfo) {
console.log(`Limit per page: ${pageInfo.limitPerPage}`);
console.log(`Total results: ${pageInfo.totalResults}`);
console.log(`Page expired at: ${pageInfo.pageExpiredAt}`);
console.log(`Next page token: ${pageInfo.nextPageToken || 'N/A'}`);
console.log(`Previous page token: ${pageInfo.prevPageToken || 'N/A'}`);
}
const result = await client.classify.byPageToken("<YOUR_PAGE_TOKEN>");
printClassifyPageResult(result);
Parameters:
Name | Type | Required | Description |
---|---|---|---|
pageToken | string | Yes | A token that identifies the page to retrieve. |
options | RequestOptions | No | Additional options for the request. Defaults to {} . |
Return value: Returns a Promise
that resolves to an Models.ClassifyPageResult
object containing the classification results.
API Reference: For a description of each field in the request and response, see the Retrieve a specific page of results page.
Related guides:
Iterative pagination
If your application must retrieve a large number of items, use iterative pagination. To retrieve the first page of results, invoke the videos
or index
method of the classify
object. To retrieve subsequent pages of results, use the async iterator protocol.
const CLASSES = [
{
name: 'DanceTok',
prompts: ['Dance tutorial', 'Dance group', 'Dance competition'],
},
{
name: 'CookTok',
prompts: ['Cooking tutorial', 'Cooking ustensils review'],
},
];
function printClassifyPageResult(result, pageNumber) {
console.log(`Page ${pageNumber}`);
console.log("Classification results:");
const data = result.data || result;
data.forEach(videoData => printClassifyVideoData(videoData));
}
function printClassifyVideoData(videoData) {
console.log(`Video ID: ${videoData.videoId}`);
videoData.classes.forEach(classData => printClassifyClass(classData));
console.log(); // Add a blank line between videos
}
function printClassifyClass(classData) {
console.log(` Class name: ${classData.name}`);
console.log(` Score: ${classData.score}`);
console.log(` Duration ratio: ${classData.durationRatio}`);
if (classData.clips && classData.clips.length > 0) {
console.log(" Clips:");
classData.clips.forEach(clip => printClassifyClip(clip));
}
if (classData.detailedScores) {
printClassifyDetailedScore(classData.detailedScores);
}
}
function printClassifyClip(clip) {
console.log(` Start: ${clip.start}`);
console.log(` End: ${clip.end}`);
console.log(` Score: ${clip.score}`);
console.log(` Option: ${clip.option}`);
console.log(` Prompt: ${clip.prompt}`);
console.log(` Thumbnail URL: ${clip.thumbnailUrl || 'N/A'}`);
}
function printClassifyDetailedScore(detailedScore) {
console.log(" Detailed scores:");
console.log(` Max score: ${detailedScore.maxScore}`);
console.log(` Avg score: ${detailedScore.avgScore}`);
console.log(` Normalized score: ${detailedScore.normalizedScore}`);
}
let classifyResults = await client.classify.index({
indexId: "<YOUR_INDEX_ID>",
options: ["visual"],
classes: CLASSES,
pageLimit: 2,
showDetailedScore: true,
});
let pageNumber = 1;
printClassifyPageResult(classifyResults, pageNumber);
while (true) {
const nextPage = await classifyResults.next();
if (nextPage === null) break;
pageNumber++;
printClassifyPageResult(nextPage, pageNumber);
}
console.log("No more results.");
}