惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

F
Full Disclosure
V
Vulnerabilities – Threatpost
Attack and Defense Labs
Attack and Defense Labs
N
News and Events Feed by Topic
SecWiki News
SecWiki News
S
Security @ Cisco Blogs
Schneier on Security
Schneier on Security
B
Blog
TaoSecurity Blog
TaoSecurity Blog
The Last Watchdog
The Last Watchdog
H
Hacker News: Front Page
Hacker News - Newest:
Hacker News - Newest: "LLM"
博客园_首页
D
Docker
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Y
Y Combinator Blog
W
WeLiveSecurity
N
News and Events Feed by Topic
F
Fortinet All Blogs
PCI Perspectives
PCI Perspectives
WordPress大学
WordPress大学
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Announcements
Recent Announcements
Forbes - Security
Forbes - Security
T
Tailwind CSS Blog
Hacker News: Ask HN
Hacker News: Ask HN
爱范儿
爱范儿
腾讯CDC
Last Week in AI
Last Week in AI
月光博客
月光博客
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
Help Net Security
Help Net Security
V
V2EX
C
Cyber Attacks, Cyber Crime and Cyber Security
C
CXSECURITY Database RSS Feed - CXSecurity.com
H
Heimdal Security Blog
L
LINUX DO - 最新话题
GbyAI
GbyAI
The Hacker News
The Hacker News
罗磊的独立博客
S
SegmentFault 最新的问题
H
Hackread – Cybersecurity News, Data Breaches, AI and More
博客园 - 【当耐特】
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
V2EX - 技术
V2EX - 技术
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
O
OpenAI News
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻

V2EX

我用 AI 写代码,但终端管理反而成了累赘——于是我做了 codux - V2EX [调研] 各位在公司都用什么 ide 和 agent 写代码? 老运维 share 一个运维平台 新电脑 brew install node 之后,一个小设置可以提升对供应链投毒的防御 - V2EX GLM-Coding 调用持续报错: z.ai 的 Lite 套餐几乎无法使用,官方 Pro/Max 是否稳定? - V2EX 上海漕河泾内推,本组有 2 个 hc,一个后端,一个前端,预算都是 20k 左右,不打卡,氛围好 如果 V2EX 上有一组不永久保存聊天记录(比如只保存 7 天或者 24 小时)的聊天室,那么会开启哪些有用或者有趣的可能? - V2EX gemini cli 貌似挂了,一直返回 403 - V2EX 第一次在自媒体上赚到钱 收集了最近在使用的低价 GPT, Gemini,邮箱等 AI 会员的小店合集 讨论个大实话:现在企业还在说 AI 编程提效 20%, 30%的,真的太落后,没用懂 AI。因为包括很多前沿公司,已经狂奔到提效 200%-500%的情况 [招聘][远程][币安] 前端/后端/QA/iOS/Android 至少 3 年以上经验 目前有大量 HC 欢迎投递 Chatgpt Pro 用量用不完的可以开这些设置 面试的时候好像遇到钓鱼了,给各位避个坑 cursor 年续费 22 号到期, 自动续费是否还是老的计次套餐呢 - V2EX 被两件破事毁掉的一下午,琐碎的内耗消磨人的精力 使用 Planet 存储 Codex 的会话或者重要信息 - V2EX 如果业务部门领导不要你开发功能,而是要求你教会它用 claude code 开发功能,你会怎么做? 分享一个 MacOS 接绿联 CM818 USB 转 DP 转接器使用感受 - V2EX 我的 HR 朋友 10 年老 Java ,非全大专,大家帮忙看看简历 开源了一个 AI 口语练习工具,音素级发音评分,完全免费可自部署 V2EX 上有哪些你觉得很有趣、印象深刻的妹纸? 字节为啥不出个国内版 Vercel? 有在大马的朋友吗? 问个运营商问题 你们在有领导的公司大群发过的最大胆的消息是什么 公司裁员,目前没有工作。想试试摆摊,做一个移动鲜啤打酒车 我的硬盘 Memblaze Pblaze 5 Linux 下不识别,给 Linux 内核提交了补丁, AI 说有望被合并 - V2EX 只有我一个人觉得 codex 不好用? 做了个 AI + 真人专家监督的广告投放平台 Auxora, 7 个品牌跑出 6x ROAS 如何走出至亲的离世 Claude Web 端貌似 claude-opus-4-7 偷偷上了? 现在 Apple 开发者帳號應該是用哪个地区会更好? - V2EX 用回测筛选因子的一点经验分享 给女儿 vibe 了一个故事类的 app,做完发现,这类应用似乎上线难度极大? - V2EX 手机格式化 bitget 钱包没了,里面开通的银行卡还有机会拿到吗 - V2EX [送码] TransVoice - 我的第一款 App 上架啦!实时转写+翻译+字幕,会议听课好助手! PictureHub 高清摄影作品的画廊 Planet 的第一个使用 macOS 26 SDK 构建的 Insider 版本 20260416-1 - V2EX 成都二手房是不是在涨价,有点坐不住了 - V2EX claude 生态(skill mcp plugin)等 Studio Display XDR VESA 适配器脱落 有在用印度区 applestore 的大哥嘛,请教一下礼品卡去哪里买呢 - V2EX 我好像知道京东家政爆火的原因了 - V2EX 薅了公司的 a 家 api key,用机场 ip 做代理容易被封吗 如何在初期就识别 HR 在刷 KPI,没打算招你? [分享]精心打造一个 AI 编程知识库(算法/设计模式/提示词/Skills),助力程序员转型 港版 iPhone 在国内支持联通 5GA 吗?在广东用 想办港卡 AI 对 it 行业影响太大了 我做了个把照片变成 iOS 小组件贴纸的 App ChatGPT Pro 5x 套餐 量真的很足! I have found a method to directly generate advertising video materials using scripts 在小城市开个店,给人写软件,有前途吗 chrome 最新的 147 版直接卡爆炸了 - V2EX 为什么厂家不在 skill/mcp 这类的工具中塞广告呢?这样不是可以大赚嘛? minimax 真是脸都不要了,工作日下午 14:00 定时开启 529,脸都不要了。训练模型居然占用用户使用时间 外资非核心部门 vs 另一家外资的核心部门,该跳吗? iTad 标签 扩展 加小动作 ? - V2EX 去年 H200 能买,不让买是代替快出来了? - V2EX AI 赛事通 - 2026 年 4 月中国区新增 AI 竞赛和黑客松汇总 - V2EX V2EX › 登录 现在安卓开发都在做啥 - V2EX 浏览器插件 沉浸式翻译 是不支持自定义模型了吗? - V2EX Codex 里的 GPT5.4 也能降智?上午让它改两个问题,改了一个小时了, plus 额度用了一半了还是没改好,和前几天用的体感完全不一样。要它改的问题也不复杂。服了。 目前有使用 claude code 的收到人脸认证的吗 - V2EX 分享一个自己做的 Nginx 管理工具,实时请求动态预览!(无奈市面上实在找不到好用的,自己撸了个) - V2EX claude code 崩了么? 今天在反重力上用 claude 一点都不丝滑,有同样的感受吗? opencode 消息周知插件 今天 claude opus 和前两天比,质的飞跃 - V2EX 999 包月价? - V2EX 一个版本, 50 项更新:我们几乎重做了整个播放页 本地大模型多大显存够用? GOGDNS 一款简易的私人 DNS 服务器 - V2EX API key (GLM) 怎么使用 claude code desktop ? Claude 这样订阅有问题吗 - V2EX 帮我爸找回了一篇赛博兰亭集序 求推荐稳定、高性价比使用 Claude Opus 4.6 的渠道/平台 搞个云端 claude code 防止 封号 - V2EX 用 Claude 要实名了,内地用户怎么办? OpenAI Plus 和 Team 都缩水了吗 海外 Android 手机有什么好用的国内第三方应用市场推荐吗 - V2EX 把电脑伪装成电视,用 DLNA 投屏拿到视频号直播流地址 - V2EX claude 认证莫慌 北京互联网法院有什么攻略么?起诉北京智谱华章科技股份有限公司退款可行么? - V2EX Claude 开始引入身份验证 求 vscode 做笔记软件的插件推荐 - V2EX 讯飞星辰的 Coding Plan 如何? Anthropic 宣布在 Claude 平台推行身份验证机制 科普一下低价 gpt 是怎么来的 有没有长期关注 Claude 的朋友,我建了一个 Channel 自动抓取 Claude Team 的推文 啃了那篇 54 页的 Agent Harness 综述, 给大伙讲个省流版 现在那家的 coding plan 还能买到 是不是最近会有什么更聪明的大模型要发布了呀? 用多了 AI 后,有没有觉得 AI 生成的文章有很强的既视感? 如何 实践 Harness 工程? 今日份 GPT 5.4 笑话 如何建一个自己的号池,让 cursor 真正实现 token 自由 写了三个月 Agent Harness,我终于敢让 Claude Code 全自动写代码了
ChatTutor - 一个基于 DSL 的可视化可交互 AI 教师
acbox · 2025-11-20 · via V2EX

原文标题“关于 ChatTutor ,我们做了什么”,发布在 ChatTutor 的文档上,请参考 https://docs.chattutor.app/blog/2025-11-20.html

Hi, 这里是 Acbox ,ChatTutor 的作者,以下是我的各种平台账号,可以通过这些账号获得最新的动态

最近,我开源了我的项目 ChatTutor, 在 15 天内获得了 600+ stars (截止写稿日已有 641 个 stars ),并在开源圈和 AI 圈收获了一些热度。这篇博客我将会系统性的介绍 ChatTutor ,包括

  1. 什么是 ChatTutor, 他和一些传统的 ChatBot 有什么不同,他和类似 VideoTutor, Code2Video 之类的产品又有什么不同
  2. 关于 Multi-Agent - Teacher 与 Painter
  3. 关于 DSL - 绘图引擎如何驱动? Agent 如何用响应式变量与用户交互?

什么是 ChatTutor

ChatTutor 是一个可以使用白板的老师 Agent ,通过工具调用的形式将数学图形,笔记注释,思维导图绘制在像是幻灯片一样的多页白板上

demo

我们希望模仿真实的老师上课时的样子,通过画图->讲解->距离,来让学生逐步掌握知识。期间,学生可以打断,并向老师提出问题,老师可以对上一步的白班作出修改或新建页面来解释学生的疑问

他和 VideoTutor, Code2Video 这类产品有什么不同

这类产品有一个共同点:都是基于 Manim 进行渲染的。Manim 是 Youtube 博主@3blue1brown基于 Python 开发的一个数学动画引擎,通过 Python 代码来生成一个精美的科普视频。

VideoTutor 和 Code2Video 通过复杂的工作流,让 LLM 去生成 Python 代码,并最终渲染成视频。

ChatTutor 实现了一个 DSL 语法,大量模仿了现代前端框架的设计,并实现了一些组件库,关于 DSL, 请参考[这个小节](#关于 dsl---响应式)

VideoTutor 和 Code2Video 的最终产物都是视频,用户无法与其交互,也无法基于视频里的图形做二次修改。ChatTutor 所渲染的图形都是可交互的,且全部渲染在前端,不需要考虑视频编译的时间,且可以通过与用户的交互产生反应。

Multi-Agent: Teacher 模型与 Painter 模型

我们使用了 Multi-Agent 架构来拆分他们的任务,其中:

  • Teacher: 用户所在右侧看到的输出
  • Painter: 负责绘图的 LLM, 可以输出 DSL 语法

Teacher 可以通过工具调用的形式输入自然语言,并通过 Painter 输出 DSL 语法

graph TB
  T{Teacher Agent} ---> P{Painter Agent}
  T ---> M(Mermaid)
  T ---> N(Note)
  T ---> C(Code)

目前的 Painter 使用提示词方案,未来有考虑模型训练,也考虑单独把 Painter 拆成一个 api 服务,让别的应用可以使用 Painter 并将图形渲染到自己的网页

关于 DSL - 响应式

我们使用了@vue/reactivity作为 DSL 的响应式基础,并且大量模仿了现代前端框架的设计

我们同时也写了很多数学组件和动画,未来将会增加物理,电路,化学等学科的图形支持

就比如,三角形 ABC ,Painter 输出的 DSL Document 看起来会像是这样的:

Teacher 给 Painter 的提示词:Draw a simple triangle, A = (0, 0), B = (3, 4), C = (1, 2)

---
refs:
  x_A: '0'
---
<plane :range="[-1, 5]" :domain="[-1, 4]">
  <polygon type="line" :points="[[x_A, 0], [3, 4], [1, 2], [x_A, 0]]" color="primary"/>
  
  <dot :x="x_A" :y="0" color="primary" label="A" />
  <dot :x="3" :y="4" color="primary" label="B" />
  <dot :x="1" :y="2" color="primary" label="C" />
</plane>

文档包含一个 yaml 头,有一个 refs 的定义,即响应式变量,这个 x_A 最终会被渲染在前端并暴露给用户。用户和 Teacher 都可以操作这个变量。当 x_A 被更新时,A 点的坐标也会被改变

同时,Painter 支持一个键-值类型的参数,可以手动指定 <变量名>-<变量描述>,然后 Painter 就会把你指定的变量名暴露出来

我们来看一个更具体的例子:

Input:

Draw a unit circle (radius 1) centered at the origin. Draw the x and y axes with labels.
Draw a radius from the origin making an angle theta with the positive x-axis, where theta is a reactive variable starting at π/4. At the end of this radius, mark a point P. From point P, draw a vertical line down to the x-axis to form a right triangle.
Label the horizontal distance as cos(theta) and the vertical distance as sin(theta).
Draw and label the angle theta at the origin. Also show the coordinates of point P as (cos θ, sin θ).
Use different colors: circle in gray, radius in blue, the right triangle sides in green, and point P in red.`

Exposes: {"theta": "角度 theta (弧度)"}

---
refs:
  theta: 'Math.PI / 4'
---
<plane :range="[-1.5, 1.5]" :domain="[-1.5, 1.5]" axis grid>
  <!-- Unit circle in gray -->
  <parameter 
    :value="(t) => [Math.cos(t), Math.sin(t)]" 
    :domain="[0, 2 * Math.PI]" 
    color="gray"
  />
  
  <!-- Point P at (cos(theta), sin(theta)) in red -->
  <dot 
    :x="Math.cos(theta)" 
    :y="Math.sin(theta)" 
    color="red" 
    label="P"
    labelColor="red"
  />
  
  <!-- Radius from origin to P in blue -->
  <line 
    :from="[0, 0]" 
    :to="[Math.cos(theta), Math.sin(theta)]" 
    color="blue"
  />
  
  <!-- Vertical line from P down to x-axis (green) -->
  <line 
    :from="[Math.cos(theta), Math.sin(theta)]" 
    :to="[Math.cos(theta), 0]" 
    color="green"
  />
  
  <!-- Horizontal line from origin to projection point (green) -->
  <line 
    :from="[0, 0]" 
    :to="[Math.cos(theta), 0]" 
    color="green"
  />
  
  <!-- Angle theta at origin -->
  <angle 
    :start="[1, 0]" 
    :end="[Math.cos(theta), Math.sin(theta)]" 
    :origin="[0, 0]" 
    color="blue"
    label="θ"
  />
  
  <!-- Label for cos(theta) on x-axis -->
  <label 
    :x="Math.cos(theta) / 2" 
    :y="-0.15" 
    content="\cos(\theta)" 
    color="green"
  />
  
  <!-- Label for sin(theta) on y-axis -->
  <label 
    :x="Math.cos(theta) + 0.2" 
    :y="Math.sin(theta) / 2" 
    content="\sin(\theta)" 
    color="green"
  />
  
  <!-- Coordinates of point P -->
  <label 
    :x="Math.cos(theta) + 0.3" 
    :y="Math.sin(theta) + 0.2" 
    content="(\cos\theta, \sin\theta)" 
    color="red"
  />
</plane>

demo

当 Teacher 让 Painter 做完这一切后,如图,Teacher 调用其他工具创建了一个滑动条,当用户改变滑动条的值时,角度就会改变

我们正在计划准备给 Teacher 更多工具允许他自己操控这些组件

结尾

这就是这个博客的全部内容了,希望大家如果感兴趣可以来体验一下,并在 GitHub 上点一个 Star

GitHub: https://github.com/sheepbox8646/ChatTutor 在线体验(需要填写 apikey ):https://chattutor.app