声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 761|回复: 2

[编程技巧] 关于在遗传算法解码中遇到的矩阵生成问题

[复制链接]
发表于 2008-5-9 11:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
我在处理遗传算法的染色体的解码中遇到一下问题:
例如:编码串【1| 010】 译为:【1 1】
                      【0|101】 译为:【0 0 0 0 0】
‘|’前的一位为码值;
‘|’后的三位转为十进制后即为码长;

于是我遇到一下问题
经过染色体处理后我得到染色体码值位矩阵
A=[1 0 1 1 0];
以及 码长矩阵
B=[2 1 3 2 1];
最终应得到
C = [ 1 1 ,0 , 1 1 1 ,1 1 ,0];
谢谢大家!
为提高效率还是考虑不用循环的好

[ 本帖最后由 eight 于 2008-5-12 17:33 编辑 ]
回复
分享到:

使用道具 举报

 楼主| 发表于 2008-5-9 13:02 | 显示全部楼层
这个问题想了很久没头绪;
其就是产生【1 2 2 3 3 3 4 4 4 4】矩阵的问题。
不过 如果遗传算法采用二进制码的话解码就很容易,

bin =[ 1     1     1     0];
bit = cumprod(2*ones(length(bin) ,1),1)/2;
f = bin*bit(end:-1:1);
发表于 2008-5-9 13:49 | 显示全部楼层
我也想了好一会,不过避不开循环;但觉得也不会太影响运行效率.

A=[1 0 1 1 0];
B=[2 1 3 2 1];
a=int2str(A');
for k=1:length(A),
      C{k}=repmat(a(k),1,B(k));
end
disp(C);


    '11'    '0'    '111'    '11'    '0'
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-5-16 04:23 , Processed in 0.055024 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表