当前位置: 首页 > web >正文

数学建模——最大最小化模型

1.概念

最大最小化模型(Maximin Model)是一种优化方法,旨在最大化最坏情况下的收益或最小化最坏情况下的损失

常见的现实问题有:

求最大值的最小化问题

最大风险的最低限度

最小化最坏情况下的损失等

2.一般数学模型 

\underset{x}{min}\left \{ max[f_1(x)],max[f_2(x)] ,...,max[f_m(x)]\right \}(找最大值里面最小的)

s.t.\left\{\begin{matrix} Ax\leq b \\ Aeq\cdot x=beq \\ C(x)\leq 0 \\ Ceq(x)=0 \\ VLB\leq X\leq VUB \end{matrix}\right.

3.例题

 建立模型:

\underset{(x,y)}{min}\left \{ \underset{i}{max}[|x-a_i|+|y-b_i|] \right \}

s.t.\left\{\begin{matrix} 4\leq x \leq 16 \\ 3\leq y \leq 11 \end{matrix}\right.

函数套用:

fminimax
fun把目标函数定义成一个单独的函数文件(min)
x0决策变量的初始值
A,b线性约束不等式变量系数矩阵和常数项矩阵(左侧系数和右侧向量,支持\leq or<
Aeq,beq线性约束等式变量系数矩阵和常数项矩阵(左侧系数和右侧向量)
lb,ub决策变量的最小与最大取值(变量上下界)
nonlcon非线性约束(包括不等式与等式)
option求解非线性规划使用的方法

注意:fminimax函数与非线性规划的函数用法基本上一样,但是目标函数需要用函数向量表示如:

function \; f=fun(x)

f=zero(m,1)

f(1)=\cdots

f(2)=\cdots

          \vdots

f(m)=\cdots

代码:

%最大最小值问题
x0=[6,6];
lb=[4,3];
ub=[16,11];
[x,fval]=fminimax(@minimaxFun,x0,[],[],[],[],lb,ub);
max(fval)
x
function f=minimaxFun(x)a=[2 5 7 9 11 12 15 18];b=[3 8 12 5 9 2 7 4];f=zeros(8,1);for i= 1:8f(i)=abs(x(1)-a(i))+abs(x(2)-b(i));end
end

解释一下函数代码:

1  function f = fun(x)
  • 定义一个名为 fun 的函数,输入参数是 2×1 向量 x,输出是 8×1 向量 f
    x(1) 代表供应中心的横坐标,x(2) 代表纵坐标。

2      a = [ 1  4  3  5  9 12  6 20 17  8];
  • 行向量 a 存放 8 个需求点的 横坐标

3      b = [ 2 10  8 18  1  4  5 10  8  9];
  • 行向量 b 存放 8 个需求点的 纵坐标

4      f = zeros(10,1);
  • 预分配 8×1 的零向量 f,用来存 8 个距离值。
    预分配可以提高 MATLAB 效率,也可避免动态增长数组。

5      for i = 1:10
6          f(i) = abs(x(1) - a(i)) + abs(x(2) - b(i));
7      end
  • 循环 8 次,依次计算当前供应中心 (x(1), x(2)) 到第 i 个需求点的直角距离
    公式:|x − aᵢ| + |y − bᵢ|
    结果写入 f(i)

  • 该函数把 二维决策变量 (x,y) 映射到 8 个目标函数

  • fminimax 会把这 8 个数中的最大值作为要最小化的“最坏情况”目标,从而完成
    min_(x,y) max_i |x−aᵢ| + |y−bᵢ|
    的求解。

  • 这里其实就是完成了8个函数向量

http://www.xdnf.cn/news/16793.html

相关文章:

  • 硬件电路设计(基本元器件)
  • sqli-labs:Less-7关卡详细解析
  • 数据治理平台如何选?深度解析国产化全栈方案与行业落地实践
  • Charles中文教程 高效抓包与API接口调试实战全指南
  • 《汇编语言:基于X86处理器》第10章 复习题和练习
  • yolo8+阿里千问图片理解(华为简易版小艺看世界)
  • Docker常用命令速查手册:容器运维七维指南
  • Centos7 | 防火墙(firewalld)使用ipset管理ip地址的集合
  • 以ros的docker镜像为例,探讨docker镜像的使用
  • Power Pivot 数据分析表达式(DAX)
  • 《Java 程序设计》第 10 章 - 接口与 Lambda 表达式
  • HTML基础P2 | JS基础讲解
  • JSON.parse解析大整数踩坑
  • 重生之我在10天内卷赢C++ - DAY 1
  • 安全和AI方向的学习路线
  • Tdesign-React 模板面包屑如何放到 Header头部
  • 白话容器基础(一):进程
  • 2025年6月电子学会青少年软件编程(C语言)等级考试试卷(一级)
  • SSRF漏洞基础
  • Akamai CloudTest before 60 2025.06.02 XXE注入导致文件包含漏洞(CVE-2025-49493)
  • Solon v3.4.2(Java 应用开发生态基座)
  • T113-i Linux系统完整构建指南:从SDK开箱到内核镜像量产烧录全流程
  • 【力扣热题100】哈希——最长连续序列
  • MSVC编译KDChart过程
  • 实现了加载 正向 碰撞 雅可比 仿真
  • [SKE]UVM环境下OpenSSL加密算法参考模型设计
  • BOSMA博冠8K广播级讯道摄像机DC0300 EFP产品画册(下)
  • 利用SQL文件上传注入植入WebShell
  • 【从零实践Onvif】01、Onvif详细介绍(从Onvif客户端开发的角度认识Onvif、Web Servies、WSDL、SOAP)
  • SpringCloud -- MQ高级