- 66
- 0
- 约4.57千字
- 约 7页
- 2019-05-27 发布于浙江
- 举报
人工智能实验报告
学 号:
姓 名:
实验名称: 遗传算法
实验日期: 2016.1.5
【实验名称】 遗传算法
【实验目的】
掌握遗传算法的基本原理,熟悉遗传算法的运行机制,学会用遗传算法来求解问题。
【实验原理】
遗传算法(Genetic Algorithm)是模拟 \t /_blank 达尔文 \t /_blank 生物进化论的自然选择和 \t /_blank 遗传学机理的生物进化过程的计算 \t /_blank 模型,是一种通过模拟自然进化过程搜索 \t /_blank 最优解的方法。
遗传算法是从代表问题可能潜在的解集的一个 \t /_blank 种群开始的,而一个种群则由经过 \t /_blank 基因编码的一定数目的个体组成。每个个体实际上是 \t /_blank 染色体带有特征的实体。在一开始需要实现从 \t /_blank 表现型到基因型的 \t /_blank 映射即 \t /_blank 编码工作。由于仿照基因编码的工作很复杂,我们往往进行简化,如 \t /_blank 二进制编码,初代种群产生之后,按照适者生存和优胜劣汰的原理,逐代演化产生出越来越好的近似解,在每一代,根据问题域中个体的 \t /_blank 适应度大小选择个体,并借助于自然遗传学的遗传 \t /_blank 算子进行组合交叉和变异,产生出代表新的解集的种群。这个过程将导致种群像自然进化一样的后生代种群比前代更加适应于环境,末代种群中的最优个体经过 \t /_blank 解码,可以作为问题近似最优解。
遗传算法程度流程图为:
【实验内容】
题目:已知f(x)=x*sin(x)+1,x?[0,2p],求f(x)的最大值和最小值。
数据结构:
struct poptype
{
double gene[length];//染色体
double realnumber;//对应的实数x
double fitness;//适应度
double rfitness;//相对适应度
double cfitness;//累计适应度
};
struct poptype population[popsize+1];//最后一位存放max/min
struct poptype newpopulation[popsize+1];//
染色体编码:
,变量长度为2 π,取小数点后6位,由于
因此,染色体由23位字节的二进制矢量表示,则X与二进制串(b22 b21…… b0)2之间的映射如下:
;
适应度函数:
由于要求f(x)的最值,所以适应度函数即可为f(x)。但为了确保在轮赌法选择过中,每个个体都有被选中的可能性,因此需要将所有适应度调整为大于0的值。因此,设计求最大值的适应度函数如下:
将最小问题转化为求-f(x)的最大值,同理,设计最小值的适应度函数如下:
种群大小:
本实验默认为50,再进行种群初始化。
实验参数:
主要有迭代数,交叉概率,变异概率这三个参数。一般交叉概率在0.6-0.9范围内,变异概率在0.01-0.1范围内。可以通过手动输入进行调试。
主要代码如下:
void initialize()//种群初始化
{
srand(time(NULL));
int i,j;
for(i=0;ipopsize;i++)
for(j=0;j23;j++)
population[i].gene[j]=rand()%2;
void transform()//染色体转化为实数x
{
int i,j;
for(i=0;i=popsize+1;i++)
{
population[i].realnumber=0;
for(j=0;j23;j++)
population[i].realnumber+=population[i].gene[j]*pow(2,j);
population[i].realnumber=population[i].realnumber*2*pi/(pow(2,23)-1);
}
}
void cal_fitness()//计算适应度
{
int i;
for(i=0;ipopsize;i++)
population[i].fitness=population[i].realnumber*sin(population[i].realnumber)+6;
}
void sele
原创力文档

文档评论(0)