当前位置: 首页 > news >正文

LangSmith 模型评估 (Evaluation) 完整指南

本文档将手把手教你如何使用LangSmith对 LLM(如 Gemini, DeepSeek, GPT)进行自动化评估和对比。


1. 注册与准备

1.1 注册账号

  1. 访问 LangSmith 官网。此处需要魔法
  2. 使用 GitHub 或 Google 账号登录。
  3. 注意:LangSmith 分为US (美国)EU (欧洲)两个数据中心。注册时请留意你所在的区域(或者由系统自动分配)。

1.2 获取 API Key

  1. 登录后,点击左下角的Settings (设置)图标。
  2. 选择API Keys选项卡。
  3. 点击Create API Key
  4. 给 Key 起个名字(如 “Test Key”),然后复制保存(只显示一次)。

    在上图这里选 Run an Evaluation


点击这里Generate API key 就会获得一个key

1.3 确认 Endpoint (关键步骤!)

如果你的账号被分配到了EU (欧洲)节点(URL 是eu.smith.langchain.com),你必须显式配置 Endpoint,否则会报403 Forbidden

  • US 节点(默认):https://api.smith.langchain.com
  • EU 节点https://eu.api.smith.langchain.com

设置环境变量:

ANGCHAIN_ENDPOINT="https://eu.api.smith.langchain.com"LANGCHAIN_API_KEY="lsvxxxxxxxxxxxxxxxxxxxx"

2. 环境配置

2.1 安装依赖

你需要安装langsmithlangchain相关库。

pipinstalllangsmith langchain langchain-openai

2.2 配置环境变量 (.env)

在项目根目录创建.env文件,填入以下内容:

# 开启 Tracing (可选,但推荐) LANGCHAIN_TRACING_V2=true # 你的 API Key LANGCHAIN_API_KEY="ls__your_api_key_here" # 如果你是 EU 账号,必须加这一行!US 账号可忽略 LANGCHAIN_ENDPOINT="https://eu.api.smith.langchain.com" # 你的模型 Key (用于调用模型) GEMINI_API_KEY="AIza..." DEEPSEEK_API_KEY="sk-..."

3. 实战代码:模型对比评估

我们将编写一个脚本,对比GeminiDeepSeek在回答同一组问题时的表现。

完整代码 (compare_model.py)

importosfromlangsmithimportClient,evaluatefromsrc.llm.gemini_chat_modelimportget_gemini_llmfromsrc.llm.deepseek_chat_modelimportget_deepseek_llm# ================= 1. 初始化客户端 =================client=Client()# ================= 2. 准备数据集 (Dataset) =================# 数据集名称dataset_name="AI_Interview_Questions"# 检查数据集是否存在,不存在则创建ifnotclient.has_dataset(dataset_name=dataset_name):print(f"创建新数据集:{dataset_name}")dataset=client.create_dataset(dataset_name=dataset_name,description="用于测试模型的基础问答能力")# 写入测试用例 (Inputs)# 可以在这里添加标准答案 (Outputs) 用于自动打分,这里仅做生成测试client.create_examples(inputs=[{"prompt":"什么是 RAG (Retrieval-Augmented Generation)?"},{"prompt":"用 Python 写一个快排算法。"},{"prompt":"解释量子纠缠,像我只有5岁一样。"},],dataset_id=dataset.id,)else:print(f"使用现有数据集:{dataset_name}")# ================= 3. 准备模型 (Target Functions) =================# 初始化 LangChain 模型对象gemini=get_gemini_llm()deepseek=get_deepseek_llm()# 定义包装函数# LangSmith 会把数据集里的 inputs (如 {"prompt": "..."}) 传给这个函数defpredict_gemini(inputs:dict):# 调用模型response=gemini.invoke(inputs["prompt"])# 返回结果,key 可以是 "output" 或 "answer"return{"output":response.content}defpredict_deepseek(inputs:dict):response=deepseek.invoke(inputs["prompt"])return{"output":response.content}# ================= 4. 运行评估 (Run Evaluation) =================print("开始评估 Gemini...")evaluate(predict_gemini,data=dataset_name,experiment_prefix="gemini-v1",# 实验名称前缀description="Gemini Pro 基础测试")print("开始评估 DeepSeek...")evaluate(predict_deepseek,data=dataset_name,experiment_prefix="deepseek-v1",description="DeepSeek Chat 基础测试")

4. 代码深度解析

Step 1:client.create_dataset

  • 作用:在云端创建一个持久化的数据集。
  • 特性:数据集只需创建一次。之后你可以反复使用它来测试不同的模型,或者测试同一个模型的不同版本(Prompt 迭代)。
    当dataset 创建后, 可以从langsmith也页面见到该dataset

Step 2:client.create_examples

  • Inputs:模型的输入(Prompt)。
  • Outputs (可选):标准答案(Ground Truth)。如果提供了 Output,你可以使用“正确性评估器”来自动判断模型回答得对不对。

Step 3:predict_wrapper(包装函数)

  • evaluate函数需要一个可调用的对象(函数)。
  • 这个函数接收inputs字典,必须返回一个字典(通常包含output)。
  • 你可以在这里进行 Prompt 组装、解析 JSON 等预处理/后处理逻辑。

Step 4:evaluate(核心)

这是 LangSmith 的魔法所在。它会:

  1. 拉取数据集中的每一条例子。
  2. 并发调用你的predict函数。
  3. 将 Input, Output, Latency (耗时), Token Usage 等信息全部上传到云端。
  4. 生成一个唯一的Experiment (实验)链接。

5. 查看结果

  1. 运行脚本后,控制台会输出一个 URL。
  2. 点击进入 LangSmith 网页。
  3. 你可以看到一个对比视图
    • 每一行是一个测试用例(Prompt)。
    • 每一列是一个实验(Gemini vs DeepSeek)。
  4. 你可以直观地看到:
    • 哪个模型回答得更准确?
    • 哪个模型速度更快(Latency)?
    • 哪个模型更啰嗦?

通过这种方式,原本凭感觉的“模型好坏”,变成了可视化、可量化的数据。

http://www.rkmt.cn/news/132720.html

相关文章:

  • 如何更好地作为数据科学家进行沟通
  • 3.1
  • 数字化项目管理系统分享:7款助力企业实现项目智能化协同的工具精选
  • 142_尚硅谷_数组的使用价值
  • 配置Wireshark抓取https数据包
  • 3.4
  • C#应用程序取得当前目录和退出
  • 基于Spring Boot的美食信息分享平台设计与实现毕设源码
  • 多项目管理系统怎么选:8款支持跨项目资源与进度统筹的解决方案
  • 【文章记录-001】
  • 搜索与过滤功能-Cordova 与 OpenHarmony 混合开发实战
  • 2025年主流项目集管理系统工具推荐:6款助力企业实现战略级项目群管控的系统盘点
  • 财务目标页面 UI 与进度展示 - Cordova与OpenHarmony混合开发实战
  • 主次设备号
  • Cordova与OpenHarmony全文搜索功能
  • FFT:嵌入式开发的“算力引擎”,支持Q15定点和F32浮点两种算法
  • 第七届传智杯 初赛 小红的四子棋 题解 简单bfs遍历
  • 对 Promise.race 的理解
  • 用Kotlin 的图像验证码识别系统设计与实现
  • 调用api练习(1)
  • 【计算机毕业设计案例】基于Spring Boot+Vue人力资源管理系统的设计与实现基于springboot的人力资源管理系统的设计与实现(程序+文档+讲解+定制)
  • 改善深层神经网络 第一周:深度学习的实践(一)偏差与方差
  • Harbor镜像仓库的搭建和迁移
  • 研究生必备7款免费AI论文神器:一键极速生成超长篇幅论文
  • Django 中创建用户与修改密码
  • 【课程设计/毕业设计】基于springboot的人力资源管理系统的设计与实现员工个人信息修改、请假、员工 的薪资管理、考勤管理、社保管理【附源码、数据库、万字文档】
  • 1分钟对接500个大模型?这才叫 AI 开发!
  • Docker的安装和使用
  • 8个降AI率工具,MBA高效写作必备
  • 【毕业设计】基于springboot的人力资源管理系统的设计与实现(源码+文档+远程调试,全bao定制等)