> ## Documentation Index
> Fetch the complete documentation index at: https://wb-21fd5541-sdk-testing-latest.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# 퀵스타트: LLM 입력 및 출력 추적

> LLM 애플리케이션에 트레이싱을 추가해 모델 상호작용을 디버그하고 모니터링하며 W&B Weave를 시작해 보세요.

export const GitHubLink = ({url}) => <a href={url} target="_blank" rel="noopener noreferrer" className="github-source-link">
    <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
      <path d="M12 0C5.37 0 0 5.37 0 12c0 5.31 3.435 9.795 8.205 11.385.6.105.825-.255.825-.57 0-.285-.015-1.23-.015-2.235-3.015.555-3.795-.735-4.035-1.41-.135-.345-.72-1.41-1.23-1.695-.42-.225-1.02-.78-.015-.795.945-.015 1.62.87 1.845 1.23 1.08 1.815 2.805 1.305 3.495.99.105-.78.42-1.305.765-1.605-2.67-.3-5.46-1.335-5.46-5.925 0-1.305.465-2.385 1.23-3.225-.12-.3-.54-1.53.12-3.18 0 0 1.005-.315 3.3 1.23.96-.27 1.98-.405 3-.405s2.04.135 3 .405c2.295-1.56 3.3-1.23 3.3-1.23.66 1.65.24 2.88.12 3.18.765.84 1.23 1.905 1.23 3.225 0 4.605-2.805 5.625-5.475 5.925.435.375.81 1.095.81 2.22 0 1.605-.015 2.895-.015 3.3 0 .315.225.69.825.57A12.02 12.02 0 0024 12c0-6.63-5.37-12-12-12z" />
    </svg>
    GitHub 소스 코드
  </a>;

export const ColabLink = ({url}) => <a href={url} target="_blank" rel="noopener noreferrer" className="colab-link">
    <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
      <path d="M14.25.18l.9.2.73.26.59.3.45.32.34.34.25.34.16.33.1.3.04.26.02.2-.01.13V8.5l-.05.63-.13.55-.21.46-.26.38-.3.31-.33.25-.35.19-.35.14-.33.1-.3.07-.26.04-.21.02H8.77l-.69.05-.59.14-.5.22-.41.27-.33.32-.27.35-.2.36-.15.37-.1.35-.07.32-.04.27-.02.21v3.06H3.17l-.21-.03-.28-.07-.32-.12-.35-.18-.36-.26-.36-.36-.35-.46-.32-.59-.28-.73-.21-.88-.14-1.05-.05-1.23.06-1.22.16-1.04.24-.87.32-.71.36-.57.4-.44.42-.33.42-.24.4-.16.36-.1.32-.05.24-.01h.16l.06.01h8.16v-.83H6.18l-.01-2.75-.02-.37.05-.34.11-.31.17-.28.25-.26.31-.23.38-.2.44-.18.51-.15.58-.12.64-.1.71-.06.77-.04.84-.02 1.27.05zm-6.3 1.98l-.23.33-.08.41.08.41.23.34.33.22.41.09.41-.09.33-.22.23-.34.08-.41-.08-.41-.23-.33-.33-.22-.41-.09-.41.09zm13.09 3.95l.28.06.32.12.35.18.36.27.36.35.35.47.32.59.28.73.21.88.14 1.04.05 1.23-.06 1.23-.16 1.04-.24.86-.32.71-.36.57-.4.45-.42.33-.42.24-.4.16-.36.09-.32.05-.24.02-.16-.01h-8.22v.82h5.84l.01 2.76.02.36-.05.34-.11.31-.17.29-.25.25-.31.24-.38.2-.44.17-.51.15-.58.13-.64.09-.71.07-.77.04-.84.01-1.27-.04-1.07-.14-.9-.2-.73-.25-.59-.3-.45-.33-.34-.34-.25-.34-.16-.33-.1-.3-.04-.25-.02-.2.01-.13v-5.34l.05-.64.13-.54.21-.46.26-.38.3-.32.33-.24.35-.2.35-.14.33-.1.3-.06.26-.04.21-.02.13-.01h5.84l.69-.05.59-.14.5-.21.41-.28.33-.32.27-.35.2-.36.15-.36.1-.35.07-.32.04-.28.02-.21V6.07h2.09l.14.01.21.03zm-6.47 14.25l-.23.33-.08.41.08.41.23.33.33.23.41.08.41-.08.33-.23.23-.33.08-.41-.08-.41-.23-.33-.33-.23-.41-.08-.41.08z" />
    </svg>
    Colab에서 사용해 보기
  </a>;

<div style={{ display: 'flex', gap: '12px', flexWrap: 'wrap' }}>
  <ColabLink url="https://colab.research.google.com/github/wandb/docs/blob/main/weave/cookbooks/source/traces-quickstart.ipynb" />

  <GitHubLink url="https://github.com/wandb/docs/blob/main/weave/cookbooks/source/traces-quickstart.ipynb" />
</div>

코드에 트레이싱을 추가해 Weave로 LLM call을 추적하는 방법을 알아보세요. 이 퀵스타트에서는 OpenAI로 보내는 요청을 트레이스하고 Weave UI에서 결과를 확인하는 방법을 안내합니다. Weave를 처음 사용하는 개발자가 디버깅과 모니터링을 위해 LLM 애플리케이션을 계측하려는 경우에 적합합니다.

<div id="what-youll-learn">
  ## 배울 내용
</div>

이 가이드에서는 다음 방법을 설명합니다:

* 코드에 Weave를 임포트하고 설정하기.
* `weave.op` 데코레이터를 사용해 코드를 추적하기.
* Weave UI에서 트레이스 보기.

<div id="prerequisites">
  ## 사전 요구 사항
</div>

* [W\&B 계정](https://wandb.ai/signup)
* Python 3.10+ 또는 Node.js 18+
* 필수 패키지가 설치되어 있어야 합니다:
  * **Python**: `pip install weave openai`
  * **TypeScript**: `npm install weave openai`
* [OpenAI API 키](https://platform.openai.com/api-keys)를 환경 변수로 설정해야 합니다.

<div id="log-a-trace-to-a-new-project">
  ## 새 프로젝트에 트레이스 로깅하기
</div>

이 섹션에서는 Weave가 입력, 출력, 코드를 기록할 수 있도록 작은 애플리케이션에 계측을 추가합니다. 코드 추적을 시작하고 Weave에 트레이스를 로깅하려면 다음 단계를 수행하세요.

1. 코드에 `weave` 라이브러리를 임포트합니다.
2. 코드에서 `weave.init('your_wb_team/project_name')`를 호출하여 추적 정보를 W\&B [팀](/ko/platform/app/settings-page/teams) 및 [프로젝트](/ko/platform/hosting/iam/org_team_struct#project)로 전송합니다. 팀을 설정하지 않으면 Weave는 트레이스를 [기본 팀](/ko/platform/app/settings-page/user-settings/#default-team)으로 전송합니다. 지정한 프로젝트가 팀에 없으면 Weave가 해당 프로젝트를 생성합니다.
3. 추적하려는 함수에 [`@weave.op()` 데코레이터](/ko/weave/guides/tracking/ops)를 추가합니다. Weave는 지원되는 LLM Call을 자동으로 추적하지만, 이 데코레이터를 사용하면 특정 함수의 입력, 출력, 코드도 추적할 수 있습니다. TypeScript에서는 `weave.op(your_function)` 구문을 사용합니다.

다음 예시 코드는 OpenAI에 요청을 보내며([OpenAI API 키](https://platform.openai.com/docs/quickstart) 필요), Weave가 요청의 트레이싱 정보를 기록합니다. 이 요청은 입력에서 공룡 이름을 추출하고 각 공룡의 식성(초식 또는 육식)을 파악하도록 OpenAI 모델에 요청합니다.

다음 예시 코드는 Weave로 첫 번째 프로젝트를 추적합니다.

<Tabs>
  <Tab title="Python">
    ```python lines {1-2,7-8,27-28} theme={null}
    # Weave 라이브러리를 임포트합니다
    import weave
    from openai import OpenAI

    client = OpenAI()

    # Weave가 이 함수의 입력, 출력 및 코드를 자동으로 추적합니다
    @weave.op()
    def extract_dinos(sentence: str) -> dict:
        response = client.chat.completions.create(
            model="gpt-4o",
            messages=[
                {
                    "role": "system",
                    "content": """In JSON format extract a list of `dinosaurs`, with their `name`,
    their `common_name`, and whether its `diet` is a herbivore or carnivore"""
                },
                {
                    "role": "user",
                    "content": sentence
                }
                ],
                response_format={ "type": "json_object" }
            )
        return response.choices[0].message.content

    # Weave를 초기화하고, 데이터를 로깅할 팀과 프로젝트를 설정합니다
    weave.init('your-team/traces-quickstart')

    sentence = """I watched as a Tyrannosaurus rex (T. rex) chased after a Triceratops (Trike), \
    both carnivore and herbivore locked in an ancient dance. Meanwhile, a gentle giant \
    Brachiosaurus (Brachi) calmly munched on treetops, blissfully unaware of the chaos below."""

    result = extract_dinos(sentence)
    print(result)
    ```
  </Tab>

  <Tab title="TypeScript">
    ```typescript twoslash lines {1-2,7-8,20,24-25} theme={null}
    // @noErrors
    // Weave 라이브러리를 임포트합니다
    import * as weave from 'weave';
    import OpenAI from 'openai';

    const openai = new OpenAI();

    // Weave가 이 함수의 입력, 출력 및 코드를 자동으로 추적합니다  
    async function extractDinos(input: string) {
      const response = await openai.chat.completions.create({
        model: 'gpt-4o',
        messages: [
          {
            role: 'user',
            content: `In JSON format extract a list of 'dinosaurs', with their 'name', their 'common_name', and whether its 'diet' is a herbivore or carnivore: ${input}`,
          },
        ],
      });
      return response.choices[0].message.content;
    }
    const extractDinosOp = weave.op(extractDinos);

    async function main() {

      // Weave를 초기화하고, 데이터를 로깅할 팀과 프로젝트를 설정합니다
      await weave.init('your-team/traces-quickstart');

      const result = await extractDinosOp(
        'I watched as a Tyrannosaurus rex (T. rex) chased after a Triceratops (Trike), both carnivore and herbivore locked in an ancient dance. Meanwhile, a gentle giant Brachiosaurus (Brachi) calmly munched on treetops, blissfully unaware of the chaos below.'
      );
      console.log(result);
    }

    main();

    ```
  </Tab>
</Tabs>

`extract_dinos` 함수를 호출하면 Weave가 터미널에 트레이스를 확인할 수 있는 링크를 출력합니다. 출력은 다음과 같습니다.

```text theme={null}
weave:  $ pip install weave --upgrade
weave: Logged in as Weights & Biases user: example-username.
weave: View Weave data at https://wandb.ai/your-team/traces-quickstart/weave
weave: 🍩 https://wandb.ai/your-team/traces-quickstart/r/call/019ae171-7f32-7c96-8b42-931a32f900b7
{
  "dinosaurs": [
    {
      "name": "Tyrannosaurus rex",
      "common_name": "T. rex",
      "diet": "carnivore"
    },
    {
      "name": "Triceratops",
      "common_name": "Trike",
      "diet": "herbivore"
    },
    {
      "name": "Brachiosaurus",
      "common_name": "Brachi",
      "diet": "herbivore"
    }
  ]
}
```

<div id="see-traces-of-your-application-in-your-project">
  ## 프로젝트에서 애플리케이션 트레이스 확인하기
</div>

이제 코드가 트레이스를 생성했으므로 Weave UI에서 이를 살펴볼 수 있습니다. 터미널의 링크를 클릭하거나 브라우저에 붙여넣어 Weave UI를 여세요. Weave UI의 **Traces** 패널에서 트레이스를 클릭해 입력, 출력, 지연 시간, token 사용량 등의 데이터를 확인하세요.

<img src="https://mintcdn.com/wb-21fd5541-sdk-testing-latest/BwrnEjaj-2zjRpjo/images/tutorial_trace_1.png?fit=max&auto=format&n=BwrnEjaj-2zjRpjo&q=85&s=3498f59fe46219cb7e1b6df999d98d5b" alt="extract_dinos 함수의 트레이스를 보여주는 Weave UI의 Traces 패널로, 입력, 출력, 지연 시간, token 사용량이 포함되어 있습니다." width="1614" height="1342" data-path="images/tutorial_trace_1.png" />

이제 첫 번째 Weave 트레이스를 로깅하고 확인했습니다.

<div id="learn-more-about-traces">
  ## 트레이스에 대해 더 알아보기
</div>

* [함수에 데코레이터를 적용하고 call 정보를 조회하는 방법](/ko/weave/guides/tracking/tracing)을 알아보세요.
* [플레이그라운드](/ko/weave/guides/tools/playground)를 사용해 로깅된 트레이스에서 다양한 모델을 테스트해 보세요.
* [인테그레이션을 살펴보세요](/ko/weave/guides/integrations/). Weave는 OpenAI, Anthropic 등 다양한 LLM 라이브러리에 대한 call을 자동으로 추적합니다. 현재 사용 중인 LLM 라이브러리가 Weave 인테그레이션 중 하나가 아니더라도, `@weave.op()`로 감싸면 다른 LLM 라이브러리나 프레임워크에 대한 call도 추적할 수 있습니다.

<div id="next-steps">
  ## 다음 단계
</div>

[앱 평가 시작하기](/ko/weave/tutorial-eval)를 먼저 살펴본 다음, [RAG 애플리케이션 평가 방법](/ko/weave/tutorial-rag)을 확인하세요.
