找回密码
 注册
关于网站域名变更的通知
查看: 506|回复: 4
打印 上一主题 下一主题

多维函数

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-7-8 13:36 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
函数如下:y=(0.0206*x(2)^2/(2*9.81*x(1))+(0.5*(1-(x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2))))+((0.25*(x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2)))-1)^2+x(5)*x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2)))^0.5)*(x(4)/1040-1)+1.8413*(x(2)/(9.81*x(1)))^2.7736*(0.5*(1-(x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2))))+((0.25*(x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2)))-1)^2+x(5)*x(2)/(4*x(3)*9.81*(x(4)-1040)/(3*0.43*1040))^0.5*(1-(x(3)/x(1))^2)*2.7183^(-(2.65*x(5)-3.32*x(5)^2.2)))^0.5)*0.43*x(3)/x(1)*(x(4)/1040-1))/(x(4)*x(5)/1040);0 J; x9 K/ [7 H# W- P3 P4 _
$ }: D& B/ ?$ _, y" R
函数中有五个自变量,自变量之间没有任何的约束关系,但是自变量有范围,x(1)=[0.2,0.4],x(2)=[1.234,3],x(3)=[0.01,0.04],x(4)=[1190,1398],x(5)=[0.15,0.4], 劳烦大神指点看怎么编程,能求出自变量范围内的结果 ,谢谢
. p* ?) r5 B$ z. S+ ^$ D/ b! W( V/ u% b( P

% r" s8 |1 X: {' ^, h% H# P2 N

该用户从未签到

5#
 楼主| 发表于 2020-7-9 14:14 | 只看该作者
zaiyiaaaa 发表于 2020-7-9 10:50
9 ]: B3 _0 z( P. _) W& W% z理论上最小值就是-2.83599462789046,如果非要为正,那就是0了。

7 d+ `4 k( A! m好吧,我再看看
7 n9 W7 _- A! X& z$ U# E5 n* b9 c' h4 Y  }

该用户从未签到

4#
发表于 2020-7-9 10:50 | 只看该作者

% l2 C. h4 B& W$ l: n理论上最小值就是-2.83599462789046,如果非要为正,那就是0了。

点评

好吧,我再看看  详情 回复 发表于 2020-7-9 14:14

该用户从未签到

3#
发表于 2020-7-8 14:02 | 只看该作者
帮你顶一下

该用户从未签到

2#
 楼主| 发表于 2020-7-8 13:57 | 只看该作者
fitnessFunction=@minf_5;nvars=5;
4 O0 o  i9 @4 G. P! aoptions=gaoptimset;7 l7 p6 {% p* n/ P
options=gaoptimset(options,'PopInitRange',[0;1]);8 j) S8 I, P5 c9 m, I) w: k
options = gaoptimset(options,'PopulationSize',100);
7 x$ b0 s. c9 v3 ~' L% `0 U5 Boptions=gaoptimset(options,'CrossoverFraction',0.9);
' W4 |# y6 ~7 A, H6 ^4 ^options=gaoptimset(options,'Generations',1000);
: |* w) c- \: D3 H* z% P+ @- ~options=gaoptimset(options,'CrossoverFcn',{@crossoverheuristic,0.9});
: k# Z( l7 l& Q* ]3 ?options=gaoptimset(options,'MutationFcn',{@mutationuniform,0.02});- h# z* A7 u" X4 ]' l$ G
[x fval reason output population scores]=ga(@minf_5,nvars,options)# C& i. a" W$ B1 d7 c; c
Optimization terminated: average change in the fitness value less than options.TolFun., \. L# H8 l% o/ l, l9 t
! U$ z7 I& Q" S7 v, f
x =
/ Q# [' Z9 G& O# i3 r  |$ L2 Q, ?# K1 G
    0.6026    0.0979    0.2421    0.9712    0.9449- y/ o$ }1 u6 c3 q, V

$ Q. F( g& O! \9 v# ?* B4 X& q2 r& Y3 ^* Y! S& |; I
fval =* u8 [- A- ?- s4 W9 n' t" W
1 s) ~! N3 q# C$ j; Z$ P& G5 G
  -1.6983e+03 - 1.4575e+01i9 z. a) H" a. w; V
0 b% I; K2 Z) g# O% D& N
附上我自己的遗传算法编程,首先是第三行的自变量范围,只能定义一个区间,不知道怎么分开定义五个自变量的范围,再就是这样计算结果竟然是个复数,还都是负号,跟我想要的正实数实在是相去甚远,
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-24 20:37 , Processed in 0.156250 second(s), 25 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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