> ## Documentation Index
> Fetch the complete documentation index at: https://docs.trychroma.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Building with AI

> Use LLMs to process unstructured data in your applications.

AI is a new type of programming primitive. Large language models (LLMs) let us write software which can process **unstructured** information in a **common sense** way.

Consider the task of writing a program to extract a list of people's names from the following paragraph:

> Now the other princes of the Achaeans slept soundly the whole night through, but Agamemnon son of Atreus was troubled, so that he could get no rest. As when fair Hera's lord flashes his lightning in token of great rain or hail or snow when the snow-flakes whiten the ground, or again as a sign that he will open the wide jaws of hungry war, even so did Agamemnon heave many a heavy sigh, for his soul trembled within him. When he looked upon the plain of Troy he marveled at the many watchfires burning in front of Ilion... - The Iliad, Scroll 10

Extracting names is easy for humans, but is very difficult using only traditional programming. Writing a general program to extract names from any paragraph is harder still.

However, with an LLM the task becomes almost trivial. We can simply provide the following input to an LLM:

> List the names of people in the following paragraph, separated by commas: Now the other princes of the Achaeans slept soundly the whole night through, but Agamemnon son of Atreus was troubled, so that he could get no rest. As when fair Hera's lord flashes his lightning in token of great rain or hail or snow when the snow-flakes whiten the ground, or again as a sign that he will open the wide jaws of hungry war, even so did Agamemnon heave many a heavy sigh, for his soul trembled within him. When he looked upon the plain of Troy he marveled at the many watchfires burning in front of Ilion... - The Iliad, Scroll 10

The output would correctly be:

> Agamemnon, Atreus, Hera

Integrating LLMs into software applications is as simple as calling an API. While the specifics of the API may vary between LLMs, most have converged on some common patterns:

* Calls to the API typically consist of parameters including a `model` identifier, and a list of `messages`.
* Each `message` has a `role` and `content`.
* The `system` role can be thought of as the *instructions* to the model.
* The `user` role can be thought of as the *data* to process.

For example, we can use AI to write a general purpose function that extracts names from input text.

<Tabs>
  <Tab title="OpenAI">
    <CodeGroup>
      ```python Python theme={null}
      import json
      import os
      import openai

      openai.api_key = os.getenv("OPENAI_API_KEY")

      def extract_names(text: str) -> list[str]:
          system_prompt = "You are a name extractor. The user will give you text, and you must return a JSON array of names mentioned in the text. Do not include any explanation or formatting."

          response = openai.ChatCompletion.create(
              model="gpt-4o",
              messages=[
                  {"role": "system", "content": system_prompt},
                  {"role": "user", "content": text}
              ]
          )

          response = response.choices[0].message["content"]
          return json.loads(response)
      ```

      ```typescript TypeScript theme={null}
      import { OpenAI } from "openai";

      const openai = new OpenAI({
        apiKey: process.env.OPENAI_API_KEY,
      });

      export async function extractNames(text: string): Promise<string[]> {
        const systemPrompt =
          "You are a name extractor. The user will give you text, and you must return a JSON array of names mentioned in the text. Do not include any explanation or formatting.";

        const chatCompletion = await openai.chat.completions.create({
          model: "gpt-4o",
          messages: [
            { role: "system", content: systemPrompt },
            { role: "user", content: text },
          ],
        });

        const responseText = chatCompletion.choices[0].message?.content ?? "[]";
        return JSON.parse(responseText);
      }
      ```
    </CodeGroup>
  </Tab>

  <Tab title="Anthropic">
    <CodeGroup>
      ```python Python theme={null}
      import json
      import os
      import anthropic

      client = anthropic.Anthropic(
          api_key=os.getenv("ANTHROPIC_API_KEY")
      )

      def extract_names(text: str) -> list[str]:
          system_prompt = "You are a name extractor. The user will give you text, and you must return a JSON array of names mentioned in the text. Do not include any explanation or formatting."

          response = client.messages.create(
              model="claude-sonnet-4-20250514",
              max_tokens=1000,
              system=system_prompt,
              messages=[
                  {"role": "user", "content": text}
              ]
          )

          response_text = response.content[0].text
          return json.loads(response_text)
      ```

      ```typescript TypeScript theme={null}
      import Anthropic from "@anthropic-ai/sdk";

      const anthropic = new Anthropic({
        apiKey: process.env.ANTHROPIC_API_KEY,
      });

      export async function extractNames(text: string): Promise<string[]> {
        const systemPrompt =
          "You are a name extractor. The user will give you text, and you must return a JSON array of names mentioned in the text. Do not include any explanation or formatting.";

        const message = await anthropic.messages.create({
          model: "claude-sonnet-4-20250514",
          max_tokens: 1000,
          system: systemPrompt,
          messages: [{ role: "user", content: text }],
        });

        const responseText =
          message.content[0]?.type === "text" ? message.content[0].text : "[]";
        return JSON.parse(responseText);
      }
      ```
    </CodeGroup>
  </Tab>
</Tabs>

Building with AI allows new type of work to be done by software. LLMs are capable of understanding abstract ideas and take action. Given access to retrieval systems and tools, LLMs can operate on tasks autonomously in ways that wasn't possible with classical software.
