【3万块指令免费送】Evol-Instruct 应用:扩充大模型数据多样性

news2024/7/11 10:13:41

Evol-Instruct 应用:扩充大模型数据多样性

    • 提出背景
    • 流程步骤
    • 总结
    • Evol-Instruct 代码复现
    • Evol-Instruct 应用:扩充大模型数据多样性

 


提出背景

论文:https://arxiv.org/pdf/2304.12244.pdf

代码:https://github.com/nlpxucan/WizardLM
 
Evol-Instruct 利用大模型生成指令的方法,可生成相对复杂和多样的指令数据集。

  1. 子问题1:初始指令集的限制(人类懒得写复杂指令)
    子解法1:指令数据演化
    • 特征: 需要将初始指令集(D(0))升级,以产生更多样化的指令。
    • 目的: 通过演化提高指令的复杂度和响应性,增强模型对不同类型指令的处理能力。

现在有一个创业方向,就是给带货行业写指令,一条好的指令可以卖到 5000-几万块,但复杂的指令十分烧脑。

  1. 子问题2:生成复杂指令的需求
    子解法2:指令演化者(Instruction Evolver)

    • 特征: 使用特定提示(prompts)来使指令更复杂和困难。
    • 目的: 产生高质量的、难度逐步增加的指令,避免过度复杂化影响模型泛化性能。
  2. 子问题3:指令多样性不足
    子解法3:广度演化(In-Breadth Evolving)

    • 特征: 通过创建与给定指令基于同一领域但更为罕见的全新指令来增加主题和技能覆盖面。
    • 目的: 扩展数据集的主题和技能多样性,增强模型的综合应用能力。
  3. 子问题4:演化失败的指令的筛选
    子解法4:淘汰演化(Elimination Evolving)

    • 特征: 识别和过滤那些没有提供信息增益、难以生成响应、只包含标点和停止词、或明显复制了演化提示词汇的指令。
    • 目的: 保证指令集的质量,提供有效的数据用于模型训练。
  4. 子问题5:如何有效地微调LLM
    子解法5:在演化指令上微调LLM

    • 特征: 将所有演化的指令数据与初始指令集合并,随机洗牌以创造最终的微调数据集。
    • 目的: 确保在数据集中指令难度级别的均匀分布,最大化模型微调的平滑性。

 


流程步骤

Evol-Instruct方法的示例,这是一种使用大型语言模型(LLMs)代替人类来自动生成各种难度级别的开放域指令的新方法。

在这里插入图片描述

从一个简单的初始指令“1+1=?”开始,如何通过两种演化方式——“In-depth Evolving”(深度演化,蓝色方向线)和“In-breadth Evolving”(广度演化,红色方向线)——来提升指令的复杂性或创造新的指令以增加多样性。

图中给出了五种深度演化操作和一种广度演化操作,具体如下:

  1. 深度演化(In-depth Evolving) 包括五种类型的操作:

    • 添加约束(Add Constraints):如将“1+1=?”演化为“在哪种情况下1+1不等于2?”
    • 深化(Deepening):如将“1+1=?”演化为“如何证明1+1=2在哥德巴赫猜想中是正确的?”
    • 具体化(Concretizing):如将“如果你有一个苹果,有人给了你一个香蕉,你有多少水果?”
    • 增加推理步骤(Increase Reasoning):如将“1+1=?”演化为“x的值是多少,如果3x+3=7?”
    • 复杂化输入(Complicate Input):通过增加代码或公式来提高问题的复杂性,如给出一个包含数学函数和随机数的Python代码片段要求求解。
  2. 广度演化(In-breadth Evolving) 是突变,即基于给定指令生成一个完全新的指令:

    • 例如,将“1+1=?”演化为“请填写下表,提供光速在不同介质中的近似值。”
    • 另一个示例是将“请解释上述公式中叶绿素的主要作用。”演化为一个复杂化输入的表格任务。

此外,图中还显示了一个被称为“Elimination Evolving”(淘汰演化)的过程,用于过滤失败的指令。

 


这张图提供了Evol-Instruct方法的概览,标题为“Figure 2: Overview of Evol-Instruct”。这是一个由三个主要部分组成的流程图:

  1. 初始指令(Initial Instruction):这是流程的起点,表示Evol-Instruct方法的开始,用一个灯泡图标表示,可能象征着一个简单的、创意的或基础的想法。

  2. 演化过程(Evolving Process):从初始指令出发,指令经历了三种演化过程:

    • 深度演化(In-Depth Evolving):用蓝色箭头表示,指令变得更加复杂和深入。
    • 广度演化(In-Breadth Evolving):用红色箭头表示,指令变得更加多样化。
    • 淘汰演化(Elimination Evolving):用黄色箭头表示,不成功的指令将被淘汰。

    演化过程中使用了不同的图标来表示这一过程,包括树木的图标表示生长和发展,以及一个回收符号可能表示从失败的指令中回收和重组元素。

  3. 指令消除器(Instruction Eliminator):这是一个用于过滤掉不成功或不合格指令的步骤,用一个带有红色错误标记的图标表示。

  4. 指令池(Instruction Pool):通过演化过程成功的指令被收集到指令池中,表示为一个数据库或存储图标。

  5. 基础LLM(Foundation LLM):指令池中的指令被用来训练或微调基础大型语言模型,这里用一只骆驼图标表示,可能代表LLM的负载能力或基础性质。

  6. WizardLM:最终,经过微调的LLM被称为WizardLM,这里用一个魔术师图标表示,可能意味着模型通过Evol-Instruct变得更加强大或具有魔法般的能力。

Evol-Instruct的整个流程:从一个初始指令开始,通过多轮的演化和过滤,最终生成一个高质量的指令池,这个指令池被用于训练或微调一个更先进的LLM,即WizardLM。

 


总结

Evol-Instruct方法的拆解和解释如下:

主问题: 如何通过Evol-Instruct方法生成多样化和复杂度高的指令,以提升大型语言模型(LLMs)的性能。

问题与解法组成:

  1. 子问题1:生成复杂度更高的指令。

    • 子解法1:Instruction Evolver。
      • 特点: 利用LLM的能力,通过深度演化和广度演化的策略来生成更复杂的指令。
      • 原因: 深度和广度演化可以从不同角度增加指令的复杂性,增强LLM处理多样化任务的能力。
  2. 子问题2:从深度方面增加指令复杂性。

    • 子解法2:深度演化操作,包括增加约束、深化、具体化、增加推理步骤和复杂化输入。
      • 特点: 这些操作通过改写现有指令,增加其复杂度和细节。
      • 原因: 这些改写方法可以使指令更加具体和挑战性,迫使LLM进行更深入的思考和处理。

例子:

  • 增加约束:原指令:“翻译这段文字。” ------ 改写后的指令:“翻译这段文字,并确保翻译结果在文化上是敏感和适当的。”
  • 深化:原指令:“总结这篇文章的主要观点。” ------ 改写后的指令:“总结这篇文章的主要观点,并解释它们对当前政治环境的影响。”
  • 具体化:原指令:“描述一个健康的饮食。” ------ 改写后的指令:“描述一个适合糖尿病患者的健康饮食计划。”
    增加推理步骤:原指令:“计算10加20的结果。” ------ 改写后的指令:“如果一个人有10个苹果,每天吃掉2个,计算他需要多少天吃完这些苹果。”
  • 复杂化输入:原指令:“根据提供的数据绘制图表。” ------ 改写后的指令:“根据提供的数据中的趋势和异常值绘制图表,并解释可能的原因。”
  1. 子问题3:从广度方面增加指令复杂性。
    • 子解法3:广度演化操作,即创造全新指令。
      • 特点: 生成与现有指令相似但更为罕见的新指令。
      • 原因: 创造新的指令可以提高数据集的多样性,促进LLM学习更广泛的应用场景。

原指令:“写一个关于太空旅行的短故事。”

改写后的新指令:“创建一个关于在火星上建立殖民地的未来主义场景。”

  1. 子问题4:筛选有效的演化指令。
    • 子解法4:Instruction Eliminator,即指令消除器。
      • 特点: 剔除演化过程中产生的无效或低效指令。
      • 原因: 确保数据集中的指令都是高质量的,有助于提高LLM的训练效率和性能。

假设通过演化产生了一条指令:“编写一个故事,然后删除它。”

因为这个指令缺乏具体的目的和效用,所以被指令消除器剔除。

 
每个子问题和子解法在整体解法中的目的:

  • 子问题1和子解法1 的目的是通过创新的演化方法生成具有不同复杂度的指令,增强LLM的处理能力。
  • 子问题2和子解法2 的目的是通过深化和具体化现有指令,使LLM能够处理更复杂和具体的任务。
  • 子问题3和子解法3 的目的是增加数据集的广度和多样性,使LLM能够适应更广泛的应用场景。
  • 子问题4和子解法4 的目的是确保通过演化方法生成的指令是高质量的,提高LLM训练的效率和成果。

 


Evol-Instruct 代码复现

 


Evol-Instruct 应用:扩充大模型数据多样性

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何提高思维能力,洞悉事物本质?(二)

在上一篇文章里,我们分享了几个简单、有效的思维模型。 这一篇,会继续探讨这个话题,向大家介绍几个常用的思维模型。 今天的主题是「找本质」。 大多数问题,当我们思考和讨论的时候,许多人常犯的错误,其实是…

【Redis】实现购物秒杀及分布式锁

Redis实现购物秒杀及分布式锁 全局唯一ID Redis自增ID策略 ID构造是:时间戳 + 计数器 每天一个key,方便统计订单量 业务实现 获取指定时间的秒数 LocalDateTime timeBegin = LocalDateTime.of(2024, 1, 1, 0, 0, 0); long second = timeBegin.toEpochSecond(ZoneOffset…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之DatePicker组件

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之DatePicker组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、DatePicker组件 日期选择器组件,用于根据指定日期范围创建日期滑…

前端工程\模块化

前端工程\模块化🏭 本篇文章,学习记录于:尚硅谷🎢,紧接前文:邂逅Node.JS的那一夜→博客 无论是前端、后端、甚至非编程领域都有模块化的概念,只是不同的领域叫法不同,不过&#xf…

n-皇后-dfs

import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import java.io.OutputStreamWriter; import java.util.Scanner;public class Main {static int n,N 20; //这里只会用到2 * n - 1的格子,开大点保险static char[][] g new c…

编曲学习:功能和声 歌曲结构 和弦编配(上)

34届三和弦 功能和声 歌曲结构 和弦编配(上)https://app8epdhy0u9502.pc.xiaoe-tech.com/live_pc/l_65b4e014e4b064a83b8f44fd?course_idcourse_2XLKtQnQx9GrQHac7OPmHD9tqbv 34届独立音乐人编曲训练营https://app8epdhy0u9502.pc.xiaoe-tech.com/p/t_…

【Java程序设计】【C00219】基于SSM的大学生课程管理系统(论文+PPT)

基于SSM的大学生课程管理系统(论文PPT) 项目简介项目获取开发环境项目技术运行截图 项目简介 这个一个基于SSM的大学生课程管理系统,本系统共分为三种权限:管理员、教师和学生 管理员:查看个人中心、学生管理、公告信…

CTF-WEB的知识体系

CTF概念 CTF是Capture The Flag的缩写,中文一般译作夺旗赛 CTF起源于1996年DEFCON全球黑客大会 DEFCONCTF是全球技术水平和影响力最高的CTF竞赛 竞赛模式 解题模式:解决网络安全技术挑战(即找到flag),提交后获取相应分值。 攻防赛模式:要求找到其他队…

计算机基础知识讲解(原码反码补码)(以及在C语言里面是如何计算和运用的)

补码反码掩码以及原理 补码、反码和掩码是计算机科学中用于表示和处理数值的三种编码方式。 原码 原码是最直观的数值表示方法,它将数值的二进制表示与其符号位结合起来。在原码表示中,正数的符号位为0,而负数的符号位为1。原码的缺点在于…

Django实例_后台管理及分页器

原理步骤参考: Django开发_14_后台管理及分页器-CSDN博客 一、创建Django项目 二、创建page_app python manage.py startapp page_app三、修改settings.py文件 (一)添加app (二)设置每页显示数据个数 (三)设置中文显示 四、总路由添加子路由路径 from django.contrib impo…

MD5算法:高效安全的数据完整性保障

摘要:在数字世界中,确保数据完整性和安全性至关重要。消息摘要算法就是一种用于实现这一目标的常用技术。其中,Message Digest Algorithm 5(MD5)算法因其高效性和安全性而受到广泛关注。本文将详细介绍MD5算法的优缺点…

C++初阶:入门泛型编程(函数模板和类模板)

大致介绍了一下C/C内存管理、new与delete后:C初阶:C/C内存管理、new与delete详解 我们接下来终于进入了模版的学习了,今天就先来入门泛型编程 文章目录 1.泛型编程2.函数模版2.1概念2.2格式2.3函数模版的原理2.4函数模版的实例化2.4.1隐式实例…

leetcode 27.移除元素(python版)

需求 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度…

Cocos creator 动作系统

动作系统简介 是用于控制物体运动的一套系统,完全依赖代码进行实现,动态调节节点的移动。 移动 cc.moveTo 移动到某个坐标(x,y) //1秒时间内,移动到0,0let action1 cc.moveTo(1,0,0)this.node.runAction(action1)c…

LeetCode.2670. 找出不同元素数目差数组

题目 题目链接 分析 一种暴力的方法,枚举数组所有数字,分别计算当前元素前面不同的元素和后面不同的元素,然后相减即可。这样的话太暴力,前缀和后缀也需要分别遍历:O(N*2)了。 我们来优化一下: 根据这种…

Git 介绍 与 配置

Git 介绍 Git是一个分布式版本控制系统,用于跟踪文件的更改和协作开发。它可以管理项目的版本历史记录,并允许多个开发者在同一时间进行并行开发。 解决上图产生的问题就出现了git 分布式版本控制系统 看下图 Git 配置 Git的基本配置包括用户名和电子邮…

基于深度学习的鸟类识别系统matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 卷积神经网络基础 4.2 GoogLeNet模型 4.3 鸟类识别系统 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ............................…

使用Neo4j做技术血缘管理

目录 一、neo4j介绍 二、windows安装启动neo4j 2.1下载neo4j 2.2 解压文件 2.3 启动neo4j 三、neo4j基础操作 3.1 创建结点和关系 3.2 查询 3.3 更改 3.4 删除 四、技术血缘Demo实现 4.1 构建节点对象 4.2 构建存储对象 4.3 创建有属性关联关系 4.4 最后是图结果…

工业物联网接入网关在制造企业的实际应用-天拓四方

随着工业4.0和智能制造的兴起,工业物联网(IIoT)已成为工厂自动化的关键驱动力。在这个转变中,工业物联网网关扮演着至关重要的角色。它们充当了设备与企业系统之间的桥梁,实现了数据采集、分析和设备控制等功能。 案例…

微信开放平台第三方开发,实现代小程序认证申请

大家好,我是小悟 微信小程序认证整体流程总共分为五个环节:认证信息填写、平台初审、管理员验证、供应商审核和认证成功。 服务商可以代小程序发起认证申请。平台将对认证基础信息进行初步校验。通过后,平台将向管理员微信下发模板消息&…