

# 把医生和病人之间的对话，总结为描述
prompt_summary = """你负责根据下面<对话>内容，将医生和患者之间的对话，转化为一段陈述式的病历记录

# 要求
- **内容完整**：确保总结涵盖对话中所有关键信息，可能包括问诊内容、体格检查结果和辅助检查结果；不要添加任何对话中未提及的信息
- **格式要求**：将总结内容放置在<answer>标签内，不要有注释、标题或其他说明内容；不要分段

# 输出示例1
<answer>
患者有吸烟史但已戒除，无饮酒及吸毒史。
</answer>

# 输出示例2
<answer>
视神经检查显示视乳头水肿伴周边视野视力下降。
</answer>

# 输出示例3
<answer>
胸部高分辨率CT显示双肺散在磨玻璃影伴小叶间隔增厚；垂体激素全套测试结果显示ACTH降低、皮质醇降低，TSH、游离T4、LH、FSH、GH、IGF-1均正常。
</answer>


医生病人之间的对话如下：
<对话>
{}
</对话>


请你进行转化为陈述格式，不要丢失任何信息细节，把结果放在<answer>标签内。
"""



# 辅检阶段，需要详细的鉴别诊断分析
prompt_long_diagnosis = """你是一名医学专家，你的任务是根据提供的患者病历，推理出top-5鉴别诊断列表。

**核心要求：**
- **诊断排序**：诊断列表按可能性由高到低排列。
- **诊断完整性**：每个诊断都应是完整的，应具体明确（例如：使用“右下叶肺炎”而非“肺炎”；“冠心病不稳定型心绞痛”而非“心脏病”）；可包含主要疾病和相关的并发症/合并症（例如：2型糖尿病 合并 社区获得性肺炎）。
- **诊断竞争性**：列表中的各项诊断应该是相互竞争的备选方案（即鉴别诊断）。**不要将一个统一病理过程的不同方面拆分成独立的条目**（如将“社区获得性肺炎”和“发热”分别列为两个诊断）。
- **聚焦诊断**：你的回答应专注于诊断推理过程和最终的诊断列表。**严禁**提供任何治疗方案、用药建议或健康指导，也不要包含病人的检查结果等无矛盾信息。
- **诊断个数**：允许鉴别诊断个数不足5个。

输出格式:
- 最可能的诊断
- 第二可能的诊断
- 第三可能的诊断
- 第四可能的诊断
- 第五可能的诊断



输出格式示例：
- 肝胆管囊腺癌合并2型糖尿病
- 肝内胆管细胞癌伴囊性变合并2型糖尿病
- 肝细胞癌伴囊性变合并2型糖尿病
- 肝胆管囊腺瘤伴囊内出血合并2型糖尿病
- 肝转移性肿瘤伴囊性变合并2型糖尿病



以下是病人的信息：
<病历>
{}
</病历>

现在请输出若干个相互竞争、完整的诊断方案，不要给出其他无矛盾的内容或解释。
"""


# 生成下一步辅助检查
prompt_recommend_auxiliary_exams = """你是一名医学专家，负责根据 患者现有的病历信息 和 初步鉴别诊断列表，为临床医生提供下一步的辅助检查建议。

### 决策核心原则
请遵循临床医学的“阶梯式检查”策略：
1. **必要性优先**：只推荐能显著改变临床决策或鉴别诊断方向的检查。
2. **不重复检查**：一般不要重复推荐已做过的检查项目。
3. **精准度与成本控制**：
   - 首选无创、低成本、高敏感度的筛查项目。
   - 昂贵或侵入性检查（如穿刺、PET-CT、基因检测）仅在低成本检查无法确诊，且对区分核心鉴别诊断至关重要时才推荐。
4. **名称具体化**：检查项目的名称需要足够具体，例如CT/MRI等检查项目必须注明部位及方式（如：头部CT平扫、腹部增强CT、冠状动脉CTA）。

### 检查目标
推荐的检查组合应致力于实现以下目标之一：
- **确诊**：获取“金标准”证据。
- **排除**：通过关键阴性结果，安全地排除高危的鉴别诊断。
- **鉴别**：有效区分列表中最相似的两个竞争性诊断。


### 输出格式要求
- 只输出推荐的检查项目：你的回答应专注于推荐的检查项目。**严禁**提供任何治疗方案、用药建议或健康指导，也不要输出病人的检查结果等无矛盾信息；不要输出分析过程
- 检查项目需要足够具体和确定，严禁使用‘建议考虑’、‘或者’等模糊表述。输出列表应为一份确定的、必须执行的临床医嘱清单。
- 每一行输出一个检查项目；**禁止把多个项目放在同一行中**（例如，禁止形如“肝硬度检测或血清肝纤维化标志物检测”、“全血细胞计数、凝血功能、肝功能”等表述）
- 输出的格式模板：
请求进行以下辅助检查：
- 第一个项目
- 第二个项目
- 第三个项目
...


### 输出格式示例
请求进行以下辅助检查：
- 头部CT平扫
- 全血细胞计数


患者现有的病历信息：
<病历>
{}
</病历>


初步鉴别诊断列表：
<诊断>
{}
</诊断>

请你根据病历和诊断，推荐若干项辅助检查。
"""

prompt_exam_or_diagnosis = """你是一名医学专家，负责根据 患者现有的病历信息 和 初步鉴别诊断列表，为临床医生建议下一步是否进行辅助检查，还是直接给出最终诊断。


直接出具最终诊断的条件（满足其一即可）：
   **唯一诊断且证据确凿**: 鉴别诊断列表中仅有一个疾病，该疾病能完全解释患者的核心症状，并且已有足够的证据支持（例如“金标准”检查结果）
   **诊断层级、因果清晰**: 列表中的一个诊断是根本病因（首要诊断），而其他诊断均可被明确解释为该诊断的**直接诱因、并发症或附属表现**，而非独立的竞争性诊断。同时，首要诊断已有足够的证据支持
   **证据优势原则**: 某一个诊断的证据链条完整、逻辑严密，与病历中的所有信息（包括症状、体征、已有检查）完美契合、无任何矛盾，并且已有足够证据支持；而列表中的其他诊断均存在无法解释当前病历信息的关键性疑点

注意，只有诊断结果有足够证据支持时，才可以给出最终诊断；否则，必须继续辅助检查。


如果选择给出最终诊断，还需要根据病历对诊断进行扩充，最终输出两句话(核心诊断+完整诊断)，包括（仅在病历包含相关信息时描述，**严禁编造**）：
*   **a. 病因:** 明确指出导致疾病的直接病原体，以及根本的、促成的危险因素（例如，生活习惯、既往病史等）
*   **b. 核心疾病:** 陈述核心诊断名称
*   **c. 主要并发症:** 列出由核心疾病直接引发的最重要的并发症和伴随疾病
*   **d. 关键病理生理状态:** 描述这些并发症导致的身体功能异常状态


输出格式要求：
- 只输出是否继续检查或最终的完整诊断：**严禁**提供任何治疗方案、用药建议或健康指导，也不要输出病人的检查结果等无矛盾信息
- 只输出结果，不要输出分析过程
- 如果选择继续辅助检查，只输出 `继续辅助检查`
- 如果选择给出最终诊断，只输出核心诊断+完整诊断，形如 `您的诊断结果为：xxx(核心诊断)\n您的完整诊断如下：xxx(完整诊断)`

输出示例1
继续辅助检查

输出示例2
您的诊断结果为：颅内静脉窦血栓
您的完整诊断如下：由终末期肝病（肝硬化失代偿期）继发的凝血功能障碍和高氨血症所引发的颅内静脉窦血栓；并继发颅内高压、脑缺血性损伤及肝性脑病。


患者现有的病历信息：
<病历>
{}
</病历>


初步鉴别诊断列表：
<诊断>
{}
</诊断>


请你判断医生下一步应该继续辅助检查，还是给出最终诊断。
"""


# 编造检查结果
prompt_makeup_exam_results = """你是一位资深临床医学专家，任务是**在掌握完整病历的基础上，科学、严谨地补全未记录在病历中的检查结果或回答医生的临床提问**。请严格依循下列推理路径与格式规范，确保所有推导符合循证医学标准。

【一、推理流程】
请在<reasoning>模块中逐层展开逻辑分析，务必严谨、透明，避免跳步或推断断裂：

1. **信息筛选**：区分病历中已明确记录的结果与需推导或补充项。
2. **目标定位**：根据医生的提问类型（询问、体格检查请求、辅助检查请求），明确回应目标。
3. **机制推演**：构建从「症状/体征/背景」→「病理生理机制」→「检查表现」的合理推理链。
4. **结果生成**：基于上述推理，输出符合医学共识的规范描述。

【二、输出结构】  
请严格按照以下标签和内容要求组织回答：

在<reasoning>标签内进行下面的思考：
1. **问题分类**：
   - **直接可答项**：列出在病历中已明确记录且可直接摘录的条目
   - **需推导项**：列出需基于临床线索推理的条目。

2. **逐项推理**（仅针对“需推导项”）：
   a) **临床意义**：该检查或提问在当前情境下的诊断/鉴别价值；
   b) **关键线索**：病历中相关的症状、体征、实验室或影像提示；
   c) **病理机制**：从组织/器官病理生理角度建立推理依据；
   d) **预期表现**：描述检查中预期可见的定性特征；
   e) **逻辑自洽**：确认推理不与病历其他信息冲突。


在<answer>标签内用简洁、标准、定性的语言输出结果。
- 只给出结果，禁止包含推理过程
- 禁止带有“可能”等推测性词语；如果某项结果可能正常，也可能异常，请推理后选择出概率更高的结果
- 禁止透露最终的诊断性信息，例如“符合xx疾病”
- **直接可答项** 和 **需推导项** 都需要输出对应的结果




【回答的示例格式】
一行只对应一个问题或者检查请求
例如需要响应胸部CT和血常规：
<answer>
- 胸部CT：见双肺下叶片状渗出影，部分小叶间隔增厚  
- 血常规：白细胞计数轻度升高，中性粒细胞比例偏高  
</answer>



完整病历：
<病历>
{}
</病历>



需响应的内容如下：
{}


请严格按照上述<reasoning>与<answer>结构进行回复。
"""


prompt_summary_record = """你负责根据提供的病历，将其中的问诊结果和体格检查结果转化为两段描述性的总结，不要丢失任何细节。

# 输出格式
<answer>
问诊结果：...
体格检查结果：...
</answer>


# 输出示例
<answer>
问诊结果：
患者25岁女性，头痛进行性加重6周伴畏光，近1周出现恶心呕吐和视物模糊。患者6周前开始出现非典型头痛，位于头部中央，伴有畏光、畏声和耳鸣症状。患者陈述头痛在晨起时持续存在，咳嗽时加重，站立时可缓解。患者自行服用布洛芬治疗，但效果无效。患者报告近1周出现向左看时视物模糊，偶发持续数秒的完全视力丧失，伴随恶心呕吐导致无法进食。患者有偏头痛病史、肥胖症和阿片类药物使用障碍，目前使用丁丙诺啡-纳洛酮治疗，1个月前最后一次注射海洛因。患者无药物过敏或食物过敏史。患者目前使用丁丙诺啡-纳洛酮治疗阿片类药物使用障碍。患者吸烟，每日半包香烟；不饮酒；居住在新英格兰林区；2年前有监禁史。职业未知，婚姻状况未知，患者饲养4只猫和1只狗。患者有两位父系亲属患有卵巢癌。
体格检查结果：
神经系统：嗅神经功能正常；视神经检查显示视乳头水肿伴周边视野视力下降；动眼神经、滑车神经功能正常，外展神经左侧麻痹；三叉神经面部感觉和运动功能正常；面神经功能正常；前庭蜗神经听力正常；舌咽神经和迷走神经吞咽和发音功能正常；副神经胸锁乳突肌和斜方肌力量正常；舌下神经舌肌运动正常；深反射检查（肱二头肌、肱三头肌、膝、跟腱反射等）双侧对称活跃；浅反射检查（腹壁、提睾、跖反射等）双侧腹壁反射存在，提睾反射对称存在，跖反射正常；病理反射检查（Babinski征、Hoffmann征等）双侧Babinski征未引出，Hoffmann征阴性。患者意识清醒，时间、地点、人物定向力完整，言语流畅，命名、复述和理解功能正常，精神行为无异常；体温36.9°C，脉搏77次/分，呼吸16次/分，血压117/58 mmHg，血氧饱和度96%；发育正常，营养过剩，病态肥胖体态，双腿可见注射针痕；身高160cm，体重109kg，BMI 42.6皮肤色泽正常，未见明显苍白或黄染；双侧下肢可见散在针痕，未见活动性皮疹；皮下未触及明显异常结节；双下肢轻度凹陷性水肿；皮肤温暖，湿度适中；口腔黏膜稍干燥，眼结膜无充血，鼻腔黏膜湿润。
</answer>


<病历>
{}
</病历>


请你对`<病历>`中的内容进行总结。
"""


#########################################################################################
# 诊断正确性的分级
SYSTEM_PROMPT_judge_diagnosis_correct_level = """你是一名医学专家，负责阅卷：基于提供的标准答案，对临床医生的诊断进行精准、客观的评估。
你必须严格遵循以下的**评估流程**来给出判断和解释。


# 评估流程
你必须严格遵守以下两个步骤进行评估：

## 第一步：核心诊断解构
在评估之前，你必须先分析【最终诊断】，将其拆解为：
1.  **核心诊断**：
    *   导致患者当前就诊的主要原因，是诊断中比较严重的若干个疾病。
    *   包括但不限于危及生命或需要紧急医疗干预的疾病。
    *   *评估原则*：后续评估时，这是主要依据。
2.  **次要诊断**：
    *   可以是长期稳定的慢性基础病（如控制良好的高血压），通常不会危及生命，也不需要紧急干预
    *   也可以是核心诊断所直接导致的伴随疾病和伴随症状。
    *   *评估原则*：后续评估时，通常忽略不计。如果医生遗漏了次要诊断，**不**扣分。

## 第二步：基于治疗后果的四级评估
基于“核心诊断”，对比“医生诊断”，根据**对治疗核心诊断的主要方案的影响**选择以下四个等级之一：

### 1. 完全正确
*   **定义**：医生诊断准确覆盖了所有的**核心诊断**。
*   **特征**：
    *   病因、部位、性质完全一致。
    *   仅遗漏了次要诊断。

### 2. 临床可接受
*   **定义**：医生诊断在**核心方向**上正确，仅在**精度**上存在瑕疵。
*   **关键特征**：
    *   **精度瑕疵**：使用了正确的上位概念（如写了“细菌性肺炎”而非“肺炎链球菌肺炎”），或分型/分级不精准。
*   **判别金标准**：**后续治疗方案不会有太大区别**。医生基于该诊断开具的处方，涵盖了患者所需的核心治疗（如抗生素覆盖面正确、手术方式基本一致）。

### 3. 部分正确
*   **定义**：医生诊断的大方向（如系统或症状）有一定的道理，但存在**关键性缺失或模糊**，导致治疗方案存在明显缺陷。
*   **关键特征**：
    *   **核心遗漏**：并存多个核心诊断中，漏掉了其中一个
    *   **精度过于模糊**：诊断过于笼统，导致无法进行必须的特异性治疗（如“感染性休克”未指明感染源，导致抗生素滥用或无效）;或者只给出了核心诊断导致的严重综合征（如休克、心衰），但未诊断原发病。
    *   **分型错误致治疗改变**：例如，将需要手术的类型误判为保守治疗类型。
*   **判别金标准**：**治疗方案有明显区别**，或者**遗漏核心诊断**。虽然医生没有完全误诊（**有一定的道理**），但患者无法获得针对性的关键治疗（如漏了溶栓药、漏了特定手术）。

### 4. 不正确
*   **定义**：**完全错误**的诊断，不仅没有覆盖到任何核心诊断，也没有参考价值。
*   **特征**：将A病误诊为B病（机制完全不同），或仅诊断“腹痛”、“待查”。
*   **判别金标准**：**治疗完全错误或延误**。


# 注意
1. 次要诊断，相比于核心诊断，更加次要；次要诊断不依赖于具体的疾病，例如“脂肪肝”本身可以作为核心诊断，但是如果病人同时存在“肺癌”，那么“肺癌”就是核心诊断，而“脂肪肝”则成为次要诊断。
2. **治疗方案只考虑针对核心诊断的大致诊断路径**，不考虑次要诊断，也无需考虑详细具体的治疗方案。
3. 相比于完全正确，如果在精度上存在错误，那么有可能被分类到“临床可接受”或“部分正确”，具体分到哪个类别，需要根据后续治疗方案判断这种错误程度是否可以接受。


# 回复格式
逐步的分析过程
<answer>判断标签</answer>

其中，判断标签必须是4个类别中的一个，例如
<answer>临床可接受</answer>
"""

USER_PROMPT_judge_diagnosis_correct_level = """{}


请基于提供的医疗信息，对临床医生的诊断进行评估并分类。先给出逐步的分析，并把最终判断放在标签<answer></answer>内。"""



prompt_exist_gold_standard = """请你根据提供的诊断结果，分析病历中是否存在对应的“金标准”：
诊断结果如下：
<诊断>
{}
</诊断>

病历如下：
<病历>
{}
</病历>


# 输出格式
先给出分析过程，然后把最终结果放在<answer>标签内。
如果存在金标准，输出<answer>yes</answer>；否则，输出<answer>no</answer>"""