京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 8857|回复: 0

英特尔“演化算法”新框架:29个Python代码块,自动生成新算法

[复制链接]

10

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2019-4-13 00:53:30 | 显示全部楼层 |阅读模式 来自 中国
新智元报道 % x0 c. W1 Z: ~, ^: `& p7 h4 P
编辑:大明& M: l" m: s9 ~8 t) [2 |
【新智元导读】英特尔的研究人员提出一种新的自动算法生成器(AAD),利用演化算法框架,以Python语言的基本子集作为语法架构,能够对29个数组/向量问题的代码块进行组合,通过学习,自动生成更复杂问题的解决方案。" i; X  n( t- N9 ?( {& ~2 E2 W" Q

: Y7 Z* Y: d, P: J. T' J) q( B本文介绍一种自动算法发现器(AAD),这是一种用于合成高复杂度计算程序的演化算法框架。此前的演化算法依赖于客观的适应函数,这在给算法设计上增加了难度。- r  @6 |4 i& Q& F1 q
本文提出的AAD采用问题式引导演化过程(PGE),这需要将一组问题一起引入,针对更简单问题发现解决方案,用于解决同一组问题中的更复杂的问题。 PGE还支持几种新的进化策略,并自然地应用于高性能计算(HPC)技术。1 E$ B9 ~9 t( l6 V* Z0 C: m: b) k

$ C1 q* ?2 i5 A7 ]7 AAAD可以为29个数组/向量问题生成Python代码,范围从min,max,reverse到更具挑战性的问题,如排序和矩阵向量乘法。此外,AAD显示出对受限环境/受限输入的强适应性,以及针对“开箱即用”的问题的解决能力。
- c3 d! w+ L# N& T7 ?3 XAAD是将相对简单的问题解决组件自动组合程序,可以实现搜索由这些组件的所有可能排列所组成的整个空间,然后寻找满足给定要求的解决方案。目前已经提出了许多这样的搜索策略(例如枚举,基于演绎,约束求解,随机)来应对这类挑战。
$ I1 |1 ]' _. s' _  x
8 {% F' R9 ]/ P使用AAD的分类算法代码块示例2 k( U) c& f4 c1 C2 P
本文提出了一种基于演化算法的搜索策略,将其AAD中实现。AAD可以基于Python的子集作为语法结构,组合成复杂度相对较高的程序(循环,嵌套块,嵌套函数调用等),并生成可执行的Python代码。在本文中使用AAD来发现数组/向量问题的算法解决方案。
& [4 ]: K5 t: v$ Y3 Y: X$ x
& D6 ]) f. C: |* u9 n2 [9 ^总的来说,AAD实现了以下目标:6 `; Q3 F3 P$ A% f+ M4 b9 J- _# a

    1 D/ Q2 K8 M- m3 j
  • 使用问题导向型的演化策略来消除算法中的目标函数。
    : g+ w3 z& f9 g! l" U# K: F: N% d
  • 使用多样化的演化策略(多环境解决方案,异花授粉和联合演化),并通过广泛的实验评估其有效性。
    , O# w& L" }5 s; C/ y+ ^, e
  • 利用AAD解决通用Python语言中的29个数组/向量问题,表明演化算法能够解决复杂的新问题。
    $ \$ C: d- [$ ]6 }2 r# G
  • 支持循环模块,可以发现任何(非零)输入的算法。
    4 D, k( d* p# p5 u: N. l7 f2 p0 D
AAD结构设计方案和原理 3 ]; S) |5 M0 N2 L5 W. w7 @
AAD主要架构示意图,主要由问题生成器、解决方案生成器和检测器组成
8 q5 H: c, h: C1 F问题生成器(ProbGen)( v: }; I6 k9 F. B5 \  ~% j! [8 S
我们想要解决的每个问题都从问题生成器开始。 这部分负责:(1)指定输入和输出的数量和类型。(2)为给定的问题生成输入。例如,对于最大查找(Max),问题生成器指定Max将一个数组作为输入,并生成一个数字作为输出。另外,当请求为大小为N的问题生成输入时,会产生一个由N个数字组成的输入数组。
# x! |( ~. k9 n1 m检测器(Checker)" T4 `/ |& ?  S' U; f6 m
检测器负责接受/拒绝为给定问题生成解决方案。 检测器使用问题生成器生成的输入执行生成的程序,并生成输出。检测器中包含接受/拒绝输出的逻辑。因此,检测器与给定的问题生成器对应,两者齐头并进。, X! Z$ }" a+ R+ k
检测器不一定真正需要实现其想要发现的算法。比如,针对“排序问题”的检测器不必对真的对输入数组进行排序,而是可以比较输出数组中的每两个相邻元素,并查看这两个元素是否按预期顺序排列。一旦检测到未排序数据对,检测器会做出“失败”的声明。如果每对相邻元素都是有序的,并且输出数组中包含的元素与输入数组完全相同,则检测器宣布可接受该解决方案。. P2 e/ f2 B; q1 i( s) h, X
解决方案生成器(SolGen)
) f7 U9 j" P$ H0 ?1 j5 G6 }3 iSolGen主要由两部分组成:(1)表达式/短语存储,以及(2)演化器。
8 L! ~: o9 O. V0 b表达式/短语存储器(ExpStore)' m& T0 {; V4 N" s7 k: o
解决方案生成器使用语法构造源程序。 AAD使用的Python语法子集存储在ExpStore中,如表1所示。在AAD中,语法规则使用类型信息进行扩充。9 ~' a& ~5 M" ~& x" V* T
AAD支持四种数据类型:数字(NUM),布尔数(BOOL),数组(ARR)和数组的数组(AoA),它们可以对矩阵进行建模。此外,表达式的每个操作数都标记为Consumer(只读),Producer(只写)或ProdCon(读-修改-写)。9 S7 n  T4 o( m5 {' |: Y
演化器(Evolver)
2 p$ C$ f5 `$ a6 |' k; M- I! B演化器负责对表达式和短语进行组合,以生成程序(或函数),以解决问题生成器提出的问题。演化器分三个阶段构建解决函数(SolFunc)。
$ {7 |6 P/ K. y) c
    0 e1 u% w6 g1 \9 N$ X. T9 e
  • 阶段1:构建解决函数
    3 ]3 q( u' D- _; G8 J! H- P3 Q
  • 阶段2:在“生产者”(只写数据)和“消费者”(只读数据)间建立联系
    2 j& |6 ?: \, g4 q
  • 阶段3:操作和函数调用突变% l$ A9 J+ e8 s% Z
检查输出
2 e3 j& f8 F  S" z# t一旦解决函数构建出来,就会执行这个函数,使用Python的exec函数生成输出结果。检测器负责检查输出,判定接受或拒绝输出。如果第一个输出被接受,则使用问题生成器生成的更多不同大小的、与输入测试相同的解决函数。如果检测器接受了所有测试,则该解决函数即被声明为该问题的解决方案。上述三个阶段构成了一个循序渐进的步骤。% G# n# S3 v1 U' y: C: c3 \

0 Y# d7 W  \. C: ]) i! L上表所示为在问题集A中的调用者-被调用者的关系。比如SortDesc函数所在的行显示,SortAsc在57%的解决方案中调用了Max函数,在14%的解决方案中调用了Min函数,以此类推。Min,Max和ReverseArr函数没有调用任何其他函数。所有其他函数都依赖于一个或多个函数来得到解决方案,显示出函数组合的重要性。
, }! x, |2 s) x0 ~4 w4 I7 V" j# u' y) e, d

, @! ^8 a8 i& u  y! }上表中列出了3组问题以及在基线方法下的步数表现,并将其与四种演化策略下的表现进行了对比。- m) @2 @9 c8 H2 F% Z. |( S2 {
未来前景与应用方向从概念上讲,AAD也可用于程序翻译。对于用C语言,汇编语言甚至二进制语言编写的程序,可以执行该实例作为AAD的检测器来生成Python(或类似语言)代码。这种方式与仅通过观察另一个对象行为,来构建自身行为方式的机器学习算法类似。很明显,本文中使用的Python代码可以被视为“Python到Python”的翻译,因为不同的检测器对应了不同的Python实现。
( E! T, B# w# G$ T; z8 eAAD可能不仅仅是一个程序合成器。它还可以用来获取机器的内在知识。通过调用-被调用关系图和父子图捕捉不同问题之间的内在关系。这些关系是由AAD本身发现的,并且可以被认为是不同操作之间的联想记忆的一种表示,其形式与人类大脑构造和机制类似。
: I# x8 @  o" u( r* o由于AAD可以通过引入越来越多的问题来增加知识储备的扩展,通过适当的指导机制,就可以引导系统获取大量技能(算法),并自己构建知识表示。就像我们在自己孩子还小时,向TA们提出许多问题和挑战,目的是为了引导孩子们获得大量技能和知识。5 f# W, Y/ Z; W3 v, G
AAD是用于综合高复杂度程序的演化框架,它以Python语言的基本子集作为语法架构。使用AAD能够对29个数组/向量问题的代码块进行组合,其中既有最大值、最小值,矩阵翻转这类简单问题,也有更具挑战性的问题,如排序和矩阵向量乘法等,对于输入没有大小限制。7 a8 u* I5 F9 j' |3 t5 X* t  e
我们评估了解决这些问题策略的有效性,并证明了AAD具备解决“开箱即用”问题的能力。为了应对复杂需求带来的各种挑战,AAD工具还能实现与高性能计算(HPC)技术的结合。总的来说,与现有技术相比,采用PGE的演化算法能够解决类似或更高复杂性的问题。
; ~1 f* j6 P. `" c5 W' v0 h  G6 W论文链接:* }! n$ W$ l$ Z4 W: Z- @
【2019新智元 AI 技术峰会精彩回顾3 C$ \1 {  ~; ~0 e
2019年3月27日,新智元再汇AI之力,在北京泰富酒店举办AI开年盛典——2019新智元AI技术峰会。峰会以“智能云•芯世界“为主题,聚焦智能云和AI芯片的发展,重塑未来AI世界格局。, F# P; v0 {. F1 c. i* T/ P2 q
同时,新智元在峰会现场权威发布若干AI白皮书,聚焦产业链的创新活跃,评述AI独角兽影响力,助力中国在世界级的AI竞争中实现超越。9 ?* x9 E! y! W
6 ?# E: a0 M8 i2 O  C
7 `+ e; s$ `/ ~1 u
来源:http://www.yidianzixun.com/article/0LiLzwbS( i! b- H* j; O; H! S6 l! g
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-3-18 03:06 , Processed in 0.037457 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表