数学建模(二)线性规划

这篇具有很好参考价值的文章主要介绍了数学建模(二)线性规划。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

课程推荐:6 线性规划模型基本原理与编程实现_哔哩哔哩_bilibili

目录

一、线性规划的实例与定义

1.1 线性规划的实例

1.2 线性规划的定义

1.3 最优解

1.4 线性规划的Mathlab标准形式

1.5 使用linprog函数

二、线性规划模型建模实战与代码

2.1 问题提出

2.2 基本假设

2.3 模型的分析与建立 

2.3.1 模型分析

2.3.2 建立模型

2.3.3 多目标线性规划模型转化为单目标线性规划模型——制定界限

2.3.4 求解


在人们的生产实践中,经常会遇到如何利用现有资源来安排生产,以取得最大经济效益的问题。此类问题构成了运筹学的一个重要分支:数学规划。而线性规划(Linear Programming 简记LP)则是数学规划的一个重要分支。

一、线性规划的实例与定义

1.1 线性规划的实例

例:某机床厂生产甲、乙两种机床,每台销售后的利润分别为4千元与3千元。生产甲机床需用A、B机器加工,加工时间分别为每台 2小时和1小时;生产乙机床需用A、B、C三种机器加工,加工时间为每台各一小时。若每天可用于加工的机器时数分别为A机器10小时、B机器8小时和C机器7小时,问该厂应生产甲、乙机床各几台,才能使总利润最大?

上述问题的数学模型:设该厂生产x1台甲机床和x2乙机床时总利润z最大,则x1,x2应满足:

数学建模(二)线性规划,数学建模,数学建模

以上便是一个线性规划问题的数学模型,其中变量x1,x2称之为决策变量,(1.1)式被称为问题的目标函数,(1.2)中的几个不等式是问题的约束条件,记为s.t.(即subject to)。

1.2 线性规划的定义

目标函数约束条件均为线性函数,故被称为线性规划问题。线性规划问题是在一组线性约束条件的限制下,求一线性目标函数最大或最小的问题。

1.3 最优解

满足约束条件的解x=[x,,L ,xI',称为线性规划问题的可行解,而使目标函数达到最大值的可行解叫最优解。

1.4 线性规划的Mathlab标准形式

线性规划的目标函数可以是求最大值,也可以是求最小值,约束条件的不等号可以是小于号也可以是大于号。为了避免这种形式多样性带来的不便,Matlab中规定线性规划的标准形式:

数学建模(二)线性规划,数学建模,数学建模

其中c和x为n维列向量,A、Aeq为适当维数的矩阵,b、beq为适当维数的列向量。

Matlab中求解线性规划的命令为

Matlab中的linprog函数是一个线性规划求解器,可以用于求解线性规划问题。使用条件满足Mathlab线性规划标准形式

[x,fval] = linprog(c,A,b)
[x,fval] = linprog(c,A,b,Aeq,beq)
[x,fval] = linprog(c,A,b,Aeq,beq,lb,ub)

其中,x返回的是决策向量的取值,fval返回的是目标函数的最优值,c为价值向量,A,b对应的是线性不等式约束,Aeq,beq对应的是线性等式约束,lb和ub分别对应的是决策向量的下界向量和上界向量

1.5 使用linprog函数

数学建模(二)线性规划,数学建模,数学建模

求解的Matlab程序如下:

f=[-2;-3;5];
a=[-2,5,-1;1,3,1]; b=[-10;12];
aeq=[1,1,1];
beq=7;
[x,y]=linprog(f,a,b,aeq,beq,zeros(3,1));
x, y=-y

1. 目标函数中求max时,将目标函数的系数全部取反,即可看作求min,代入linprog函数,求得目标函数的最优值再取反回来,便得到了求max时目标函数的最优值(y)。这时,决策向量(x)的取值正对应着求max时目标函数的最优值,所以不变。

2. 约束条件中的不等号为大于号时,系数全部取反,代入linprog函数即可。

二、线性规划模型建模实战与代码

2.1 问题提出

        市场上有n种资产 (i= 1,2,L ,n)可以选择,现用数额为M的相当大的资金作一个时期的投资。这n种资产在这一时期内购买 的平均收益率为风险损失率为,投资越分散,总的风险越少,总体风险可用投资的中最大的一个风险来度量。
        购买 时要付交易费费率为,当购买额不超过给定值时,交易费按购买计算。另外,假定同期银行存款利率是既无交易费又无风险(= 5%)。


        已知n=4时相关数据如表1.1。

数学建模(二)线性规划,数学建模,数学建模

        试给该公司设计一种投资组合方案,即用给定资金M,有选择地购买若干种资产或存银行生息,使净收益尽可能大,使总体风险尽可能小。

2.2 基本假设

  • (1)投资数额M相当大,为了便于计算,假设M=1。
  • (2)投资越分散,总的风险越小。
  • (3)总体风险用投资项目中最大的一个风险来度量。
  • (4)n+1 种 资产之间是相互独立的。其中s0表示存入银行的资产。
  • (5)在投资的这一时期内,,,为定值,不受意外因素影响。
  • (6)净收益和总体风险只受,,影响,不受其它因素干扰。

2.3 模型的分析与建立 

2.3.1 模型分析

  • 1. 首先,我们要明确两个目标,即收益最大和风险最小,因此这是一个多目标规划模型
  • 2. 总体风险用所投资的 中最大的一个风险来衡量,即

                                                        

  • 3. 购买 (i= 1,L ,n) 所付交易费是一个分段函数,即

数学建模(二)线性规划,数学建模,数学建模

而所给的定值 (单位:元)相对总投资M很小,更小可以忽略不计,这样购买 的净收益可以简化为

2.3.2 建立模型

数学建模(二)线性规划,数学建模,数学建模

其中, 表示投资项目 的资金,i= 0,1,…,n;x0表示存入银行的资产。约束条件表示总资金投入必须等于M,投资项目 的资金必须大于等于0。

2.3.3 多目标线性规划模型转化为单目标线性规划模型——制定界限

方案一:固定风险水平,优化收益

在实际投资中,投资者承受风险的程度不一样, 若给定风险一个界限a,使最大的一个风险,可找到相应的投资方案。这样把多目标规划变成一个目标的线性规划。

数学建模(二)线性规划,数学建模,数学建模

方案二:固定盈利水平,极小化最大风险

给定收益一个界限k。

数学建模(二)线性规划,数学建模,数学建模

方案三:设置投资偏好系数

投资者在权衡资产风险和预期收益两方面时,希望选择一个令自己满意的投资组合。因此对风险、收益分别赋予权重s (0<s≤1)和1-s,s称为投资偏好系数。

数学建模(二)线性规划,数学建模,数学建模

2.3.4 求解

模型一:

数学建模(二)线性规划,数学建模,数学建模

由于a是任意给定的风险度,没有一个确定的准则,不同的投资者有不同的风险度。我们从a= 0开始,以步长 = 0.001进行循环搜索,编制程序如下:

clc,clear
a=0;hold on
while a<0.05
    c=[-0.05,-0.27,-0.19,-0.185,-0.185];
    A=[zeros(4,1 ),diag([0.025,0.015,0.055,0.026])];
    b=a*ones(4,1);
    Aeq=[1,1.01,1.02,1.045,1.065];
    beq=1; LB= zeros(5,1);
    [x,Q]=linprog(C,A,b,Aeq,beq,LB);
    Q=-Q; plot(a,Q,'*k');
    a=a+0.001;
end
xlabel('a'),ylabel('Q')

数学建模(二)线性规划,数学建模,数学建模

可以看出,在a=0.006附近有一个转折点,在这一点左边,风险增加很少时,利润增长很快。在这一点右边,风险增加很大时,利润增长很缓慢,所以对于风险和收益没有特殊偏好的投资者来说,应该选择曲线的转折点作为最优投资组合,所对应投资方案为风险度a= 0.006,收益Q=0.2019,x0=0,x1= 0.24,x1= 0.4,x3= 0.1091,x4= 0.2212。文章来源地址https://www.toymoban.com/news/detail-650496.html

到了这里,关于数学建模(二)线性规划的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数学建模十大算法03—线性规划、整数规划、非线性规划、多目标规划

    一、线性规划(Linear Programming,LP) 1.1 引例 在人们的生产实践中,经常会遇到 如何利用现有资源来安排生产,以取得最大经济效益的问题。 此类问题构成了运筹学的一个重要分支一数学规划,而 线性规划(Linear Programming, LP) 则是数学规划的一个重要分支。 简而言之,线

    2024年02月13日
    浏览(29)
  • 数学建模| 线性规划(Matlab)

    线性规划:约束条件和目标函数都是线性的。简单点说,所有的决策变量在目标函数和约束条件中都是一次方。 Matlab函数: 参数解释: func 表示目标函数。 A 表示不等式约束条件系数矩阵,b 表示不等式约束条件常数矩阵。 Aeq 表示等式约束条件系数矩阵,beq 表示等式约束条

    2024年02月07日
    浏览(30)
  • 数学建模——非线性规划

    目录 基本概念 凸规划 判别定理 二次规划模型 非线性规划的求解 无约束极值问题 有约束极值问题 基于求解器的解法 基于问题的求解 其他 非线性规划:描述目标函数或约束条件条件的数学表达式中,至少有一个是非线性函数。 记是n维欧式空间中的一个点(n维向量),,

    2024年02月06日
    浏览(31)
  • 数学建模【非线性规划】

    一、非线性规划简介 通过分析问题判断是用线性规划还是非线性规划 线性规划:模型中所有的变量都是一次方 非线性规划:模型中至少一个变量是非线性 非线性规划在形式上与线性规划非常类似,但在数学上求解却困难很多 线性规划有通用的求解准确解的方法(单纯形法

    2024年02月19日
    浏览(34)
  • 一、数学建模之线性规划篇

    1.定义 2.例题 3.使用软件及解题 1.线性规划 (Linear Programming,简称LP)是一种数学优化技术,线性规划作为运筹学的一个重要分支,专门研究在给定一组线性约束条件下,如何找到一个最优的决策,使得目标函数取得最大或最小值。 线性规划属于运筹学 (Operations Research)这

    2024年02月12日
    浏览(23)
  • 数学建模 | 第一章 线性规划例题

    例1.1 某机床厂生产甲、乙两种机床,每台销售后的利润分别为 4000 元与 3000 元。生产甲机床需用A、B机器加工,加工时间分别为每台2小时和1小时;生产乙机床需用A、B、C三种机器加工,加工时间为每台各一小时。若每天可用于加工的机器时数分别为A机器10小时、B机器8小时和

    2024年02月03日
    浏览(33)
  • MATLAB-数学建模-线性规划-1

    目录 1.1  线性规划模型的一般形式: 1.2  线性规划模型          minz=f(x)         s.t.     (i=1,2,···,m) 1和2组成的模型属于约束优化  f(x)称为目标函数,称为约束条件   决策变量 、 目标函数 、 约束条件 构成了线性规划的3个基本要素 min    u=cx s.t.      Ax b        

    2024年02月09日
    浏览(28)
  • 数学建模学习---非线性规划

    目录 前言 一、非线性规划问题是什么? 二、非线性规划的数学模型 1.一般形式 三、线性规划的 Matlab 解法 Matlab 中非线性规划的数学模型: 2.Matlab 中的命令: 本篇讲述非线性规划问题极其matlab解法 如果目标函数或约束条件中包含非线性函数,就称这种规划问题为非线性规

    2024年02月06日
    浏览(39)
  • 数学建模(五)非线性规划

     课程推荐: 13 非线性规划算法在数学建模中的应用与编程实现_哔哩哔哩_bilibili 如果目标函数或约束条件中包含非线性函数,就称这种规划问题为非线性规划问题 。一般说来,解非线性规划要比解线性规划问题困难得多。而且,也不像线性规划有单纯形法这一通用方法,

    2024年02月11日
    浏览(30)
  • 线性规划模型(数学建模python版)

    前言:本篇文章只涉及问题的应用层面(如何调用包调用函数,如何把问题归结为一般形式方便使用第三方库中的函数求解),不涉及问题的具体求解原理。 首先回顾一下高中学过的线性规划:求一个线性目标函数在先行可行域内的 最值问题。 高中遇到的问题:配送运输问

    2024年02月20日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包