进化算法

作者: chenmingang | 来源:发表于2016-12-05 21:47 被阅读66次

blog
嗯,写个东西玩,这就是很像进化的进化算法.

进化算法是以达尔文的进化论思想为基础,通过模拟生物进化过程与机制的求解问题的自组织、自适应的人工智能技术。生物进化是通过繁殖、变异、竞争和选择实现的;而进化算法则主要通过选择、重组和变异这三种操作实现优化问题的求解。

首先生成一个随机位置的"太阳",然后生成一堆位置随机会移动会光合作用,会呼吸作用的生命.靠近"太阳"将可以进行"光合作用",否则就只能进行"呼吸作用"消耗生命,当生命值消耗完就die了,当生命值很健康时有一定几率产生后代.

import random
import math
import pylab
import matplotlib.animation as animation
#一个太阳
sunCoordX = random.randint(1,99)
sunCoordY = random.randint(1,99)
#一堆生命
lifes = []

class Life(object):
 """一个会移动会光合会呼吸的生命"""
 def __init__(self, name):
  #super(Life, self).__init__()
  self.name = name
  self.x = random.randint(1,99)
  self.y = random.randint(1,99)
  self.hp = random.randint(0,99)
  self.agility = random.randint(1,5)
  self.cos = self.cosWithSun()
  #一系列生化反应
 def live(self):
  self.move()
  self.costHp()
  self.photosynthesis()
  self.birth()
  #运动
 def move(self):
  self.x += round(random.randint(-self.agility,self.agility))
  self.y += round(random.randint(-self.agility,self.agility))
  if(self.x<=0):
   self.x = 1
  if(self.y<=0):
   self.y = 1
  self.cos = self.cosWithSun()
  if(self.cos<5 and self.agility<10):
   self.agility +=1
   

 def printMe(self):
  if(self.hp>0):
   print "%s" % (self.name)
   print "[cos:%f,x:%d,y:%d,hp:%d,agility:%d]" % (self.cos,self.x,self.y,self.hp,self.agility)
 #靠近太阳 光合作用
 def photosynthesis(self):
  self.cos = self.cosWithSun()
  if(self.cos<15):
   #print "photosynthesis"
   self.hp +=11
if(self.agility>1):
    self.agility -=1
 #呼吸 消耗生命值
 def costHp(self):
  self.hp -=10
  if(self.hp<=0):
   self.die()
 def die(self):
  print "%s die"%(self.name)
  lifes.remove(self)
 def cosWithSun(self):
  cos = math.sqrt((sunCoordX-self.x)**2+(sunCoordY-self.y)**2)
  #print "%d %d %d %d %d" % (sunCoordX,sunCoordY,self.x,self.y,cos)
  return cos
 #生小的
 def birth(self):
  if(random.randint(0,10)<2 and self.hp>70 and len(lifes)<2000):
   child = Life(self.name+"_child")
   child.x=self.x
   child.y=self.y
   child.hp=self.hp+1
   child.agility=self.agility
   lifes.append(child)

j=0
while(j<50):
 life = Life("life%d"%(j))
 lifes.append(life)
 j+=1

fig = pylab.figure()  
scat1 = pylab.scatter(1, 1, s=10,color='blue')  
scat2 = pylab.scatter(1, 1, s=50,color='red')  
pylab.xticks([0, 25, 50, 75, 100])
pylab.yticks([0, 25, 50, 75, 100])
def setup_plot():  
 return scat1,scat2

def update_plot(i):
 print "lives num %d"%len(lifes)
 data = []
 for l in lifes:
  #l.printMe()
  data.append(l.x)
  data.append(l.y)
  l.live()
 scat1.set_offsets([data])
 scat2.set_offsets([sunCoordX,sunCoordY])
 return scat1, scat2

ani = animation.FuncAnimation(fig, update_plot, interval=50, init_func=setup_plot, blit=True)
pylab.show()  

相关文章

  • 遗传算法详解

    遗传算法(Genetic Algorithm)又叫基因进化算法,或进化算法。属于启发式搜索算法一种,这个算法比较...

  • 进化算法

    blog嗯,写个东西玩,这就是很像进化的进化算法. 进化算法是以达尔文的进化论思想为基础,通过模拟生物进化过程与机...

  • 收入倍增计划 #1000计划

    在收入倍增计划的微信文章中,主要提到两个引起思考的算法:生涯规划进化算法、阶层规划进化算法 生涯规划进化算法 生涯...

  • 离开T209 | 9 进化师

    9 进化师 本节概要:菲利普的状况令人担忧,但缥岩区域在进化算法下越来越适宜人类居住。进化师凡塞尔认为进化算法能让...

  • 遗传算法(Genetic Algorithm)

    遗传算法(GA, Genetic Algorithm)是进化算法(EA, Evolutionary Algorit...

  • 优化算法笔记(七)差分进化算法

    1. 差分进化算法简介 (以下描述,均不是学术用语,仅供大家快乐的阅读)差分进化算法(Differential E...

  • 进化算法

    进化算法,也被成为是演化算法(evolutionary algorithms,简称EAs),它不是一个具体的算法,...

  • 进化算法

    进化只是一种算法,这个算法设定了一个目标,挑你觉得最好的方式去做决策,这就是大脑

  • ERL:ES-NES-CMA-ES-GA

    进化策略 ES 遗传算法 GA 交叉熵方法 CME 协方差自适应进化策略 CMA-ES 进化策略 Evolutio...

  • 遗传算法简析

    遗传算法(genetic algorithm (GA))是用于解决最优化的搜索算法,是进化算法的一种。遗传算法基于...

网友评论

    本文标题:进化算法

    本文链接:https://www.haomeiwen.com/subject/kgslmttx.html