博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
多目标规划——fgoalattain
阅读量:6709 次
发布时间:2019-06-25

本文共 1726 字,大约阅读时间需要 5 分钟。

多目标规划

多个目标函数,之间可以用他们的重要程度分析,来一次进行这个序贯算法,当然也可以无限逼近的方案——

clc,clear;% 约束a = [-1 -1 0 0    0 0 -1 -1    3 0 2 0    0 3 0 2];b = [-30    -30    120    48];% 求两次单一目标函数c1 = [-100 -90 -80 -70];c2 = [0 3 0 2];​% 单一目标值 g1,g2[x1,g1] = linprog(c1,a,b,[],[],zeros(4,1));[x2,g2] = linprog(c2,a,b,[],[],zeros(4,1));​% 组合多目标规划,fgoalattaing3 = [g1    g2];​[x,fval] = fgoalattain('Fun',rand(4,1),g3,abs(g3),a,b,[],[],zeros(4,1));

 

如何设置权重weight呢?

比如:

 

第一个式子的重要程度是20%,第二个式子的重要程度是80%。

哈哈,想到这里,其实是错误的,可以有这种想法,但是我们的多目标规划问题,就是要无限逼近这两个目标,不存在说两个式子哪个重要。哪个重要,还不如用我们的之前的那个序贯算法呢。看看MATLAB官方文档是如何说的这个参数。

A weighting vector to control the relative underattainment or overattainment of the objectives in fgoalattain. When the values of goal are all nonzero, to ensure the same percentage of under- or overattainment of the active objectives, set the weighting function to abs(goal). (The active objectives are the set of objectives that are barriers to further improvement of the goals at the solution.)Note Setting a component of the weight vector to zero will cause the corresponding goal constraint to be treated as a hard constraint rather than as a goal constraint. An alternative method to set a hard constraint is to use the input argument nonlcon.
When the weighting function weight is positive, fgoalattain attempts to make the objectives less than the goal values. To make the objective functions greater than the goal values, set weight to be negative rather than positive. To make an objective function as near as possible to a goal value, use theEqualityGoalCount option and put that objective as the first element of the vector returned by fun (see the preceding description of fun and options).

转载于:https://www.cnblogs.com/TreeDream/p/8309243.html

你可能感兴趣的文章
jquery 判断ul下是否存在li
查看>>
Backtrack5 R3实用新工具分析(上)
查看>>
如何解决在 beamer 中使用 utf8 的中文标签乱码问题
查看>>
NYOJ1238 最小换乘 (dijkstra)
查看>>
【Android】保存Fragment切换状态
查看>>
关于TextView的setText()与Integer之间一个易犯的小错误
查看>>
杭电OJ2004——成绩转换
查看>>
第一阶段冲刺10
查看>>
POJ-1679 The Unique MST---判断最小生成树是否唯一
查看>>
(转)关于Struts 2 拦截器参数丢失问题
查看>>
数据筛选和排序
查看>>
Promise 理解
查看>>
Ueditor在MVC中上传文件和远程图片下载的脚本
查看>>
关于索引
查看>>
让pandoc输出pdf时支持中文
查看>>
利用反射实现页面控件与实体之间的绑定
查看>>
Xamarin-Android_BaseAdapter 简单的复用
查看>>
快速傅里叶变换(FFT)
查看>>
在C#程序中使用ocx的方法
查看>>
C# 递归查找文件夹下所有文件和子文件夹的所有文件
查看>>