NexusLearnAI / Project.md
ChaseHan's picture
Upload 15 files
833dac3 verified
# 教育LLM助手项目文档
## 项目概述
这是一个基于Gradio构建的教育类LLM应用,主要功能是将学习问题分解为相关概念并提供详细解释。
## 系统架构
### 主要组件
1. **前端界面** (app.py)
- 使用Gradio构建的Web界面
- 包含用户配置、问题输入、概念图谱展示和概念解释等模块
2. **LLM链** (llm_chain.py)
- 处理核心的AI交互逻辑
- 包含两个主要功能:概念分解和概念解释
3. **可视化模块** (visualization.py)
- 负责生成概念知识图谱
### 数据流程
```mermaid
graph LR
A[用户输入] --> B[问题分析]
B --> C[概念分解]
C --> D[知识图谱生成]
C --> E[概念卡片生成]
E --> F[概念选择]
F --> G[概念解释生成]
```
## Prompt系统
### 1. 概念分解 Prompt (prompts.py)
输入参数:
- question: 用户问题
- grade: 年级水平
- subject: 学科
- learning_needs: 学习需求
Prompt模板:
```python
def generate_decomposition_prompt(question, grade, subject, learning_needs):
return f"""
作为一名{subject}教育专家,请分析以下{grade}级学生的问题:
问题:{question}
学习需求:{learning_needs}
请将这个问题分解为相关的核心概念,并说明它们之间的关系。
"""
```
### 2. 概念解释 Prompt (prompts.py)
输入参数:
- concept_name: 概念名称
- concept_description: 概念描述
- grade: 年级水平
- subject: 学科
- learning_needs: 学习需求
Prompt模板:
```python
def generate_explanation_prompt(concept_name, concept_description, grade, subject, learning_needs):
return f"""
请为{grade}级{subject}学生解释以下概念:
概念:{concept_name}
描述:{concept_description}
学习需求:{learning_needs}
请提供:
1. 详细解释
2. 具体例子
3. 相关学习资源
4. 练习题
"""
```
## 处理流程
1. **用户输入阶段**
- 用户设置学习配置(年级、学科、学习需求)
- 输入学习问题
2. **概念分解阶段**
- 系统使用decomposition prompt分析问题
- 生成相关概念及其关系
- 创建概念知识图谱
- 生成概念卡片
3. **概念解释阶段**
- 用户选择特定概念
- 系统使用explanation prompt生成详细解释
- 提供例子、资源和练习题
4. **缓存机制**
- 使用AppState类管理状态
- 缓存已生成的概念解释
- 存储用户配置和当前概念数据
## 输出格式
1. **概念分解输出**
- 概念列表(名称、描述、难度)
- 概念间关系
- 可视化知识图谱
2. **概念解释输出**
- 详细解释文本
- 示例(包含难度分级)
- 学习资源链接
- 练习题(带答案)
## 注意事项
1. 所有输出都经过格式化,以适应不同年级水平
2. 系统支持多语言(通过用户界面配置)
3. 实现了错误处理和优雅的降级机制
4. 使用缓存来提高响应速度