找回密码
 注册
Simdroid-非首页
查看: 393|回复: 4

【原创】二维光子晶体禁带的遗传优化算法

[复制链接]
发表于 2007-3-17 20:11:15 | 显示全部楼层 |阅读模式 来自 河南郑州
GreenSim团队的博客开通了,更多原创程序请访问我们的博客
http://blog.sina.com.cn/greensim
  1. function [Zp,Yp,Xp,LC1,LC2]=PBGGA(M,N,Pm)
  2. %--------------------------------------------------------------------------
  3. % PBGGA.m
  4. % Photonic Band Gap Genetic Algorithm
  5. % 二维光子晶体禁带的遗传优化算法
  6. %--------------------------------------------------------------------------
  7. % 函数功能
  8. % 在平面波展开法的基础上,使用遗传算法寻找具有最大光子禁带的二维光子晶体结构
  9. %--------------------------------------------------------------------------
  10. % 主要参考文献
  11. % 龚春娟,胡雄伟.快速遗传算法优化计算二维光子晶体[J].
  12. % 半导体学报.2006,27(6):1098-1102
  13. %--------------------------------------------------------------------------
  14. % 输入参数列表
  15. % M 遗传进化迭代次数
  16. % N 种群规模(取偶数)
  17. % Pm 变异概率
  18. %--------------------------------------------------------------------------
  19. % Zp 最大禁带
  20. % Yp 最大禁带的区间上下限
  21. % Xp 光子晶体结构决策变量(10×10的01矩阵)
  22. % LC1 收敛曲线1,各代最优个体适应值的记录
  23. % LC2 收敛曲线2,各代群体平均适应值的记录
  24. %--------------------------------------------------------------------------

  25. %第一步:变量初始化
  26. epsa=11.56;%介质介电常数
  27. epsb=1;%空气介电常数
  28. Xp=zeros(10,10);%最优结构
  29. Yp=zeros(1,2);%禁带上下限
  30. Zp=0;%禁带宽度
  31. LC1=zeros(1,M);%收敛曲线1
  32. LC2=LC1;%收敛曲线2

  33. %第二步:随机产生初始钟群
  34. farm=cell(1,N);%采用细胞结构存储种群
  35. for i=1:N
  36. A=unidrnd(2,5,10)-ones(5,10);%由于基本单元结构是中心对称的,所以只需要对矩阵的上半部分进行初始化
  37. B=flipud(fliplr(A));%剩余部分先做上下倒置,再做左右旋转
  38. C=[A;B];%把两步分合并
  39. farm{i}=reshape(C,100,1);%个体被存储在细胞结构farm中
  40. end

  41. counter=0;%设置迭代计数器
  42. while counter<M%停止条件为达到最大迭代次数

  43. %第三步:交叉
  44. newfarm=cell(1,N);%交叉产生的新种群存在这里面
  45. Ser=randperm(N);%用这个函数保证随机配对
  46. for i=1:2:(N-1)
  47. AA=reshape(farm{Ser(i)},10,10);% 待交叉的两个父代个体
  48. BB=reshape(farm{Ser(i+1)},10,10);
  49. A=AA(1:5,:);%为保证对称性,需先提取其中一半的基因
  50. B=BB(1:5,:);
  51. Manner=unidrnd(2);%随机选择交叉方式
  52. if Manner==1%横交叉
  53. cp=unidrnd(4);%随机选择交叉点
  54. a=[A(1:cp,:);B((cp+1):5,:)];%双亲双子单点交叉
  55. b=[B(1:cp,:);A((cp+1):5,:)];
  56. else%列交叉
  57. cp=unidrnd(9);%随机选择交叉点
  58. a=[A(:,1:cp),B(:,(cp+1):10)];%双亲双子单点交叉
  59. b=[B(:,1:cp),A(:,(cp+1):10)];
  60. end
  61. a=[a;flipud(fliplr(a))];%反演对称
  62. b=[b;flipud(fliplr(b))];
  63. newfarm{i}=reshape(a,100,1);%交叉后的子代存入newfarm
  64. newfarm{i+1}=reshape(b,100,1);
  65. end
  66. %新旧种群合并
  67. FARM=[farm,newfarm];

  68. %第四步:选择复制
  69. FITNESS=zeros(1,2*N);
  70. fitness=zeros(1,N);
  71. for i=1:(2*N)
  72. X=FARM{i};
  73. Band=pixelTM(X,10,epsa,epsb,0);%调用平面波展开法的程序,中间结果不画图
  74. B1=Band(:,1);
  75. B2=Band(:,2);
  76. for j=1:length(B1)
  77. if B1(j)>1||B2(j)>1
  78. B1(j)=0;
  79. B2(j)=0;
  80. end
  81. end
  82. BB=abs(B1-B2);
  83. pos=find(BB==max(BB));
  84. Z=BB(pos(1));%最宽的禁带作为适应值
  85. FITNESS(i)=Z;
  86. end
  87. Ser=randperm(2*N);%选择复制采取两两随机配对竞争的方式,具有保留最优个体的能力
  88. for i=1:N
  89. f1=FITNESS(Ser(2*i-1));
  90. f2=FITNESS(Ser(2*i));
  91. if f1>=f2
  92. farm{i}=FARM{Ser(2*i-1)};
  93. fitness(i)=FITNESS(Ser(2*i-1));
  94. else
  95. farm{i}=FARM{Ser(2*i)};
  96. fitness(i)=FITNESS(Ser(2*i));
  97. end
  98. end
  99. %记录最佳个体和收敛曲线
  100. maxfitness=max(fitness)
  101. meanfitness=mean(fitness)
  102. LC1(counter+1)=maxfitness;%收敛曲线1,各代最优个体适应值的记录
  103. LC2(counter+1)=meanfitness;%收敛曲线2,各代群体平均适应值的记录
  104. pos=find(fitness==maxfitness);
  105. xp=farm{pos(1)};
  106. Zp=maxfitness;
  107. Xp=reshape(xp,10,10);

  108. %第五步:变异
  109. for i=1:N
  110. if Pm>rand;%变异概率为Pm
  111. X=farm{i};
  112. XX=reshape(X,10,10);%为保证对称性,需先将个体基因变形
  113. XA=XX(1:5,:);
  114. posX=unidrnd(5,1,1);%随机选取变异位
  115. posY=unidrnd(10,1,1);
  116. XA(posX(1),posY(1))=mod(XA(posX(1),posY(1))+1,2);%变异,0变成1,1编程0
  117. %XA(posX(2),posY(2))=mod(XA(posX(2),posY(2))+1,2);
  118. XB=flipud(fliplr(XA));
  119. XX=[XA;XB];
  120. farm{i}=reshape(XX,100,1);%还原个体形态
  121. end
  122. end
  123. farm{pos(1)}=reshape(Xp,100,1);

  124. counter=counter+1
  125. end

  126. %输出结果并绘图
  127. figure(1);
  128. xp=reshape(Xp,100,1);
  129. Band=pixelTM(xp,10,epsa,epsb,1);%画最优个体的禁带图
  130. B1=Band(:,1);
  131. B2=Band(:,2);
  132. BB=abs(B1-B2);
  133. pos=find(BB==max(BB));
  134. Zp=BB(pos(1));
  135. Yp=[B1(pos(1)),B2(pos(1))];
  136. figure(2);
  137. plot(LC1);%画收敛曲线1
  138. figure(3);
  139. plot(LC2);%画收敛曲线2
复制代码
--------------------------------------------------------------------------------
GreenSim团队简介

——更多原创程序,请访问GreenSim团队的主页→http://blog.sina.com.cn/greensim

    GreenSim团队长期从事建模仿真、算法设计、代写程序等业务,为您提供实验、课题、论文、项目等方面的仿真服务。
    GreenSim团队擅长的学科领域主要有
智能算法】遗传算法、模拟退火、神经网络、蚁群算法、免疫优化、支持向量机、拟物拟人
运筹优化】数学建模、数值优化算法、大规模/非线性问题、组合优化、NP完全问题
信息与通信】无线通信、信号处理、计算机网络
其它学科】任何问题,只要能归结为数学问题或者算法仿真,我们都有实力和信心解决
    GreenSim团队的联系方式:
QQ: 330264704,535115369  Email:
greensim@163.com(来 信 必 复)

[ 本帖最后由 aiwa 于 2007-3-18 13:34 编辑 ]

评分

2

查看全部评分

发表于 2007-3-17 21:32:22 | 显示全部楼层 来自 天津河西区
Simdroid开发平台
好东西。建议版主加分!
发表于 2008-1-10 01:31:02 | 显示全部楼层 来自 北京
运行不了啊  说M没有定义

[ 本帖最后由 zhangbit 于 2008-1-10 01:44 编辑 ]
回复 不支持

使用道具 举报

发表于 2016-3-13 10:56:44 | 显示全部楼层 来自 黑龙江哈尔滨
pixelTM这个函数能分享一下吗,谢谢您!
回复 不支持

使用道具 举报

发表于 2017-5-28 17:18:04 | 显示全部楼层 来自 辽宁大连
楼主太牛了,赞
回复 不支持

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|小黑屋|联系我们|仿真互动网 ( 京ICP备15048925号-7 )

GMT+8, 2024-4-19 17:53 , Processed in 0.035629 second(s), 15 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5 Licensed

© 2001-2024 Discuz! Team.

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