遗传算法染色体与信道分配映射关系MATLAB代码实现求助

遗传算法 专栏收录该内容
1 篇文章 0 订阅

这是利用遗传算法来进行信道分配代码的一部分,就剩一个问题解决不了,导致整个程序都不能运行。哪位大神指点一下,一般来说染色体与信道分配策略之间的映射关系是怎样的实现的吗?也就是说,在这一段代码中要怎样定义L1才能使整段程序运行呢?
function [opt_solution,opt_reward]=genetic_algorithm(T,population,P_crossover,P_mutation,L1,B,C)
%T 迭代次数
%population 每一代个体数
%P_crossover 交叉概率
%P_mutation 变异概率
%L1 染色体与信道分配策略的映射关系
%B 效益矩阵
%C 干扰矩阵
temp=size(L1);
L=temp(3);%染色体长度
chromesome=randsrc(population,L,[0,1;0.5,0.5]);%初始化群体中所有个体的染色体
fitness=zeros(1,population);
Best_solution=zeros(1,L,T);%存储每一代的最优解
opt_solution=zeros(1,L);%存储全局最优解
opt_reward=zeros(1,T);
for t=1:1:T

for i=1:population
    chromesome(i,:)=check_modify(chromesome(i,:),L1,C);%检查染色体是否符合约束条件,不符合则略作改动,使之符合
    fitness(i)=reward(chromesome(i,:),L1,B);%计算各个染色体的适应度
end

for i=1:population
    if(reward(Best_solution(:,:,t),L1,B)<reward(chromesome(i,:),L1,B))
        Best_solution(:,:,t)=chromesome(i,:);%寻找每一代的最优个体
    end
end
if(reward(Best_solution(:,:,t),L1,B)>reward(opt_solution,L1,B))
    opt_solution=Best_solution(:,:,t);%寻找全局最优解
    opt_reward(t)=reward(opt_solution,L1,B);
elseif(t>1)
    opt_reward(t)=opt_reward(t-1);
end
if(t==T)
   break;%进行到第T代后,不需要再进行T+1代的繁殖操作,因此跳出循环 
end

chromesome=wheel_select(chromesome,fitness);%根据轮盘选择方法选择population个染色体进入繁殖池
temp=randsrc(1,population,[0,1;1-P_crossover,P_crossover]);%选择繁殖池中需要交叉的染色体
N_crossover=sum(temp);
if(mod(N_crossover,2)~=1)
    N_crossover=N_crossover-1;%确保交叉的染色体数位偶数
end
if(N_crossover~=0)
   [a,b]=sort(temp,'descend'); 
    for i=1:N_crossover/2
        [chromesome(b(2*i-1)),chromesome(b(2*i))]=crossover(chromesome(b(2*i-1)),chromesome(b(2*i)));
    end
end
temp=randsrc(population,L,[1,0;P_mutation,1-P_mutation]);%变异矩阵
chromesome=mod(chromesome+temp,2);%变异

end

end

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

新的改变

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

功能快捷键

撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
查找:Ctrl/Command + F
替换:Ctrl/Command + G

合理的创建标题,有助于目录的生成

直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。

如何改变文本的样式

强调文本 强调文本

加粗文本 加粗文本

标记文本

删除文本

引用文本

H2O is是液体。

210 运算结果是 1024.

插入链接与图片

链接: link.

图片: Alt

带尺寸的图片: Alt

居中的图片: Alt

居中并且带尺寸的图片: Alt

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。2

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

Mon 06 Mon 13 Mon 20 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.2.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. mermaid语法说明 ↩︎

  2. 注脚的解释 ↩︎

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:深蓝海洋 设计师:CSDN官方博客 返回首页

打赏作者

qq_44708888

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值