进击的小白Day021——遗传算法(三)

这次不在上次的基础上改了,先自己根据流程 写一遍,然后再优化修改。

遗传算法概念及流程:
1、问题描述:
在这里插入图片描述
求极小值。
2、概念介绍
(1)种群、个体、染色体、基因
数学模型的一个可行解成为一条染色体(也可以称之为个体),一个可行解有多个元素组成,因此每个元素成为一个基因,一组(人为设定值,用n表示)可行解组合起来就形成了种群。
在这个问题中,1种群=n个体=n染色体=5n基因

今天实现了种群初始化、适应度计算、选择概率和累计概率计算这几个步骤,贴代码:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define PI 3.1415926
#define BOUND_DOWN 0
#define BOUND_UP (0.9 * PI)
#define POP_SIZE 4
#define CHROM_LEN 5
#define EVO_NUM 500

/*目标函数值*/
float objFuncVal(float *a)
{
	float x[5];
	float f = 0;
	memset(x, 0, sizeof(x));
	x[0] = *a;
	x[1] = *(a + 1);
	x[2] = *(a + 2);
	x[3] = *(a + 3);
	x[4] = *(a + 4);
	f = -5 * sin(x[0])*sin(x[1])*si
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值