QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3297|回复: 0
打印 上一主题 下一主题

[其他资源] 数学建模:matlab解决线性规划问题

[复制链接]
字体大小: 正常 放大

326

主题

32

听众

1万

积分

  • TA的每日心情
    慵懒
    2020-7-12 09:52
  • 签到天数: 116 天

    [LV.6]常住居民II

    管理员

    群组2018教师培训(呼和浩

    群组2017-05-04 量化投资实

    群组2017“草原杯”夏令营

    群组2018美赛冲刺培训

    群组2017 田老师国赛冲刺课

    跳转到指定楼层
    1#
    发表于 2020-5-28 15:56 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    在人们的生产实践中,经常会遇到如何利用现有资源来安排生产,以取得最大经济效
    8 F4 c6 f" I! @8 o( ^" Z4 h1 a1 A益的问题。此类问题构成了运筹学的一个重要分支一数学规划,而线性规划(Linear: X5 |4 M1 \; u; _+ F: h4 u
    Programming, LP)则是数学规划的一个重要分支。自从1947年G. B. Dantzig 提出求解线
    2 @0 S- X: h- ^* Z3 u5 I性规划的单纯形方法以来,线性规划在理论上趋向成熟,在实用中日益广泛与深入。特别; f4 F+ d! _) i/ x
    是在计算机能处理成千上万个约束条件和决策变量的线性规划问题之后,线性规划的适
    5 C' X1 V. u* @, N+ W用领域更为广泛了,已成为现代管理中经常采用的基本方法之一。
    4 M* A' M2 R* I! ]( i( T# b! S+ r1 ]: B% B- r/ k
    例如,给定m个数据点(xi,yi),i=1,2,…,m,拟合一条直线y=ax+b(即确定参数a、b),使得所有数据点(xi,yi)和拟合直线上对应的点(xi,axi+b)之间距离的最大值rmax最小。也就是说,对整个这组数据点而言,最大绝对偏差r=max{ | yi-y(xi) | }最小。这种准则实际上定义了如下优化问题:
    " V2 {' P! n  o 4.png + D' j0 E! a( ]* _/ z" @
    这是一个线性规划问题,具有很广泛的应用。! F# r$ c0 m) R* _
    $ }8 {5 I. T3 C; Q
    木匠问题
    ; z, @, l& u9 e+ L9 X: i7 M5 Z木匠销售桌子和书架的单位净利润分别为25美元和30美元,他希望确定每周生产的桌子数量x和书架数量y。他每周最多有690 张木板和120小时的劳动时间可以利用,如果木板和工时不用于生产桌子和书架,他能够将它们有效地使用在其他方面。他估计,生产一张桌子需要20张木板和5小时劳动时间,生产一个书架需要30张木板和4小时劳动时间。模型为) F) M. N- ]4 W8 R3 t
    5.png
    % j% r$ x& X- a. r) G, Y! F  d# t8 ^6 f0 A$ v
    木匠问题中的约束所代表的凸集在图中用多边形ABCD表示。请注意,约束所代表的直线有6个交点,但只有四个交点(即A—D)满足所有约束从而属于该凸集。点A—D是该多边形的极点。* Q. Z2 B* S/ h! @& f. c
    如果一个线性规划存在最优解,它必然也会出现在约束所形成的凸集的某个极点上,极点上目标函数的值(木匠问题的利润)是$ C% E* z' D1 x  W2 t0 i

    3 |/ o% U7 a; q" M6 C 1.png
    . d$ O* C2 {2 ~5 O- T& U: @$ o( V6 d% G

    # ?7 A9 q. [0 g6 [因此,木匠每周应该制作12张桌子和15个支架,每周最大利润为750美元。+ p$ T7 x1 Z: f6 ~
    : r; f6 J0 }) X, E$ }$ y
    木匠问题(线性规划)的matlab解法
    % q: t5 s8 A8 B, r1 G
    : K5 f$ N) J/ [' L- ]( i线性规划的目标函数可以是求最大值,也可以是求最小值,约束条件的不等号可以是6 G' b, j6 k7 A" J
    小于等号也可以是大于等号。为了避免这种形式多样性带来的不便, Matlab中规定线性
    & M" ]6 p) i. E6 e2 ~8 ]规划的标准形式为
    : h9 K9 G7 _1 |4 i# b
    2.png

    " M5 u$ H- D0 [3 o3 A" A3 B# e1 R
    " v; a- B9 T$ ?式中:f,x ,b ,beq,lb, ub为列向量,其中f称为价值向量,b称为资源向量;A , Aeq为矩阵。
    . ?) Z0 P$ f5 \' NMatlab中求解线性规划的命令为3 d" l: ^" @( \( N
    [x,fval] = linprog(f,A,b)* ?% E' }  a$ q  b% J
    [x,fval] = linprog( f,A,b,Aeq, beq)' Y9 `$ z+ Q  P, X: B
    [x,fval] = linprog( f ,A, b,Aeq , beq,1b,ub)
    ( R8 i3 g' i3 W/ G0 h- K9 x, L式中:x返回决策向量的取值;fval返回目标函数的最优值;f为价值向量;A和b对应线性$ G6 z9 I2 R# j4 z: T/ x; S7 ?
    不等式约束;Aeq和beq对应线性等式约束;lb和ub分别对应决策向量的下界向量和上
    . n7 z. N2 X/ g# {$ d界向量。
    0 M2 u  N- U9 z4 V/ k& f例如,线性规划
    . R9 U( z  @; n: P) E: Y 6.png
    . k: H. T. }3 F7 u0 t的matlab标准型为
    9 ]$ C! r2 y; G  ~ 7.png 5 {) j! H; ~- U0 }4 m) p: [
    5 D, C7 l0 Z4 @! J
    * t* u4 V" i: U6 O5 E6 K6 `7 ]
    附上木桶问题的matlab代码
    1 N5 R3 R2 Y1 z8 t 3.png
    & {  L+ u" o2 v" N% Q8 ~  c0 y% w1 F3 B2 n: T
    ————————————————" [2 x  S: V5 p
    版权声明:本文为CSDN博主「板砖大的砖头」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    # h# B# R# m' _  b' b# S/ s原文链接:https://blog.csdn.net/qq_44953660/article/details/104227831+ w5 D4 Z* Z! Q. H2 D& g% n* o

    6 Y- ]- l* N/ M$ ~$ z" z3 J
    ; y" X4 }0 t/ i# H) W$ L/ v
    4 m9 L1 B9 ?# n4 W0 W
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-12 11:47 , Processed in 0.353699 second(s), 53 queries .

    回顶部