Python实现遗传算法(二进制编码)求函数最优值方式

作者:Mr_Leeeee 时间:2023-05-07 15:51:40 

目标函数

Python实现遗传算法(二进制编码)求函数最优值方式

编码方式

本程序采用的是二进制编码精确到小数点后五位,经过计算可知对于 Python实现遗传算法(二进制编码)求函数最优值方式 其编码长度为18,对于 Python实现遗传算法(二进制编码)求函数最优值方式 其编码长度为15,因此每个基于的长度为33。

参数设置

Python实现遗传算法(二进制编码)求函数最优值方式

算法步骤

设计的程序主要分为以下步骤:1、参数设置;2、种群初始化;3、用轮盘赌方法选择其中一半较好的个体作为父代;4、交叉和变异;5、更新最优解;6、对最有个体进行自学习操作;7结果输出。其算法流程图为:

Python实现遗传算法(二进制编码)求函数最优值方式

算法结果

由程序输出可知其最终优化结果为38.85029, Python实现遗传算法(二进制编码)求函数最优值方式

输出基因编码为[1 1 0 0 1 0 1 1 1 1 1 1 1 0 1 1 1 1 0 1 0 1 1 0 1 0 0 1 0 1 1 1 1]。

代码


import numpy as np
import random
import math
import copy

class Ind():
def __init__(self):
 self.fitness = 0
 self.x = np.zeros(33)
 self.place = 0
 self.x1 = 0
 self.x2 = 0

def Cal_fit(x, upper, lower): #计算适应度值函数
Temp1 = 0
for i in range(18):
 Temp1 += x[i] * math.pow(2, i)
Temp2 = 0
for i in range(18, 33, 1):
 Temp2 += math.pow(2, i - 18) * x[i]
x1 = lower[0] + Temp1 * (upper[0] - lower[0])/(math.pow(2, 18) - 1)
x2 = lower[1] + Temp2 * (upper[1] - lower[1])/(math.pow(2, 15) - 1)
if x1 > upper[0]:
 x1 = random.uniform(lower[0], upper[0])
if x2 > upper[1]:
 x2 = random.uniform(lower[1], upper[1])
return 21.5 + x1 * math.sin(4 * math.pi * (x1)) + x2 * math.sin(20 * math.pi * x2)
def Init(G, upper, lower, Pop): #初始化函数
for i in range(Pop):
 for j in range(33):
  G[i].x[j] = random.randint(0, 1)
 G[i].fitness = Cal_fit(G[i].x, upper, lower)
 G[i].place = i
def Find_Best(G, Pop):
Temp = copy.deepcopy(G[0])
for i in range(1, Pop, 1):
 if G[i].fitness > Temp.fitness:
  Temp = copy.deepcopy(G[i])
return Temp

def Selection(G, Gparent, Pop, Ppool): #选择函数
fit_sum = np.zeros(Pop)
fit_sum[0] = G[0].fitness
for i in range(1, Pop, 1):
 fit_sum[i] = G[i].fitness + fit_sum[i - 1]
fit_sum = fit_sum/fit_sum.max()
for i in range(Ppool):
 rate = random.random()
 Gparent[i] = copy.deepcopy(G[np.where(fit_sum > rate)[0][0]])

def Cross_and_Mutation(Gparent, Gchild, Pc, Pm, upper, lower, Pop, Ppool): #交叉和变异
for i in range(Ppool):
 place = random.sample([_ for _ in range(Ppool)], 2)
 parent1 = copy.deepcopy(Gparent[place[0]])
 parent2 = copy.deepcopy(Gparent[place[1]])
 parent3 = copy.deepcopy(parent2)
 if random.random() < Pc:
  num = random.sample([_ for _ in range(1, 32, 1)], 2)
  num.sort()
  if random.random() < 0.5:
   for j in range(num[0], num[1], 1):
    parent2.x[j] = parent1.x[j]
  else:
   for j in range(0, num[0], 1):
    parent2.x[j] = parent1.x[j]
   for j in range(num[1], 33, 1):
    parent2.x[j] = parent1.x[j]
  num = random.sample([_ for _ in range(1, 32, 1)], 2)
  num.sort()
  num.sort()
  if random.random() < 0.5:
   for j in range(num[0], num[1], 1):
    parent1.x[j] = parent3.x[j]
  else:
   for j in range(0, num[0], 1):
    parent1.x[j] = parent3.x[j]
   for j in range(num[1], 33, 1):
    parent1.x[j] = parent3.x[j]
 for j in range(33):
  if random.random() < Pm:
   parent1.x[j] = (parent1.x[j] + 1) % 2
  if random.random() < Pm:
   parent2.x[j] = (parent2.x[j] + 1) % 2

parent1.fitness = Cal_fit(parent1.x, upper, lower)
 parent2.fitness = Cal_fit(parent2.x, upper, lower)
 Gchild[2 * i] = copy.deepcopy(parent1)
 Gchild[2 * i + 1] = copy.deepcopy(parent2)

def Choose_next(G, Gchild, Gsum, Pop): #选择下一代函数
for i in range(Pop):
 Gsum[i] = copy.deepcopy(G[i])
 Gsum[2 * i + 1] = copy.deepcopy(Gchild[i])
Gsum = sorted(Gsum, key = lambda x: x.fitness, reverse = True)
for i in range(Pop):
 G[i] = copy.deepcopy(Gsum[i])
 G[i].place = i

def Decode(x):   #解码函数
Temp1 = 0
for i in range(18):
 Temp1 += x[i] * math.pow(2, i)
Temp2 = 0
for i in range(18, 33, 1):
 Temp2 += math.pow(2, i - 18) * x[i]
x1 = lower[0] + Temp1 * (upper[0] - lower[0]) / (math.pow(2, 18) - 1)
x2 = lower[1] + Temp2 * (upper[1] - lower[1]) / (math.pow(2, 15) - 1)
if x1 > upper[0]:
 x1 = random.uniform(lower[0], upper[0])
if x2 > upper[1]:
 x2 = random.uniform(lower[1], upper[1])
return x1, x2

def Self_Learn(Best, upper, lower, sPm, sLearn): #自学习操作
num = 0
Temp = copy.deepcopy(Best)
while True:
 num += 1
 for j in range(33):
  if random.random() < sPm:
   Temp.x[j] = (Temp.x[j] + 1)%2
 Temp.fitness = Cal_fit(Temp.x, upper, lower)
 if Temp.fitness > Best.fitness:
  Best = copy.deepcopy(Temp)
  num = 0
 if num > sLearn:
  break
return Best

if __name__ == '__main__':
upper = [12.1, 5.8]
lower = [-3, 4.1]
Pop = 100
Ppool = 50
G_max = 300
Pc = 0.8
Pm = 0.1
sPm = 0.05
sLearn = 20
G = np.array([Ind() for _ in range(Pop)])
Gparent = np.array([Ind() for _ in range(Ppool)])
Gchild = np.array([Ind() for _ in range(Pop)])
Gsum = np.array([Ind() for _ in range(Pop * 2)])
Init(G, upper, lower, Pop)  #初始化
Best = Find_Best(G, Pop)
for k in range(G_max):
 Selection(G, Gparent, Pop, Ppool)  #使用轮盘赌方法选择其中50%为父代
 Cross_and_Mutation(Gparent, Gchild, Pc, Pm, upper, lower, Pop, Ppool) #交叉和变异生成子代
 Choose_next(G, Gchild, Gsum, Pop)  #选择出父代和子代中较优秀的个体
 Cbest = Find_Best(G, Pop)
 if Best.fitness < Cbest.fitness:
  Best = copy.deepcopy(Cbest)  #跟新最优解
 else:
  G[Cbest.place] = copy.deepcopy(Best)
 Best = Self_Learn(Best, upper, lower, sPm, sLearn)
 print(Best.fitness)
x1, x2 = Decode(Best.x)
print(Best.x)
print([x1, x2])

来源:https://blog.csdn.net/zhenguipa8450/article/details/78938303

标签:Python,遗传算法,函数,最优值
0
投稿

猜你喜欢

  • 使用PHP获取当前url路径的函数以及服务器变量

    2023-10-31 02:31:34
  • 使用pdb模块调试Python程序实例

    2023-08-11 08:36:28
  • JS实现二维数组横纵列转置的方法

    2023-08-29 21:54:05
  • Python实现简单状态框架的方法

    2022-08-20 14:13:44
  • 新年快乐! python实现绚烂的烟花绽放效果

    2022-01-15 13:18:00
  • 用XsltArgumentList实现xsl的参数调用

    2008-09-04 11:24:00
  • 像表格一样用DIV+CSS给网页布局

    2008-10-18 15:45:00
  • python中pytest收集用例规则与运行指定用例详解

    2021-12-01 14:23:21
  • python钉钉机器人运维脚本监控实例

    2022-08-23 22:19:48
  • Python转json时出现中文乱码的问题及解决

    2021-11-29 17:02:16
  • 在asp中调用sql server的存储过程方法

    2007-08-13 13:28:00
  • php使用socket简单实现通信功能

    2023-05-31 13:01:23
  • jupyter notebook清除输出方式

    2021-05-08 02:51:13
  • ASP程序代码执行时间统计类

    2007-10-15 12:45:00
  • 详细介绍Python函数中的默认参数

    2021-02-14 09:41:47
  • SQL“多字段模糊匹配关键字查询”

    2008-04-24 14:16:00
  • 对于Python装饰器使用的一些建议

    2022-05-26 09:05:43
  • python实现简单俄罗斯方块游戏

    2023-04-13 03:28:05
  • MySQL数据库与表的最基本命令大盘点

    2010-08-31 14:29:00
  • Python之os模块案例详解

    2021-06-18 15:09:38
  • asp之家 网络编程 m.aspxhome.com