
本文将探究一个被称为二次规划的优化问题,这是一种特殊形式的非线性约束优化问题。二次规划在许多领域都有运用,比如投资组合优化、求解支持向量机(SVM)分类问题等。在R中求解二次规划有许多包,这次,我们将讨论一下quadprog包。在我们开始讲解案例之前,我们将先简短地介绍一下二次规划的机理。
对于一个二次规划问题,首先要考虑的就是一个二次目标函数:
Q(x)=12xTDx−dTx+c.
这里 x 在 ℝn 中是一个向量, D 是一个n×n 的对称正定矩阵,在 ℝn 中 d 是常数项约束,c 是一个标量常数。Q(x)函数通常以二次函数的形式出现,并且它高维的通项表达式是:
q(x)=ax2+bx+c
Q(x)的关键特性在于这是一个凸函数。
我们也对向量x构造一个线性约束集合,即x ∈ℝn。
我们把这些约束写成:
Ax=fBx≥g
这里,A 是一个 m1×n 的矩阵且约束为 m1≤n,BB 是一个 m2×n 的矩阵.向量 f 和向量 g的长度分别是m1和m2.
这是一种让我们可以充分考虑实际条件的标准型。比如我们让 x 强制满足
∑i=1nxi=1
的求和条件,或者满足ai≤xi≤bi的区间约束。接下来,我们将介绍如何将这些约束转化为矩阵表达。
用这个符号系统,我们可以简洁表示二次规划 (QP):
{minimizex∈ℝn:Q(x)=12xTDx−dTx+csubjectto:Ax=fBx≥g
考虑目标函数:
Q(x,y)==12[xy][2−1−12][xy]−[−32][xy]+4x2+y2−xy+3x−2y+4.
我们这个约束条件下的可行域内寻求最小化:
yyy≥≥≤2−x−2+x3.
我们可以找到这个可行域的顶点并在R画出整个可行域:
plot(0, 0, xlim = c(-2,5.5), ylim = c(-1,3.5), type = "n", xlab = "x", ylab = "y", main="Feasible Region") polygon(c(2,5,-1), c(0,3,3), border=TRUE, lwd=4, col="blue")
SHAPE \* MERGEFORMAT
想要用quadprog包求解二次规划,我们需要同时转化我们的目标函数和约束条件为矩阵形式。这里是官方文档的说明:
This routine implements the dual method of Goldfarb and Idnani (1982, 1983) for solving quadratic programming problems of the form min(-d^T b + 1/2 b^T D b) with the constraints A^T b >= b_0.
可惜官方文档多可读性不高,我们很难得知如何准确地转化二次型Q(x,y)为一个矩阵形式。首先,我们观察到,对于任意常数 c, 都存在MinQ(x,y)+c 和 Q(x,y)的解相等。因此,我们可以忽略二次规划中的常数项:
D=[2−1−12]d=[−32].
我们可以写出约束方程的矩阵形式:
⎡⎣⎢⎢1−1011−1⎤⎦⎥⎥[xy]≥⎡⎣⎢⎢2−2−3⎤⎦⎥⎥
因此:
A=⎡⎣⎢⎢1−1011−1⎤⎦⎥⎥Tb0=⎡⎣⎢⎢2−2−3⎤⎦⎥⎥
quadprog包默认是求解最小化问题,目标函数二次,约束一次。所以,我们的约束条件默认的形式也就是AX>=bvec。通常我们需要把一些原来是求极大值的问题或者<=约束通过乘以负号来转化。
这是R的完整实现:
· 参数Dmat表示海赛矩阵
· 参数dvet表示一阶向量,和Dmat的维数要相对应。
· 参数Amat表示约束矩阵,默认的约束都是是>=。
· 参数bvet表示右边值,由向量,和Amat的维数要相对应。
· 参数 meq 表示从哪一行开始Amat矩阵中的约束是需要被当作等式约束的。
(1/6,11/6) 点是唯一满足约束条件和 Q(x,y)的最小化目标,但 (−4/3,1/3)点才是 Q(x,y) 的最小值点。iterations,Lagrangian 和 iact 都是用来描述quadprog算法性能的。对于这些值之后我们将进一步讨论。现在,让我们先可视化二次规划的解。为此,我们在Q(x,y)的可行域边界添加一个外侧的等高线图。
在图中,深绿色区域表示Q(x,y) 表面目标函数值较小的解,而亮色表示目标函数值较大的解。红点是Q(x,y)的全局最小值点,而黄点表示二次规划的解。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
ALTER TABLE ADD 多个 INDEX:数据库批量索引优化的高效实践 在数据库运维与性能优化中,索引是提升查询效率的核心手段。当业务 ...
2025-08-27Power BI 去重函数:数据清洗与精准分析的核心工具 在企业数据分析流程中,数据质量直接决定分析结果的可靠性。Power BI 作为主 ...
2025-08-27CDA 数据分析师:数据探索与统计分析的实践与价值 在数字化浪潮席卷各行业的当下,数据已成为企业核心资产,而 CDA(Certif ...
2025-08-27t 检验与 Wilcoxon 检验:数据差异比较的两大统计利器 在数据分析中,“比较差异” 是核心需求之一 —— 如新药疗效是否优于旧药 ...
2025-08-26季节性分解外推法:解锁时间序列预测的规律密码 在商业决策、资源调度、政策制定等领域,准确的预测是规避风险、提升效率的关键 ...
2025-08-26CDA 数据分析师:数据治理驱动下的企业数据价值守护者 在数字经济时代,数据已成为企业核心战略资产,其价值的释放离不开高 ...
2025-08-26基于 SPSS 的 ROC 曲线平滑调整方法与实践指南 摘要 受试者工作特征曲线(ROC 曲线)是评估诊断模型或预测指标效能的核心工具, ...
2025-08-25神经网络隐藏层神经元个数的确定方法与实践 摘要 在神经网络模型设计中,隐藏层神经元个数的确定是影响模型性能、训练效率与泛 ...
2025-08-25CDA 数据分析师与数据思维:驱动企业管理升级的核心力量 在数字化浪潮席卷全球的当下,数据已成为企业继人力、物力、财力之后的 ...
2025-08-25CDA数据分析师与数据指标:基础概念与协同逻辑 一、CDA 数据分析师:数据驱动时代的核心角色 1.1 定义与行业价值 CDA(Certified ...
2025-08-22Power Query 移动加权平均计算 Power Query 移动加权平均设置全解析:从原理到实战 一、移动加权平均法的核心逻辑 移动加权平均 ...
2025-08-22描述性统计:CDA数据分析师的基础核心与实践应用 一、描述性统计的定位:CDA 认证的 “入门基石” 在 CDA(Certified Data Analy ...
2025-08-22基于 Python response.text 的科技新闻数据清洗去噪实践 在通过 Python requests 库的 response.text 获取 API 数据后,原始数据 ...
2025-08-21基于 Python response.text 的科技新闻综述 在 Python 网络爬虫与 API 调用场景中,response.text 是 requests 库发起请求后获取 ...
2025-08-21数据治理新浪潮:CDA 数据分析师的战略价值与驱动逻辑 一、数据治理的多维驱动引擎 在数字经济与人工智能深度融合的时代,数据治 ...
2025-08-21Power BI 热力地图制作指南:从数据准备到实战分析 在数据可视化领域,热力地图凭借 “直观呈现数据密度与分布趋势” 的核心优势 ...
2025-08-20PyTorch 矩阵运算加速库:从原理到实践的全面解析 在深度学习领域,矩阵运算堪称 “计算基石”。无论是卷积神经网络(CNN)中的 ...
2025-08-20数据建模:CDA 数据分析师的核心驱动力 在数字经济浪潮中,数据已成为企业决策的核心资产。CDA(Certified Data Analyst)数据分 ...
2025-08-20KS 曲线不光滑:模型评估的隐形陷阱,从原因到破局的全指南 在分类模型(如风控违约预测、电商用户流失预警、医疗疾病诊断)的评 ...
2025-08-20偏态分布:揭开数据背后的非对称真相,赋能精准决策 在数据分析的世界里,“正态分布” 常被视为 “理想模型”—— 数据围绕均值 ...
2025-08-19