数模之线性规划

线性规划 

优化类问题:有限的资源,最大的收益

例子:

华强去水果摊找茬,水果摊上共3个瓜,华强总共有40点体力值,每劈一个瓜能带来40点挑衅值,每挑一个瓜问“你这瓜保熟吗”能带来30点挑衅值,劈瓜消耗20点体力值,问话消耗10点体力值, 问如何利用这些瓜,使挑衅值最大?

注意:遇到不懂的词汇去百度搜,去查文献,尽快了解问题背景, 遇到大量陌生专有名词就尽量别选, 例如国赛A题

分析: 

 注意x1>=0和x2>=0这两个隐藏条件, 可能会对解答有影响

线性规划模型三要素: 

 线性规划模型:

 题目类型:

题目中提到“XXX有多少多少”“怎样安排/分配”“最多(少)”“利润最大”等词;

生产安排:

原材料、设备有限制,总利润最大
• 若生产两种机床,利润分别为XXX;A机器和B机器加工,有顺序要求,有不同损耗费用,不同的工作时间…;问题:怎样安排生产使得总利润最大?

投资收益:

涉及资产配置、收益率、损失率、组合投资,总收益最大
• 若总资金为M,有n种资产可以配置
• 每种资产的平均收益率…,风险损失率…,手续费…;问题:设计组合投资方案,使得收益尽可能大,总体风险尽可能小(本质是多目标规划,可化简为一个目标的线性规划) 

销售运输:

产地、销地、产量、销量、运费,总运费最省
• 商品有m个产地和n个销地,需要从产地运到销地
• 各产地的产量…,各销地需求量…由a产地运到b销地的运价xxx;问题:如何调运才能使总运费最省?

车辆安排:

路线、起点终点、承载量、时间点、车次安排最合理
• 不同种类的车辆有各自的承载量,工地各点之间要安排车辆运输
• 工地里有多条路线……满足用工需求的情况下…;问题:如何安排车辆能使产量尽可能大?

注意:最合理这种模糊词需要给出准确的数学定义, 可能是利润最大, 排队时间最短, 运载量最大....

投资类问题的注意事项

• 收益率 = 收益/成本,设收益率为r,收益为g,成本为c
• 如果要求“总收益最大”,一般可以用线性规划
• 如果要求“总收益率最大”,一般是非线性规划, r = g/c, 其中c是-1次方(不绝对) 

判断标准

判断的标准就是建立的模型中, 约束条件和目标函数中的变量是否全是一次方
• 如果成本c为变量,追求r最大,目标函数是 max r = g/c,其中变量c的次幂是-1,为非线性
如果成本c始终为常数, 总收益率就变成了线性规划

例题

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


问题分析

目标函数(净收益尽可能大、总风险尽可能小)
约束条件(总资金有限,和隐含数学条件:每一笔投资都是非负数) 

基本假设

由于投资数额M相当大,而题目设定的定额ui相对M很小,pi*ui更小,因此假设每一笔交易额xi都大于对应的定额ui


模型的建立 

决策变量: 投资项目si 的资金为xi (i = 0,1,2,3,4), 总收益Q

目标函数: 净收益尽可能大(max)、总风险尽可能小(min) (所以这是一个多目标线性规划模型)

约束条件: 投资总额为M、每一笔投资非负数

 目标函数

净收益尽可能大(max): 总收益=max(∑每一项的资金×(每一项的收益率-费率))

总风险尽可能小(min):  每一项的资金×风险率的最大值最小

约束条件 

 ∑每一项的资金和交易费 = 总资金

每一笔投资都是非负数


合理的简化,事半功倍 

模型的简化:

现实中,不同人所能承受的风险不同
设某一类投资者,能接受的最大投资风险率为定值a
只要风险率小于等于该定值a,可视为对该类投资者满足“总风险尽可能小”即风险率

(风险率=投资额*损失率/总资产)满足:

分情况讨论:设低风险投资者能接受的a=5%,中风险投资者能接受的a=15%等等

基于该简化,将目标函数: 转化为了约束条件:


完成模型的建立

决策变量:  xi(i = 0,1,2,3,4), 第i种资产的投资额

目标函数和约束条件:

注意,除了xi(5个变量),其他都是常数
显然,所有变量都是线性的, 因此这是一个(单目标)线性规划模型 


模型的建立到求解 

 建立模型时留下的坑

题目要求“总风险尽可能小
本模型简化为只要风险率小于等于该定值a, 可视为对某一类投资者满足“总风险尽可能小’·模型中的a是一个常数,而不是变量,所以才能在写代码时套用matlab的函数

求解问题时尽量把坑填上(在论文里写作“模型改进”)

现实中的a是一个变量,不同投资者对风险的接受程度肯定不一样
低风险投资者追求落袋为安, 对应a=5%;高风险投资者追求富贵险中求, 可能对应a=50%·那么在求解时, 对不同a取值分别进行求解(该操作实现了把a作为了“变量”) 


代码:

linprog函数使用具体分析:​​​​​​​Matlab线性规划函数linprog-小白详解_浩浩的科研笔记的博客-CSDN博客

linprog函数求解线性规划模型, linprog函数中的变量必须是matlab标准型(求最大值转化为求负的最小值, 约束条件是大于变换为小于)

函数:[x,fval]= linprog(f,A,b,Aeq,beq,lb,ub)

 

% clc是清除命令行窗口,clear是清除存储空间的变量
clc,clear;

%a矩阵的元素是不同的风险率,从0到0.05等差取值,相邻的两个数相差0.001
a = (0:0.001:0.05);

%目标函数的系数向量,因为求的是M的最大值,所以变为求-M的最小值,系数变为负
f = [-0.05,-0.27,-0.19,-0.185,-0.185]; 

%A是不等式约束条件的变量系数构成的矩阵
A = [0,0.025,0,0,0;
     0,0,0.015,0,0;
     0,0,0,0.055,0;
     0,0,0,0,0.026];
 %还可以这样构造A矩阵 A = [zeros(4,1),diag([0.025,0.015,0.055,0.026])]
 %用zeros先构造4行1列的全是0的矩阵,因为x0没有风险率系数为0
 %再构造对角矩阵,对角线上的元素为约束条件中的变量x1 x2 x3 x4的系数
 
 %等式约束的系数矩阵
 Aeq = [1 1.01 1.02 1.045 1.065];
 
 %M设为1
 beq = 1;
 
 %xi的下界
 lb = [0;0;0;0;0];
 
 %初始化保存最优解的Q矩阵,现在还没求出最优解先初始化为0
 Q = zeros(1,length(a));
 
 %XX用来存不同风险率下的最优解
 XX = [];
 
 for i = 1:length(a)
     b = a(i)*ones(4,1); %b是约束条件中的常数项矩阵,4行1列,每个元素都是a
     [x,y] = linprog(f,A,b,Aeq,beq,lb); %x是对应的投资分配xi,是列向量的形式
     Q(i) = -y; %-y是总收益的最大值
     XX = [XX;x']; %每次更新XX矩阵,保存每一个a值下的投资分配
 end

plot(a,Q,"*r");
xlabel('风险率');        % x和y轴分别附上标签
ylabel('最大收益');

​​​​​​​

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/123684.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue3 简单实现虚拟Table,展示海量单词.利用WebAPI speechSynthesis,朗读英语单词

目录 本页面完整代码 视频演示 完整的页面代码 利用webapi speechSynthesis帮助我们自动郎读英语单词,可以利用这个API,做一些小说朗读或到账提示。 本页面完整代码 用Vue写了一个简单页面,里面还写了一个简单的虚拟Table支持海量数据展示…

ubuntu 18.04安装自己ko驱动 修改secure boot

因为本人老折腾自己的电脑,所以老重装系统,然后配置又不见了,这次配置赶紧记下来 insmod netlink_test.ko 报错:insmod: ERROR: could not insert module netlink_test.ko: Operation not permitted 添加 sudo insmod netlink_te…

XCTF刷题十一道(01)

文章目录 Training-WWW-RobotsPHP2unserialize3view-sourceget_postrobotsbackupcookiedisabled_buttonweak_authsimple_php Training-WWW-Robots robots.txt,防爬虫,访问urlrobots.txt PHP2 phps源码泄露 >phps文件就是php的源代码文件&#xff0…

swift语言用哪种库适合做爬虫?

目录 1、Alamofire 2、URLSession 3、YepHttp 4、Kickbox 5、Vapor 注意事项 总结 在Swift语言中,可以使用第三方库来帮助进行网络爬虫的开发。以下是几个适合Swift语言使用的爬虫库,以及相应的代码示例: 1、Alamofire Alamofire是Sw…

【k8s】pod控制器

一、pod控制器及其功用 Pod是kubernetes的最小管理单元,在kubernetes中,按照Pod的创建方式可以将其分为两类 自主式Pod: kubernetes直接创建出来的Pod,这种Pod删除后就没有了,也不会重建 控制器创建的Pod&#xff1a…

润和软件HopeStage与奇安信网神终端安全管理系统、可信浏览器完成产品兼容性互认证

近日,江苏润和软件股份有限公司(以下简称“润和软件”)HopeStage 操作系统与奇安信网神信息技术(北京)股份有限公司(以下简称“奇安信”)终端安全管理系统、可信浏览器完成产品兼容性测试。 测试…

多路转接(上)——select

目录 一、select接口 1.认识select系统调用 2.对各个参数的认识 二、编写select服务器 1.两个工具类 2.网络套接字封装 3.服务器类编写 4.源文件编写 5.运行 一、select接口 1.认识select系统调用 int select(int nfds, fd_set readfds, fd_set writefds, fd_set ex…

Node.js |(六)express框架 | 尚硅谷2023版Node.js零基础视频教程

学习视频:尚硅谷2023版Node.js零基础视频教程,nodejs新手到高手 文章目录 📚express使用🐇初体验🐇express路由⭐️路由的使用⭐️获取请求参数⭐️获取路由参数🔥练习:根据路由参数响应歌手信息…

小白学爬虫:通过关键词搜索1688商品列表数据接口|1688商品列表数据接口|1688商品列表数据采集|1688API接口

通过关键词搜索1688商品列表数据接口可以使用1688开放平台提供的API接口实现。以下是使用关键词搜索商品列表数据的基本步骤: 1、注册并获取AppKey。 2、构造请求参数,包括搜索关键词、页码、每页条数等。 3、通过API接口链接,将请求参数发送…

简单漂亮的登录页面

效果图 说明 开发环境&#xff1a;vue3&#xff0c;sass 代码 <template><div class"container"><div class"card-container"><div class"card-left"><span><h1>Dashboard</h1><p>Lorem ip…

后台管理系统解决方案-中大型-Vben Admin

后台管理系统解决方案-中大型-Vben Admin 官网 Vben Admin 在线演示 Vben Admin 为什么选择它 github现有20K星&#xff0c;并且它有个可视化生成表单&#xff0c;我很喜欢 快速开始 # 拉取代码 git clone https://github.com/vbenjs/vue-vben-admin-doc# 安装依赖 yarn#…

【ONE·C++ || 网络基础(二)】

总言 主要内容&#xff1a;演示socke套接字编程&#xff08;TCP模式&#xff09;&#xff0c;介绍序列化和反序列化&#xff0c;并进行演示&#xff08;json版本达成协议编写、守护进程介绍&#xff09;。 文章目录 总言4、基于套接字的TCP网络程序4.0、log.hpp4.1、version1.…

C++中将数据添加到文件的末尾

参考:https://blog.csdn.net/qq_23880193/article/details/44279283 C中文件的读取需要包含fstream文件&#xff0c;即&#xff1a;#include 文件的读取和写入是是通过流操作来的&#xff0c;这不像输入、输出流那样&#xff0c;库中已经定义了对象cin和cout 文件的读取需要声…

【 毕设项目源码推荐 javaweb 项目】 基于 springboot+vue 的图书个性化推荐系统的设计与实现(springboot003)

简介 :::warning 【 毕设项目源码推荐 javaweb 项目】 基于 springbootvue 的图书个性化推荐系统的设计与实现适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负…

Etcd 常用命令与备份恢复

1. etcd简介 官方网站&#xff1a;etcd.io 官方文档&#xff1a;etcd.io/docs/v3.5/op-guide/maintenance 官方硬件推荐&#xff1a;etcd.io/docs/v3.5/op-guide/hardware github地址&#xff1a;github.com/etcd-io/etcd etcd是CoreOS团队于2013年6月发起的开源项目&#xf…

算法--数据结构

这里写目录标题 本节内容链表与邻接表链表主要思想链表操作初始化在head结点后面插入普通插入删除操作 例子 双链表&#xff08;双向循环链表&#xff09;主要思想操作初始化双向插入删除第k个点 邻接表主要思想 栈和队列栈主要思想主要操作 队列主要思想操作 单调栈与单调队列…

Kafka中遇到的错误:

1、原因&#xff1a;kafka是一个去中心化结果的&#xff0c;所以在启动Kafka的时候&#xff0c;每一个节点上都需要启动。 启动的命令&#xff1a;kafka-server-start.sh -daemon /usr/local/soft/kafka_2.11-1.0.0/config/server.properties

【凡人修仙传】预计开播倒计时,线下举办超前观影活动,隆重期待

Hello,小伙伴们&#xff0c;我是小郑继续为大家深度解析国漫资讯。 深度爆料凡人最新资讯&#xff0c;《凡人修仙传》这部备受期待的动漫作品&#xff0c;终于在新年之际宣布了定档日期。据悉&#xff0c;该动漫将于11月25日&#xff0c;也就是周六上午11点&#xff0c;与广大…

【C++干货铺】STL简述 | string类的使用指南

个人主页点击直达&#xff1a;小白不是程序媛 C系列专栏&#xff1a;C干货铺 代码仓库&#xff1a;Gitee 目录 什么是STL STL的版本 STL的六大组件 STL的缺陷 string类 C语言中的字符串 标准库中的string类 string类常用的接口使用指南 string类中常见的构造 strin…

全国5米高程DEM数据及衍生的坡度数据

坡度是地表单元陡缓的程度&#xff0c;通常把坡面的垂直高度和水平距离的比值称为坡度。坡度的表示方法有百分比法、度数法、密位法和分数法四种&#xff0c;其中以百分比法和度数法较为常用。 坡度是地表单元陡缓的程度&#xff0c;通常把坡面的垂直高度和水平距离的比值称为坡…