热门课程

免费试听

上课方式

开班时间

当前位置: 首页 -   文章 -   新闻动态 -   正文

遗传算法之二进制编码使用办法

知了堂姐
2024-07-08 17:22:16
0

遗传算法之二进制编码使用办法


编码

把所需要选择的特征进行编号,每一个特征就是一个基因,一个解就是一串基因的组合。为了减少组合数量,在图像中进行分块,然后把每一块看成一个基因进行组合优化的计算。每个解得基因数量是要通过实验确定的。


遗传算法不能直接处理问题空间的参数,必须把它们转换成遗传空间的由基因按一定结构组成的染色体或个体。这一转换操作就叫做编码。评估编码策略常采用以下 3 个规范。

(1) 完备性(Completeness): 问题空间中的所有点(候选解)都能作为 GA 空间中的点(染色体)表现。

(2) 健全性(Soundness): GA 空间中的染色体能对应所有空间中的候选解。

(3) 非冗余性(Nonredundancy): 染色体和候选解一一对应。


目前几种常用的编码技术有二进制编码、浮点数编码、字符编码、编程编码等。二进制编码是遗传算法中最常见的编码方法,即由二进制字符集 {0, 1} 产生通常的 0, 1 字符串来表示问题的候选解。它具有以下特点:


(1) 简单易行;

(2) 符合最小字符集编码原则;

(3) 便于用模式定理进行分析。


染色体编码最常用的是二进制编码,对于离散性变量直接进行编码,对于连续性变量先离散化后再编码。


SPSS常用的基础操作——连续变量离散化


在工业界,很少直接将连续值作为逻辑回归模型的特征输入,而是将连续特征离散化为一系列0、1特征交给逻辑回归模型,这样做的优势有以下几点:

0. 离散特征的增加和减少都很容易,易于模型的快速迭代;

1. 稀疏向量内积乘法运算速度快,计算结果方便存储,容易扩展;

2. 离散化后的特征对异常数据有很强的鲁棒性:比如一个特征是年龄>30是1,否则0。如果特征没有离散化,一个异常数据“年龄300岁”会给模型造成很大的干扰;

3. 逻辑回归属于广义线性模型,表达能力受限;单变量离散化为N个后,每个变量有单独的权重,相当于为模型引入了非线性,能够提升模型表达能力,加大拟合;

4. 离散化后可以进行特征交叉,由M+N个变量变为M*N个变量,进一步引入非线性,提升表达能力;

5. 特征离散化后,模型会更稳定,比如如果对用户年龄离散化,20-30作为一个区间,不会因为一个用户年龄长了一岁就变成一个完全不同的人。当然处于区间相邻处的样本会刚好相反,所以怎么划分区间是门学问;

6. 特征离散化以后,起到了简化了逻辑回归模型的作用,降低了模型过拟合的风险。


李沐曾经说过:模型是使用离散特征还是连续特征,其实是一个“海量离散特征+简单模型” 同 “少量连续特征+复杂模型”的权衡。既可以离散化用线性模型,也可以用连续特征加深度学习。就看是喜欢折腾特征还是折腾模型了。通常来说,前者容易,而且可以n个人一起并行做,有成功经验;后者目前看很赞,能走多远还须拭目以待。


举个例子

已知一元函数:

F(x) = xsin(10pi*x)+2 x∈[-1, 2]

现在要求在既定的区间内找出函数的最大值。

首先我们可以先用 MATLAB 把该函数的图像画出来:

clc, clear;

syms f(x); % 声明函数

x = linspace(-1,2,3000); % 定义 x, x 属于 [-1, 2]

f = x.*sin(10*pi.*x)+2; % 定义函数,因为 x 是向量,所以采用点乘

plot(f); % 画图

然后做出图形如下:

把所需要选择的特征进行编号,每一个特征就是一个基因,一个解就是一串基因的组合。为了减少组合数量,在图像中进行分块,然后把每一块看成一个基因进行组合优化的计算。每个解得基因数量是要通过实验确定的

我们可以看到,该图形显示说明该函数具有多个局部最优解,所以适合用遗传算法进行求解。


由遗传算法的基本步骤可知我们第一步应该是编码:


二进制编码


受到人类染色体结构的启发,我们可以设想一下,假设目前只有 0 和 1 两种碱基,我们也用一条链把它们有序的串连在一起,因为每一个单位都能表现出 1bit 的信息量,所以一条足够长的染色体就能为我们勾勒出一个个体特征的所有特征。这就是二进制编码


下面将介绍如何建立二进制编码到一个实数的映射。


明显地,一定长度的二进制编码序列,只能表示一定精度的浮点数。譬如我们要求小数点后精确到六位小数,由于区间长度为

2 - (-1) = 3

为了保证精度的要求,至少把区间 [-1, 2] 分为 3*10^6 等份。又因为

2097152=2^21 < 3*10^6 < 2^22=4194304

所以编码的二进制串至少有 22 位。

把一个二进制串 (b1b2…bn) 转换为区间里面对应的实数值通过下面两个步骤。

(1) 将一个二进制串代表的二进制转换为十进制数:

(2) 对应区间的实数:

或许有人并不知道是如何把数值转换到对应区间的实数的,为什么要这么做?我也是问了一下我的小伙伴才知晓的,下面我来简单的说一下:

通常我们归一化到 [0, 1],有时候我们需要归一化到其它区间,这样算一下就可以找到数列的最小值 m 及最大值 M,如果指定的区间是 [a, b],即:

m-->a, M-->b;

系数为:

k = (b-a)/(M-m)

对任意项Xn:变成:

X = a+k(Xn-m)

将十进制转换为二进制的 MATLAB 程序代码如下:

%% 将十进制数转换为二进制数(二进制编码)

% @params dec_num 十进制数

% @params N    需保留的二进制小数位数

function bin_num = encode(dec_num, N)

split = '.';

if rem(dec_num, 1) == 0

bin_num = dec2bin(dec_num);

float_num = zeros(1, N);

    bin_num = strcat(num2str(bin_num), split);

    bin_num = strcat(bin_num, num2str(float_num));

else

remainder = rem(dec_num, 1); % 小数部分

integer = floor(dec_num); % 整数部分

bin_num_int = dec2bin(integer);

i = 1;

flag = true;

while(flag == true)

      remainder = remainder*2;

if (i > N) % 是否满足精度

return;

end

if remainder > 1

record(i) = 1;

        remainder = rem(remainder, 1);

else if remainder == 1

record(i) = 1;

remainder = rem(remainder, 1);

else

record(i) = 0;

end

i = i+1;

end

bin_num_flt = record;

bin_num = strcat(num2str(bin_num_int), split);

bin_num = strcat(bin_num, num2str(bin_num_flt));

    end

  end

end



预约申请试听课
大家都在看

成都现在培训java开发的培训机构多吗? 有靠谱...

2024-07-08 浏览次数:0

华为鸿蒙原生应用开发启动:接入鸿蒙设备数量超7亿...

2024-07-08 浏览次数:0

女生适合做等保测评师吗?等保测评工作内容

2024-07-08 浏览次数:0

坚持发展产教融合,做好高校、人才与企业之间的桥梁

2024-07-08 浏览次数:0

庆双节¥ 19.9拼团啦!六大项目源码助你实操练...

2024-07-08 浏览次数:0

零基础学网络安全培训课程怎么样?

2024-07-08 浏览次数:0
最新资讯
a, M-->b;

系数为:

k = (b-a)/(M-m)

对任意项Xn:变成:

X = a+k(Xn-m)

将十进制转换为二进制的 MATLAB 程序代码如下:

%% 将十进制数转换为二进制数(二进制编码)

% @params dec_num 十进制数

% @params N    需保留的二进制小数位数

function bin_num = encode(dec_num, N)

split = '.';

if rem(dec_num, 1) == 0

bin_num = dec2bin(dec_num);

float_num = zeros(1, N);

    bin_num = strcat(num2str(bin_num), split);

    bin_num = strcat(bin_num, num2str(float_num));

else

remainder = rem(dec_num, 1); % 小数部分

integer = floor(dec_num); % 整数部分

bin_num_int = dec2bin(integer);

i = 1;

flag = true;

while(flag == true)

      remainder = remainder*2;

if (i > N) % 是否满足精度

return;

end

if remainder > 1

record(i) = 1;

        remainder = rem(remainder, 1);

else if remainder == 1

record(i) = 1;

remainder = rem(remainder, 1);

else

record(i) = 0;

end

i = i+1;

end

bin_num_flt = record;

bin_num = strcat(num2str(bin_num_int), split);

bin_num = strcat(bin_num, num2str(bin_num_flt));

    end

  end

end



上一篇:ONGL表达式主要用途及使用方法

下一篇:Linux包过滤防火墙工作方法

相关内容

热门资讯

就业课程介绍(Java+前端+... Java+大数据,前端全栈,信息安全
关于我们 请输入文章描述
0基础转行信安,他如何做到月薪... 转行并非简单的换份工作,而是我们在职场进行自我认同、重塑身份的一个过程。今天知了小姐姐为大家介绍一位...
img标签的onerror事件... 1.img 标签除了 onerror 属性外,还有其他获取管理员路径的办法吗? src 指定一个远程...
cisp考试费用多少?cisp...   随着网络技术的快速发展,网络安全问题变得越来越重要。那么,CISP考试费用多少?CISP报名条件...
【前端每日一题】什么是BFC?... 秋招马上就要开始了,小伙伴们最近在准备面试的东西没呢,知了姐今天将蛋糕哥整理的前端面试题共享出来,同...
pythone 文件和数据格式... 关于 Python 对文件的处理,以下选项中描述错误的是
网络安全运维岗面试题及答案详解... 在当今数字化时代,网络安全运维工程师的角色变得愈发重要。为了保障网络安全,各个企业都需要拥有一支经验...
知了堂官网V3第一版内测邀请 经过几个月的加班加点,我们终于迎来了知了堂官网3.1.0版本 现正招募内测中
川农第一次线下拓展精彩瞬间 5月15日,知了堂的哥哥姐姐们携手企业拓展教练浩浩荡荡奔赴川农。
-->