欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    非线性整数规划的遗传算法Matlab程序(共6页).docx

    • 资源ID:13398413       资源大小:71.20KB        全文页数:6页
    • 资源格式: DOCX        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    非线性整数规划的遗传算法Matlab程序(共6页).docx

    精选优质文档-倾情为你奉上非线性整数规划的遗传算法Matlab程序(附图)    通常,非线性整数规划是一个具有指数复杂度的NP问题,如果约束较为复杂,Matlab优化工具箱和一些优化软件比如lingo等,常常无法应用,即使能 应用也不能给出一个较为令人满意的解。这时就需要针对问题设计专门的优化算法。下面举一个遗传算法应用于非线性整数规划的编程实例,供大家参考!    模型的形式和适应度函数定义如下:     这是一个具有200个01决策变量的多目标非线性整数规划,编写优化的目标函数如下,其中将多目标转化为单目标采用简单的加权处理。function Fitness=FITNESS(x,FARM,e,q,w)% 适应度函数%  输入参数列表%  x        决策变量构成的4×50的0-1矩阵%  FARM     细胞结构存储的当前种群,它包含了个体x%  e        4×50的系数矩阵%  q        4×50的系数矩阵%  w        1×50的系数矩阵%gamma=0.98;N=length(FARM);%种群规模F1=zeros(1,N);F2=zeros(1,N);for i=1:N    xx=FARMi;    ppp=(1-xx)+(1-q).*xx;    F1(i)=sum(w.*prod(ppp);    F2(i)=sum(sum(e.*xx);endppp=(1-x)+(1-q).*x;f1=sum(w.*prod(ppp);f2=sum(sum(e.*x);Fitness=gamma*sum(min(sign(f1-F1);zeros(1,N)+(1-gamma)*sum(min(sign(f2-F2);zeros(1,N); 针对问题设计的遗传算法如下,其中对模型约束的处理是重点考虑的地方function Xp,LC1,LC2,LC3,LC4=MYGA(M,N,Pm)% 求解01整数规划的遗传算法% 输入参数列表%  M     遗传进化迭代次数%  N     种群规模%  Pm    变异概率% 输出参数列表%  Xp    最优个体%  LC1   子目标1的收敛曲线%  LC2   子目标2的收敛曲线%  LC3   平均适应度函数的收敛曲线%  LC4   最优适应度函数的收敛曲线% 参考调用格式Xp,LC1,LC2,LC3,LC4=MYGA(50,40,0.3)% 第一步:载入数据和变量初始化load eqw;%载入三个系数矩阵e,q,w%输出变量初始化Xp=zeros(4,50);LC1=zeros(1,M);LC2=zeros(1,M);LC3=zeros(1,M);LC4=zeros(1,M);Best=inf;% 第二步:随机产生初始种群farm=cell(1,N);%用于存储种群的细胞结构k=0;while k    %以下是一个合法个体的产生过程    x=zeros(4,50);%x每一列的1的个数随机决定    for i=1:50        R=rand;        Col=zeros(4,1);        if R<0.7            RP=randperm(4);%1的位置也是随机的            Col(RP(1)=1;        elseif R>0.9            RP=randperm(4);            Col(RP(1:2)=1;        else            RP=randperm(4);            Col(RP(1:3)=1;        end        x(:,i)=Col;    end    %下面是检查行和是否满足约束的过程,对于不满足约束的予以抛弃    Temp1=sum(x,2);    Temp2=find(Temp1>20);    if length(Temp2)=0        k=k+1;        farmk=x;    endend   % 以下是进化迭代过程counter=0;%设置迭代计数器while counter   % 第三步:交叉    %交叉采用双亲双子单点交叉    newfarm=cell(1,2*N);%用于存储子代的细胞结构    Ser=randperm(N);%两两随机配对的配对表    A=farmSer(1);%取出父代A    B=farmSer(2);%取出父代B    P0=unidrnd(49);%随机选择交叉点    a=A(:,1:P0),B(:,(P0+1):end);%产生子代a    b=B(:,1:P0),A(:,(P0+1):end);%产生子代b    newfarm2*N-1=a;%加入子代种群    newfarm2*N=b;    %以下循环是重复上述过程    for i=1:(N-1)        A=farmSer(i);        B=farmSer(i+1);        P0=unidrnd(49);        a=A(:,1:P0),B(:,(P0+1):end);        b=B(:,1:P0),A(:,(P0+1):end);        newfarm2*i-1=a;        newfarm2*i=b;    end    FARM=farm,newfarm;%新旧种群合并   % 第四步:选择复制    FLAG=ones(1,3*N);%标志向量,对是否满足约束进行标记    %以下过程是检测新个体是否满足约束    for i=1:(3*N)        x=FARMi;        sum1=sum(x,1);        sum2=sum(x,2);        flag1=find(sum1=0);        flag2=find(sum1=4);        flag3=find(sum2>20);        if length(flag1)+length(flag2)+length(flag3)>0            FLAG(i)=0;%如果不满足约束,用0加以标记        end    end    NN=length(find(FLAG)=1);%满足约束的个体数目,它一定大于等于N    NEWFARM=cell(1,NN);    %以下过程是剔除不满主约束的个体    kk=0;    for i=1:(3*N)        if FLAG(i)=1            kk=kk+1;            NEWFARMkk=FARMi;        end    end    %以下过程是计算并存储当前种群每个个体的适应值    SYZ=zeros(1,NN);    syz=zeros(1,N);    for i=1:NN        x=NEWFARMi;        SYZ(i)=FITNESS2(x,NEWFARM,e,q,w);%调用适应值子函数    end    k=0;    %下面是选择复制,选择较优的N个个体复制到下一代    while k        minSYZ=min(SYZ);        posSYZ=find(SYZ=minSYZ);        POS=posSYZ(1);        k=k+1;        farmk=NEWFARMPOS;        syz(k)=SYZ(POS);        SYZ(POS)=inf;    end    %记录和更新,更新最优个体,记录收敛曲线的数据    minsyz=min(syz);    meansyz=mean(syz);    pos=find(syz=minsyz);    LC3(counter+1)=meansyz;    if minsyz        Best=minsyz;        Xp=farmpos(1);    end    LC4(counter+1)=Best;    ppp=(1-Xp)+(1-q).*Xp;    LC1(counter+1)=sum(w.*prod(ppp);    LC2(counter+1)=sum(sum(e.*Xp);   % 第五步:变异    for i=1:N        if Pm>rand%是否变异由变异概率Pm控制            AA=farmi;%取出一个个体            POS=unidrnd(50);%随机选择变异位            R=rand;            Col=zeros(4,1);            if R<0.7                RP=randperm(4);                Col(RP(1)=1;            elseif R>0.9                RP=randperm(4);                Col(RP(1:2)=1;            else                RP=randperm(4);                Col(RP(1:3)=1;            end            %下面是判断变异产生的新个体是否满足约束,如果不满足,此次变异无效            AA(:,POS)=Col;            Temp1=sum(AA,2);            Temp2=find(Temp1>20);            if length(Temp2)=0                farmi=AA;            end        end    end       counter=counter+1end%第七步:绘收敛曲线图figure(1);plot(LC1);xlabel('迭代次数');ylabel('子目标1的值');title('子目标1的收敛曲线');figure(2);plot(LC2);xlabel('迭代次数');ylabel('子目标2的值');title('子目标2的收敛曲线');figure(3);plot(LC3);xlabel('迭代次数');ylabel('适应度函数的平均值');title('平均适应度函数的收敛曲线');figure(4);plot(LC4);xlabel('迭代次数');ylabel('适应度函数的最优值');title('最优适应度函数的收敛曲线');贴出一幅运行得到的收敛曲线专心-专注-专业

    注意事项

    本文(非线性整数规划的遗传算法Matlab程序(共6页).docx)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开