HuatuoGPT-o1:基于40K可验证医学问题的两阶段复杂推理增强框架,通过验证器引导和强化学习提升医学模型的推理能力

HuatuoGPT-o1:基于40K可验证医学问题的两阶段复杂推理增强框架,通过验证器引导和强化学习提升医学模型的推理能力

    • 论文大纲
    • 理解
      • 1. 确认目标
      • 2. 分析过程
      • 3. 实现步骤
      • 4. 效果展示
    • 解法拆解
    • 全流程
    • 提问
    • 俩阶段详细分析

 


论文:HuatuoGPT-o1, Towards Medical Complex Reasoning with LLMs

代码:https://github.com/FreedomIntelligence/HuatuoGPT-o1

论文大纲

├── HuatuoGPT-o1【论文主题】
│   ├── 研究背景【问题阐述】
│   │   ├── OpenAI o1的突破【研究动机】
│   │   ├── 数学领域推理研究较多【现状】
│   │   └── 医学领域推理研究缺乏【研究缺口】
│   │
│   ├── 可验证医学问题构建【方法基础】
│   │   ├── 从医学考试题库选取【数据来源】
│   │   ├── 筛选具有挑战性的问题【数据筛选】
│   │   └── 转化为开放式问题【数据转化】
│   │
│   ├── 两阶段训练方法【核心方法】
│   │   ├── 阶段一:学习复杂推理【基础训练】
│   │   │   ├── 策略搜索【具体方法】
│   │   │   └── 验证器反馈【训练指导】
│   │   │
│   │   └── 阶段二:强化学习增强【进阶训练】
│   │       ├── PPO算法应用【技术实现】
│   │       └── 稀疏奖励机制【训练策略】
│   │
│   └── 实验验证【成果验证】
│       ├── 模型性能提升【效果】
│       │   ├── 8B版本提升8.5点【具体指标】
│       │   └── 70B版本超越现有模型【竞争优势】
│       │
│       └── 方法有效性验证【方法验证】
│           ├── 复杂推理提升医学问题解决能力【应用价值】
│           └── 强化学习显著提升效果【方法价值】
│
└── 研究贡献【研究意义】
├── 首次实现医学复杂推理【创新性】
├── 提出两阶段训练方法【方法论】
├── 开发首个具备复杂推理能力的医学LLM【技术突破】
└── 证实复杂推理在医学问题中的有效性【实践价值】

理解

  1. 提出背景:

类别问题:LLMs在医学领域的推理能力不足

具体问题:

  • 医学诊断需要严谨的推理过程,但现有模型缺乏可验证的推理能力
  • 现有研究主要集中在数学推理,医学推理领域研究不足
  • 医学推理的验证比数学更具挑战性
  1. 概念性质:
    HuatuoGPT-o1是一个具备复杂推理能力的医学大语言模型

其性质由两个关键因素决定:

  • 可验证医学问题的构建方法
  • 两阶段训练策略(学习复杂推理+强化学习增强)
  1. 对比举例:
    正例:一个关于疟疾并发症的诊断案例,模型通过多步推理,考虑症状(发热、寒战)、实验室检查结果,最终得出脑水肿的结论
    反例:简单的是/否问题,如"患者是否发烧",这类问题不需要复杂推理

  2. 类比理解:

HuatuoGPT-o1就像一个经验丰富的医生在诊断过程中:

  • 首先收集症状和检查结果(输入信息)
  • 然后进行多角度分析(复杂推理)
  • 最后得出诊断结论(输出结果)
  • 并且能够解释推理过程(可验证性)
  1. 概念介绍与总结:

HuatuoGPT-o1是一个专门针对医学领域的大语言模型,其核心特点是:

  • 具备复杂推理能力
  • 推理过程可验证
  • 采用两阶段训练方法
  • 在多个医学基准测试中表现优异
  1. 概念重组:
    “医学推理智能助手”:在医学领域中进行智能推理,助力医生进行诊断决策

  2. 上下文关联:
    文章通过介绍背景、方法、实验和结果,完整展示了HuatuoGPT-o1的研发过程和创新价值

  3. 规律发现:
    主要矛盾:医学推理的可验证性问题
    次要矛盾:

  • 训练数据的获取和处理
  • 模型规模和计算资源
  • 推理效率的优化
  1. 功能分析:
    核心功能:提供可靠的医学推理能力
    具体表现:
  • 定量指标:在医学基准测试中提升8.5个百分点
  • 定性特征:推理过程清晰可验证,符合医学诊断思维
  1. 来龙去脉:
  • 起因:OpenAI o1展示了强大的推理能力,但医学领域缺乏类似研究
  • 经过:研究团队构建可验证医学问题,开发两阶段训练方法
  • 结果:成功开发具备复杂推理能力的医学大语言模型
  1. 创新点:
  • 首次将复杂推理应用于医学领域
  • 提出可验证医学问题的构建方法
  • 开发两阶段训练策略
  • 证明复杂推理在医学问题解决中的有效性
  • 实现模型性能的显著提升

 

1. 确认目标

主要目标:如何让大模型在医学领域实现可靠的复杂推理能力?

2. 分析过程

问题层层分解:

  1. 如何构建可验证的医学推理问题?

    • 从医学考试题库筛选挑战性问题
    • 转化为开放式问题
    • 确保答案唯一且客观
  2. 如何让模型学会复杂推理?

    • 设计搜索策略(回溯、探索新路径、验证、修正)
    • 使用验证器提供反馈
    • 将成功的推理轨迹用于微调
  3. 如何进一步提升推理能力?

    • 采用PPO算法进行强化学习
    • 设计稀疏奖励机制
    • 保持与初始策略的KL散度

3. 实现步骤

  1. 构建数据集
    • 收集192K医学选择题
    • 筛选得到40K可验证问题
    • 划分为训练集和验证集

在这里插入图片描述

  • 左侧:展示了如何从医学考试题库(MedQA & MedMCQA数据集)中筛选和转化出可验证的医学问题
  • 右侧:说明医学验证器如何检查模型输出与标准答案的匹配程度
  • 包含了一个具体示例:将一个关于30岁女性旅行相关症状的多选题转化为开放式问题
  1. 阶段一:学习复杂推理
    • 初始化推理链
    • 应用搜索策略
    • 收集成功轨迹
    • 进行模型微调

在这里插入图片描述
HuatuoGPT-o1的训练过程示意图:

  • 左侧(第一阶段):展示如何搜索正确的推理轨迹以训练模型进行复杂推理
  • 右侧(第二阶段):说明如何通过强化学习进一步增强复杂推理能力
  • 包含了问题、验证器、搜索策略和强化学习各个组件的交互过程
  1. 阶段二:强化学习增强
    • 设置奖励函数
    • 应用PPO算法
    • 迭代优化模型

在这里插入图片描述
推理路径示例详解:

  • 左侧:展示了一个完整的搜索过程,包括:
    • 初始推理尝试
    • 验证策略的应用
    • 修正策略的使用
    • 探索新路径策略的应用
    • 最终找到正确答案
  • 右侧:展示如何将搜索过程重构为流畅的复杂推理链

4. 效果展示

在这里插入图片描述

目标:开发具备复杂推理能力的医学大语言模型

过程:两阶段训练方法(复杂推理学习+强化学习)

问题:医学推理的可验证性

方法:可验证问题构建 + 搜索策略 + 强化学习

结果:

  • 8B模型性能提升8.5个百分点
  • 70B模型超越现有开源模型
  • 在多个医学基准测试中表现优异

解法拆解

  1. 逻辑关系拆解:

技术:HuatuoGPT-o1 = 可验证医学问题学习 + 基于验证器的复杂推理增强
问题:医学领域需要可靠的复杂推理能力
主要区别:与其他医学LLM相比,引入了验证和迭代反馈机制

子解法拆解:

解法1:可验证医学问题构建

  • 因为特征:医学推理需要客观验证
    • 筛选具有挑战性的问题(因为需要深度推理)
    • 确保答案唯一性(因为需要准确验证)
    • 转化为开放式问题(因为促进推理思考)

解法2:复杂推理能力培养

  • 因为特征:医学决策需要深入思考
    • 构建搜索策略(因为需要探索多个推理路径)
    • 应用验证器反馈(因为需要确保推理正确性)
    • 生成复杂推理链(因为需要展示推理过程)

解法3:强化学习增强

  • 因为特征:需要持续优化推理能力
    • 设计奖励机制(因为引导模型改进)
    • 结合KL散度(因为平衡探索和利用)
  1. 逻辑链形式:
HuatuoGPT-o1
├── 问题构建
│   ├── 筛选问题
│   ├── 验证唯一性
│   └── 开放式转化
├── 推理培养
│   ├── 搜索策略
│   │   ├── 回溯
│   │   ├── 探索新路径
│   │   ├── 验证
│   │   └── 修正
│   └── 验证器反馈
└── 强化增强
    ├── 奖励机制
    └── KL散度平衡
  1. 隐性方法:
  • 推理路径合并:将多轮搜索结果整合为连贯的推理过程
  • 验证器构建:使用GPT-4评估答案正确性
  • 自然语言转化:将结构化推理转为流畅的语言表达
  1. 隐性特征:
  • 推理质量与令牌数量的关系(平均712个令牌效果最好)
  • 验证器可靠性对整体性能的影响
  • 不同搜索策略的组合效果
  1. 潜在局限性:
  • 依赖GPT-4作为验证器可能引入偏差
  • 仅适用于有明确答案的医学问题
  • 计算资源消耗大
  • 对中小型模型效果可能有限
  • 可能存在数据覆盖不全面的问题

全流程

在这里插入图片描述

  1. 全流程优化分析:

多题一解情况:

  • 共用特征:需要深度推理的医学问题
  • 共用解法:验证器引导的搜索策略
  • 适用场景:复杂诊断、治疗方案制定等需要多步推理的医学问题

一题多解情况:

  • 特征1:需要回溯思考 -> 解法:回溯策略
  • 特征2:需要新视角 -> 解法:探索新路径
  • 特征3:需要验证确认 -> 解法:验证策略
  • 特征4:需要修正完善 -> 解法:修正策略

优化方案:

  1. 数据层面优化:

    • 原方案:直接使用医学考试题
    • 优化后:构建可验证问题库
  2. 推理过程优化:

    • 原方案:单次推理
    • 优化后:多策略迭代搜索
  3. 验证机制优化:

    • 原方案:精确匹配
    • 优化后:GPT-4语义验证
  4. 输入输出示例:

医疗案例:
输入:

患者,30岁女性,最近从印度旅行回来,出现发抖、寒战、发烧、头痛、面色苍白和黄疸。
生命体征:体温38.9°C,呼吸19/分,血压120/80mmHg,脉搏94/分。
实验室检查:红细胞压积30%,总胆红素2.6mg/dL,直接胆红素0.3mg/dL。
此症状最严重的并发症是什么?

处理流程:

  1. 初始推理(e0,y0):

    • 分析症状和体征
    • 考虑旅行史
    • 初步判断可能是疟疾
  2. 验证器检查:需要更深入分析

  3. 搜索策略迭代:

    • 探索并发症机制
    • 分析症状严重程度
    • 考虑不同类型疟疾
  4. 最终推理(ei,yi):

    • 确认为恶性疟疾
    • 分析并发症风险

输出:
“脑水肿是该病情最严重的并发症。基于患者的旅行史和临床表现,这很可能是恶性疟疾,其中脑水肿是最危险的并发症,可导致意识障碍甚至死亡。”

这个例子展示了模型如何通过复杂推理和多轮验证,从初始症状描述到最终得出准确的医学判断。

 


提问

  1. Q: HuatuoGPT-o1的核心创新是什么?
    A: 首次在医学领域引入可验证问题和医学验证器来发展复杂推理能力,通过两阶段训练方法:先利用验证器指导搜索得到复杂推理轨迹,再用强化学习进一步增强推理能力。

  2. Q: 如何将医学多选题转化为可验证问题?
    A: 通过三步流程:1)用小型模型筛选有挑战性的问题;2)确保问题有唯一明确答案;3)将封闭式多选题重写为开放式问题。

  3. Q: 医学验证器的准确率如何?
    A: GPT-4验证器在两个阶段分别达到96.5%和94.5%的准确率,远高于简单的精确匹配方法(70.5%和74.5%)。

  4. Q: 为什么复杂推理对医学问题特别重要?
    A: 医学决策通常需要谨慎的思考过程来确保答案可靠性,这类似于医生在现实诊断中的深入思考过程。

  5. Q: 四种搜索策略的具体作用是什么?
    A: 回溯用于重新审视前期推理、探索新路径用于尝试不同角度、验证用于确认当前推理、修正用于改进现有推理。

  6. Q: 模型在训练中如何处理错误答案?
    A: 当验证器发现错误时,模型会随机选择一种搜索策略进行改进,直到找到正确答案或达到最大尝试次数。

  7. Q: 强化学习阶段的奖励机制如何设计?
    A: 正确答案获得1.0分,错误答案0.1分,缺乏思考过程0分,同时结合KL散度来平衡探索和利用。

  8. Q: 为什么要限制在40K可验证问题?
    A: 这是经过严格筛选的高质量问题集,能够有效训练模型的推理能力,同时保持计算资源的合理使用。

  9. Q: 复杂推理和简单推理在强化学习中的差异?
    A: 复杂推理(平均712个令牌)获得3.6点提升,而简单推理(281个令牌)只有2.6点提升,说明更长的推理过程提供了更丰富的学习信号。

  10. Q: HuatuoGPT-o1的主要局限性是什么?
    A: 主要限制包括:依赖GPT-4作为验证器可能引入偏差、只适用于有明确答案的医学问题、计算资源需求大、可能存在数据覆盖不全面的问题。

俩阶段详细分析

第一阶段:学习复杂推理(Learning Complex Reasoning)

  1. 输入与准备:
  • 可验证医学问题(x, y*):x是问题,y*是标准答案
  • 初始LLM模型(如GPT-4o)
  • 医学验证器
  1. 搜索正确推理路径:
def search_reasoning_path(x, y*, max_tries=3, max_iter=3):
    for try_count in range(max_tries):
        # 初始推理
        e0, y0 = LLM_init(x)  # 生成初始推理链和答案
        
        if verifier(y0, y*):  # 如果初始答案正确
            return format_reasoning([e0, y0])
            
        # 如果错误,开始迭代搜索
        history = [(e0, y0)]
        for i in range(max_iter):
            # 随机选择搜索策略
            strategy = random.choice([
                'backtracking',
                'exploring_new_paths',
                'verification',
                'correction'
            ])
            
            # 应用选定策略生成新推理
            ei, yi = LLM_strategy(x, history, strategy)
            history.append((ei, yi))
            
            if verifier(yi, y*):  # 如果找到正确答案
                return format_reasoning(history)
                
    return None  # 未找到正确路径
  1. 构建训练数据:
def format_reasoning(history):
    # 将搜索历史重构为自然流畅的推理过程
    complex_cot = ""
    for i, (ei, yi) in enumerate(history):
        if i > 0:
            complex_cot += transition_words()  # 添加过渡词
        complex_cot += format_thought(ei)
    
    return complex_cot

第二阶段:强化学习增强(Enhance Reasoning with RL)

  1. 准备工作:
  • 使用第一阶段训练好的模型作为初始策略
  • 设计奖励函数
  • 配置PPO参数
  1. 强化学习实现:
def rl_training(model, verifier, beta=0.03):
    def compute_reward(y, y*, policy_old, policy_new):
        # 基础奖励
        base_reward = 1.0 if verifier(y, y*) else 0.1
        
        # KL散度惩罚
        kl_penalty = beta * compute_kl(policy_old, policy_new)
        
        return base_reward - kl_penalty
    
    ppo = PPO(
        learning_rate=5e-7,
        batch_size=128,
        clip_range=0.2,
        value_coef=1.0,
        epochs=3
    )
    
    for batch in data_loader:
        # 收集轨迹
        states, actions, old_probs = collect_trajectories(model, batch)
        
        # 计算奖励
        rewards = [compute_reward(y, y*, old_p, new_p) 
                  for y, y*, old_p, new_p in zip(
                      actions, batch.answers, old_probs, model.probs)]
        
        # PPO更新
        ppo.update(states, actions, rewards, old_probs)

关键实现细节:

  1. 验证器实现:
def medical_verifier(response, reference):
    # 使用GPT-4进行语义匹配
    prompt = construct_verification_prompt(response, reference)
    result = gpt4(prompt)
    return parse_verification_result(result)
  1. 搜索策略实现:
class SearchStrategies:
    @staticmethod
    def backtracking(history):
        # 返回到之前的推理点重新开始
        return modify_previous_reasoning(history[-2])
    
    @staticmethod
    def exploring_new_paths(history):
        # 尝试全新的推理角度
        return generate_new_approach()
    
    @staticmethod
    def verification(history):
        # 详细验证当前推理
        return validate_current_reasoning(history[-1])
    
    @staticmethod
    def correction(history):
        # 修正当前推理中的错误
        return fix_reasoning_errors(history[-1])

这种实现方式确保了:

  • 推理过程的可追踪性
  • 搜索策略的灵活性
  • 验证反馈的及时性
  • 强化学习的稳定性

整个过程形成了一个完整的循环:从初始推理开始,通过多轮搜索获得正确推理路径,再通过强化学习持续优化模型的推理能力。

 

第一阶段:学习复杂推理

  1. 初始输入:
  • 数据:医学问题x和标准答案y*
  • 示例:“30岁女性从印度旅行回来,出现发抖、寒战等症状…最严重的并发症是什么?”
  1. 推理搜索过程:

初始尝试:

  • 模型生成初始推理e0:“考虑到患者的旅行史和症状…”
  • 给出初始答案y0:“可能是心脏传导阻滞”
  • 验证器检查:错误,需要继续搜索

搜索循环:
a) 验证策略:

  • 重新审视症状和生命体征
  • 发现:“体温升高、贫血和黄疸提示可能是感染性疾病”
  • 验证器:仍需完善

b) 探索新路径:

  • 关注旅行史和地理因素
  • 推理:“印度是疟疾高发区,症状符合恶性疟疾”
  • 验证器:方向正确,但需要具体并发症

c) 修正策略:

  • 分析疟疾的严重并发症
  • 结论:“脑水肿是最严重的并发症”
  • 验证器:正确!
  1. 整合推理链:
    将成功的搜索过程重构为流畅的推理:
    “让我们分析这个病例…首先,注意到患者有印度旅行史…结合发热、贫血和黄疸症状…考虑到疟疾的可能…最终确定脑水肿是最危险的并发症…”

第二阶段:强化学习增强

  1. 奖励机制设置:
  • 正确答案:1.0分
  • 错误但有推理:0.1分
  • 无推理直接回答:0分
  • 添加KL散度平衡项
  1. 训练过程:
    a) 初始预测:
  • 模型基于第一阶段学到的推理模式生成答案
  • 验证器评估结果
  • 计算初始奖励

b) 策略优化:

  • 根据奖励信号调整模型参数
  • 平衡探索新推理方式和利用已知有效推理
  • 通过KL散度防止过度偏离原始策略

c) 迭代改进:

  • 持续收集推理样本
  • 基于验证器反馈更新策略
  • 逐步提升推理质量

实际效果展示:

输入问题:
“患者,45岁男性,突发胸痛2小时,伴有大汗、恶心。ECG显示ST段抬高…”

模型推理过程:

  1. “首先,这些症状提示急性心血管事件…”
  2. “等等,让我们具体分析ECG改变…”
  3. “考虑到症状组合和ECG表现…”
  4. “经过进一步思考,症状、体征和ECG改变高度提示…”

最终输出:
“这是典型的ST抬高型心肌梗死(STEMI),需要立即进行再灌注治疗。”

这个过程展示了模型如何:

  • 进行多角度思考
  • 不断改进推理
  • 形成系统化的诊断思路
  • 给出准确的医学判断

通过这两个阶段的训练,模型学会了像医生一样进行深入、系统的医学推理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/946277.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HTML——45.单元格合并

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>表格</title></head><body><!--合并单元格&#xff1a;1.在代码中找到要合并的单元格2.在要合并的所有单元格中&#xff0c;保留要合并的第一个单元格…

electron在arm64架构交叉编译遇到libnotify/notify.h文件找不到错误记录

问题描述 在按照官方文档进行arm64下electron编译时出现下面的错误&#xff0c;编译环境为ubuntun22.04.5。 问题分析 由于当前目标架构是arm64&#xff0c;所以从上图可知sysroot为build/linux/debian_bullseye_arm64-sysroot&#xff0c;进入到该目录下查看libnotify的头文…

我的创作纪念日与2024年年报

我的创作纪念日 机缘 原来是你&#xff01; 收获 在创作的过程中都有哪些收获 获得了14668粉丝的关注。获得了正向或者反向的反馈&#xff1a;1万多赞、426评论、140多万阅读量等。认识和哪些志同道合的领域同行&#xff1a;有且再寻觅。 日常 &#x1f3e0;个人主页&…

点击锁定按钮,锁定按钮要变成解锁按钮,然后状态要从待绑定变成 已锁定(升级版)

文章目录 1、updateInviteCodeStatus2、handleLock3、InviteCodeController4、InviteCodeService5、CrudRepository 点击锁定按钮&#xff0c;锁定按钮要变成解锁按钮&#xff0c;然后状态要从待绑定变成 已锁定&#xff1a;https://blog.csdn.net/m0_65152767/article/details…

使用npm包的工程如何引入mapboxgl-enhance/maplibre-gl-enhance扩展包

作者&#xff1a;刘大 前言 在使用iClient for MapboxGL/MapLibreGL项目开发中&#xff0c;往往会对接非EPSG:3857坐标系的地图&#xff0c;由于默认不支持&#xff0c;因此需引入mapboxgl-enhance/maplibre-gl-enhance扩展包。 在使用Vue等其他框架&#xff0c;通过npm包下载…

[2474].第04节:Activiti官方画流程图方式

我的后端学习大纲 Activiti大纲 1.安装位置&#xff1a; 2.启动&#xff1a;

UnityRenderStreaming使用记录(三)

测试UnityRenderStreaming在Ubuntu24.04.1LTS上的表现 先放上运行图操作系统 Ubuntu24.04.1LTSUnity测试工程环境相关修改遇到的问题 先放上运行图 操作系统 Ubuntu24.04.1LTS 系统下载地址 https://cn.ubuntu.com/download/desktop安装UnityHub https://blog.csdn.net/AWNUXC…

电脑主机后置音频插孔无声?还得Realtek高清晰音频管理器调教

0 缘起 一台联想电脑&#xff0c;使用Windows 10 专业版32位&#xff0c;电脑主机后置音频插孔一直没有声音&#xff0c;所以音箱是接在机箱前面版的前置音频插孔上的。 一天不小心捱到了音箱的音频线&#xff0c;音频线头断在音频插孔里面了&#xff0c;前置音频插孔因此用不…

【项目】智能BI洞察引擎 测试报告

目录 一、项目背景BI介绍问题分析项目背景 二、项目功能三、功能测试1、登录测试测试用例测试结果 2、注册测试测试用例测试结果出现的bug 3、上传文件测试测试用例测试结果 4、AI生成图表测试测试用例测试结果 5、分析数据页面测试&#xff08;异步&#xff09;测试用例测试结…

年会头投票小游戏

原型预览 源码 https://github.com/open-frame/vote 原型源文件 https://download.csdn.net/download/qq_42618566/90206788

活动预告 |【Part1】Microsoft Azure 在线技术公开课:基础知识

课程介绍 参加“Azure 在线技术公开课&#xff1a;基础知识”活动&#xff0c;培养有助于创造新的技术可能性的技能并探索基础云概念。参加我们举办的本次免费培训活动&#xff0c;扩充自身的云模型和云服务类型知识。你还可以查看以计算、网络和存储为核心的 Azure 服务。 活…

springboot499基于javaweb的城乡居民基本医疗信息管理系统(论文+源码)_kaic

摘 要 信息数据从传统到当代&#xff0c;是一直在变革当中&#xff0c;突如其来的互联网让传统的信息管理看到了革命性的曙光&#xff0c;因为传统信息管理从时效性&#xff0c;还是安全性&#xff0c;还是可操作性等各个方面来讲&#xff0c;遇到了互联网时代才发现能补上自古…

Java高级

1.反射 每个类都有一个唯一的类对象&#xff0c;该对象是 java.lang.Class 类型。【是 Java 类的元数据&#xff08;metadata&#xff09;对象&#xff0c;包含了该类的结构信息和其他相关数据】 获取类对象 1.什么是类对象 public class Daughter extends Parent{ …

HarmonyOS NEXT 实战之元服务:静态案例效果---我的热门应用服务

背景&#xff1a; 前几篇学习了元服务&#xff0c;后面几期就让我们开发简单的元服务吧&#xff0c;里面丰富的内容大家自己加&#xff0c;本期案例 仅供参考 先上本期效果图 &#xff0c;里面图片自行替换 效果图1完整代码案例如下&#xff1a; Index import { authentica…

libvirt学习

文章目录 libvirt 简介节点、Hypervisor和域libvirt 安装和配置libvirt的XML配置文件libvirt APIMain libvirt APIsError handlingSpecial specific APIs 建立到Hypervisor的连接libvirt API使用编译libvirt工具virshvirt-clonevirt-dfvirt-imagevirt-installvirt-topvirt-what…

“进制转换”公式大集合

咱们都知道十进制是“逢10进1 ”&#xff0c;同理&#xff0c;N进制就是 “逢N进1”。进制其实就这么简单。它的麻烦之处在于各种进制之间的转换。 一、十进制整数转N进制 1&#xff0e;十进制转二进制 除2取余法&#xff1a;连续除以2&#xff0c;直到商为0&#xff0c;逆序…

线程-3-线程控制

线程资源共享 线程间绝大部分资源都是共享的&#xff08;堆栈共享区&#xff09; 线程间堆空间是共享的 谁拿着堆空间的入口地址&#xff0c;谁就能访问 共享区也是共享的&#xff08;cout&#xff0c;printf库都在共享区&#xff09; 线程间有权限访问/修改其他线程栈数据&…

1、ELK的架构和安装

ELK简介 elk&#xff1a;elasticsearch logstash kibana&#xff0c;统一日志收集系统。 elasticsearch&#xff1a;分布式的全文索引引擎的非关系数据库&#xff0c;json格式&#xff0c;在elk中存储所有的日志信息&#xff0c;架构有主和从&#xff0c;最少需要2台。 …

MetaRename for Mac,适用于 Mac 的文件批量重命名工具

在处理大量文件时&#xff0c;为每个文件手动重命名既耗时又容易出错。对于摄影师、设计师、开发人员等需要频繁处理和整理文件的专业人士来说&#xff0c;找到一款能够简化这一过程的工具是至关重要的。MetaRename for Mac 就是这样一款旨在提高工作效率的应用程序&#xff0c…

方正畅享全媒体新闻采编系统 imageProxy.do 任意文件读取漏洞复现

0x01 产品简介 方正畅享全媒体新闻生产系统是以内容资产为核心的智能化融合媒体业务平台,融合了报、网、端、微、自媒体分发平台等全渠道内容。该平台由协调指挥调度、数据资源聚合、融合生产、全渠道发布、智能传播分析、融合考核等多个平台组成,贯穿新闻生产策、采、编、发…