Summaries, chapters, and highlights

Use the /summarize endpoint if you want to utilize pre-defined formats for general summarization tasks and, optionally, provide a prompt to customize the output. This endpoint generates the following:

  • Summaries: The platform returns a brief that encapsulates the key points of a video, presenting the most important information clearly and concisely. Depending on your prompt, a summary can take various forms, such as a single paragraph, a series of paragraphs, an email, or a structured list of bullet points. For example, a summary highlighting Black Friday events might include a description of a crowded mall, key commentary by a news reporter on consumer behavior, and individual perspectives on societal values associated with consumption.
  • Chapters: The platform returns a chronological list of all the chapters in a video, providing a granular breakdown of its content. For each chapter, the platform returns its starting and end times, measured in seconds from the beginning of the video, a descriptive headline that offers a brief of the events or activities within that chapter, and an accompanying summary that elaborates on the headline. For example, the first chapter of a stand-up comedy might describe the comedian's entrance and the first joke. The accompanying summary could delve into the content, detailing the comedian's humorous take on a specific subject, such as the cultural nuances of Tai Chi exercises.
  • Highlights: The platform returns a chronologically ordered list of the most important events within a video. Unlike chapters, highlights only capture the key moments, providing a snapshot of the video's main topics. For each highlight, the platform returns its starting and end times, measured in seconds from the beginning of the video, and a brief that captures its essence. For example, a highlight might capture a significant event like a bank heist in a video with multiple scenes.

Below are some ways in which you can guide the platform to generate content tailored to your specific needs:

Content typePrompt example
Specify the target audienceGenerate a summary suitable for a high school audience studying environmental science.
Adjust the toneGenerate a light-hearted and humorous chapter breakdown of this documentary.
Indicate length constraintsProvide a summary fit for a Twitter post under 280 characters.
Customize text formatGenerate a summary in no more than 5 bullet points.
Specify the purposeSummarize this video from a marketer's perspective, focusing on brand mentions and product placements.

For a description of each field in the request and response, see the API Reference > Generate ummaries, chapters, or highlights section.

You can interact with the platform using one of the available SDKs or an HTTP client like requests or axios. This guide demonstrates how to use the SDKs, the recommended approach for most scenarios. If you need to make direct HTTP requests, refer to the API Reference > Generate ummaries, chapters, or highlights page for details.

Prerequisites

The examples in this guide assume the following:

  • You’re familiar with the concepts that are described on the Platform overview page.
  • You’ve already created an index and the Pegasus video understanding engine is enabled for this index.
  • You've uploaded a video, and the platform has finished indexing it.

Generate a summary

To generate a summary based on the content of a video, invoke the summarize method of the generate object with the following parameters:

  • video_id: A string representing the unique identifier of the video for which you want to generate a title.
  • type: A string representing the type of text you want to generate. This example uses summary.
from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
  video_id="<YOUR_VIDEO_ID>",
  type="summary"
)
print(f"Summary= {res.summary}")
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});

const summary = await client.generate.summarize('<YOUR_VIDEO_ID>', 'summary');
console.log(`Summary: ${summary.summary}`);

The output should look similar to the following one:

Summary: The video begins with a woman discussing her recent lifestyle changes,
including her graduation from college and moving back home. She decides to vlog
a summer day in her house in Minnesota, showing viewers where she grew up. She talks
about her love for sunbathing, applying her tanning oil, and enjoying the outdoor
environment. Afterward, she shares her outfit including her favorite tank from Hollister 
and fold-over pants.\n She journeys to the Mall of America, making a pit stop at Starbucks.
At the mall, she shops at her favorite stores, including Hollister, Aritzia, and Victoria's Secret.
She purchases various items including a dainty blue floral top, gray yoga pants, and new
bras and shares her shopping haul with the viewers. The woman enjoys a sandwich, revealing
her love for the food.\n There's a quick transition to her preparing dinner at home.
She decides to whip up a tomato pasta dish called panzanella, using her mother's recipe.
After letting it marinate for a bit, she samples the mix, recalling its deliciousness from
her memories. \n In the evening, she meets her best friend Rachel for an outdoor adventure.
They go pennyboarding, a favored activity of theirs, which they usually do in certain mall
parking lots. She continues her activities with her friend, expressing her frustrations
over her troublesome skateboard. The video concludes with the woman sharing her day.

Optionally, you can use the prompt parameter to provide context for the summarization task. The following example specifies the purpose and the desired length:

from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
  video_id="<YOUR_VIDEO_ID>",
  type="summary",
  prompt="Generate a summary of this video for a social media post, up to two sentences.")
print(f"Summary= {res.summary}")
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});

const summary = await client.generate.summarize(
  '<YOUR_VIDEO_ID>',
  'summary',
  'Generate a summary of this video for a social media post, up to two sentences.',
);
console.log(`Summary: ${summary.summary}`);

The output should look similar to the following one:

Summary: Two women share a day in their lives, discussing topics such as graduation, moving home, 
shopping hauls, cooking, and outdoor adventures. They showcase their favorite clothing items, 
prepare food, and go pennyboarding together.

Generate chapters

To generate a list of chapters based on the content of a video, invoke the summarize method of the generate object with the following parameters:

  • video_id: A string representing the unique identifier of the video for which you want to generate a title.
  • type: A string representing the type of text you want to generate. This example uses chapter.
from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
    video_id="<YOUR_VIDEO_ID>",
    type="chapter",
)
for chapter in res.chapters:
    print(
        f"""Chapter {chapter.chapter_number},
start={chapter.start},
end={chapter.end}
Title: {chapter.chapter_title}
Summary: {chapter.chapter_summary}
"""
    )
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});

const chapters = await client.generate.summarize('<YOUR_VIDEO_ID>', 'chapter');
for (const chapter of chapters.chapters) {
  console.log(
    `Chapter ${chapter.chapterNumber}\nstart=${chapter.start}\nend=${chapter.end}\nTitle=${chapter.chapterTitle}\nSummary=${chapter.chapterSummary}`,
  );
}

The output should look similar to the following one:

Chapter 0,
start=0,
end=90
Title: College graduation and temporary move back home
Summary: A woman discusses her recent college graduation and temporary move back home.

Chapter 1,
start=90,
end=210
Title: Enjoying a summer day in Minnesota
Summary: The woman vlogs about her summer day, sharing her experience while standing in her 
childhood home in Minnesota. She talks about her love for getting some sun and shows the camera 
around her house.

Chapter 2,
start=210,
end=300
Title: Shopping at the Mall of America
Summary: The woman explores the Mall of America, mentioning her favorite stores and sharing her 
shopping haul.

Chapter 3,
start=300,
end=360
Title: Sharing favorite clothing items
Summary: The woman showcases her favorite clothing items, discussing her new yoga pants and tops 
from Aritzia and Victoria's Secret.

Chapter 4,
start=360,
end=480
Title: Food preparation and outdoor activities
Summary: The woman demonstrates how to make a bread salad and later meets up with her friend Rachel 
to go pennyboarding at a parking garage.

The following example uses the prompt parameter to indicate that the tone of voice should be casual and conversational, matching the vlogging style of the video:

from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
    video_id="<YOUR_VIDEO_ID>",
    type="chapter",
    prompt="Generate chapters using casual and conversational language to match the vlogging style of the video."
)
for chapter in res.chapters:
    print(
        f"""Chapter {chapter.chapter_number},
start={chapter.start},
end={chapter.end}
Title: {chapter.chapter_title}
Summary: {chapter.chapter_summary}
"""
    )
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});

const chapters = await client.generate.summarize(
  '<YOUR_VIDEO_ID>',
  'chapter',
  'Generate chapters using casual and conversational language to match the vlogging style of the video.',
);
for (const chapter of chapters.chapters) {
  console.log(
    `Chapter ${chapter.chapterNumber}\nstart=${chapter.start}\nend=${chapter.end}\nTitle=${chapter.chapterTitle}\nSummary=${chapter.chapterSummary}`,
  );
}

Generate highlights

To generate a list of the important events or activities within a video, invoke the summarize method of the generate object with the following parameters:

  • video_id: A string representing the unique identifier of the video for which you want to generate a title.
  • type: A string representing the type of text you want to generate. This example uses highlight.
from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
    video_id="<YOUR_VIDEO_ID>",
    type="highlight"
)
for highlight in res.highlights:
    print(f"Highlight: {highlight.highlight}, start: {highlight.start}, end: {highlight.end}")
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});

const highlights = await client.generate.summarize('<YOUR_VIDEO_ID>', 'highlight');
for (const highlight of highlights.highlights) {
  console.log(`Highlight: ${highlight.highlight}, start: ${highlight.start}, end: ${highlight.end}`);
}

The output should be similar to the following one:

Highlight: A woman vlogs about her summer day, sharing her experience while standing in her 
childhood home in Minnesota., start: 30, end: 60
Highlight: The woman talks about the heat and her confusion regarding sweat and tanning oil. 
She also mentions her outfit, consisting of a tank top and fold-over pants., start: 150, end: 180
Highlight: A woman is making a video of her food preparation and tasting., start: 420, end: 450

The following example uses the prompt parameter to generate highlights for the same video, showcasing the most entertaining parts:

from twelvelabs import TwelveLabs

client = TwelveLabs(api_key="<YOUR_API_KEY>")

res = client.generate.summarize(
    video_id="<YOUR_VIDEO_ID>",
    type="highlight",
    prompt="Generate highlights that showcase the most entertaining parts of the video."
)
for highlight in res.highlights:
    print(f"Highlight: {highlight.highlight}, start: {highlight.start}, end: {highlight.end}")
import { TwelveLabs } from 'twelvelabs-js';

const client = new TwelveLabs({ apiKey: '<YOUR_API_KEY>'});  

const highlights = await client.generate.summarize(
  '<YOUR_VIDEO_ID>',
  'highlight',
  'Generate chapters using casual and conversational language to match the vlogging style of the video.',
);
for (const highlight of highlights.highlights) {
  console.log(`Highlight: ${highlight.highlight}, start: ${highlight.start}, end: ${highlight.end}`);
}

The output should look similar to the following one:

Highlight: The woman discovers a foul smell in her car while vlogging about her day., 
start: 120, end: 150
Highlight: The woman shares her experience of shopping in a mall and discusses a surprising 
incident that happened to her., start: 210, end: 240