资源描述:
《线性规划,建模,lingo算法》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、第一章线性规划§1线性规划在人们的生产实践中,经常会遇到如何利用现有资源来安排生产,以取得最大经济效益的问题。此类问题构成了运筹学的一个重要分支—数学规划,而线性规划(LinearProgramming简记LP)则是数学规划的一个重要分支。自从1947年G.B.Dantzig提出求解线性规划的单纯形方法以来,线性规划在理论上趋向成熟,在实用中日益广泛与深入。特别是在计算机能处理成千上万个约束条件和决策变量的线性规划问题之后,线性规划的适用领域更为广泛了,已成为现代管理中经常采用的基本方法之一。1.1线性规划的实例与定义例1某机床厂生产甲、乙两种机床,每台销售后的利润分别为4000元
2、与3000元。生产甲机床需用A、B机器加工,加工时间分别为每台2小时和1小时;生产乙机床需用A、B、C三种机器加工,加工时间为每台各一小时。若每天可用于加工的机器时数分别为A机器10小时、B机器8小时和C机器7小时,问该厂应生产甲、乙机床各几台,才能使总利润最大?上述问题的数学模型:设该厂生产x台甲机床和x乙机床时总利润最大,则x,x1212应满足(目标函数)maxz=4x+3x(1)12⎧2x1+x2≤10⎪⎪x1+x2≤8s.t.(约束条件)⎨(2)x≤7⎪2⎪⎩x1,x2≥0这里变量x,x称之为决策变量,(1)式被称为问题的目标函数,(2)中的几个不等式12是问题的约束条件,
3、记为s.t.(即subjectto)。由于上面的目标函数及约束条件均为线性函数,故被称为线性规划问题。总之,线性规划问题是在一组线性约束条件的限制下,求一线性目标函数最大或最小的问题。在解决实际问题时,把问题归结成一个线性规划数学模型是很重要的一步,但往往也是困难的一步,模型建立得是否恰当,直接影响到求解。而选适当的决策变量,是我们建立有效模型的关键之一。1.2线性规划的Matlab标准形式线性规划的目标函数可以是求最大值,也可以是求最小值,约束条件的不等号可以是小于号也可以是大于号。为了避免这种形式多样性带来的不便,Matlab中规定线性规划的标准形式为Tmincxx⎧Ax≤b⎪
4、s.t.⎨Aeq⋅x=beq⎪⎩lb≤x≤ub其中c和x为n维列向量,A、Aeq为适当维数的矩阵,b、beq为适当维数的列向量。-1-例如线性规划Tmaxcxs.t.Ax≥bx的Matlab标准型为Tmin−cxs.t.−Ax≤−bx1.3线性规划问题的解的概念一般线性规划问题的(数学)标准型为nmaxz=∑cjxj(3)j=1n⎧⎪∑aijxj=bii=1,2,L,ms.t.⎨j=1(4)⎪x≥0j=1,2,L,n⎩j可行解满足约束条件(4)的解x=(x,x,L,x),称为线性规划问题的可行解,12n而使目标函数(3)达到最大值的可行解叫最优解。可行域所有可行解构成的集合称为问题
5、的可行域,记为R。1.4线性规划的图解法1092x1+x2=1087x2=76(2,6)5432x1+x2=81z=1200246810图1线性规划的图解示意图图解法简单直观,有助于了解线性规划问题求解的基本原理。我们先应用图解法来求解例1。对于每一固定的值z,使目标函数值等于z的点构成的直线称为目标函数等位线,当z变动时,我们得到一族平行直线。对于例1,显然等位线越趋于右上方,其T上的点具有越大的目标函数值。不难看出,本例的最优解为x*=(2,6),最优目标值z*=26。从上面的图解过程可以看出并不难证明以下断言:(1)可行域R可能会出现多种情况。R可能是空集也可能是非空集合,当
6、R非空时,它必定是若干个半平面的交集(除非遇到空间维数的退化)。R既可能是有界区域,也可能是无界区域。(2)在R非空时,线性规划既可以存在有限最优解,也可以不存在有限最优解(其目标函数值无界)。-2-(3)若线性规划存在有限最优解,则必可找到具有最优目标函数值的可行域R的“顶点”。上述论断可以推广到一般的线性规划问题,区别只在于空间的维数。在一般的n维n空间中,满足一线性等式∑aixi=b的点集被称为一个超平面,而满足一线性不等式i=1nn∑aixi≤b(或∑aixi≥b)的点集被称为一个半空间(其中(a1,L,an)为一n维行i=1i=1向量,b为一实数)。若干个半空间的交集被称
7、为多胞形,有界的多胞形又被称为多面体。易见,线性规划的可行域必为多胞形(为统一起见,空集Φ也被视为多胞形)。在一般n维空间中,要直接得出多胞形“顶点”概念还有一些困难。二维空间中的顶点可以看成为边界直线的交点,但这一几何概念的推广在一般n维空间中的几何意义并不十分直观。为此,我们将采用另一途径来定义它。12定义1称n维空间中的区域R为一凸集,若∀x,x∈R及∀λ∈(0,1),有12λx+(1−λ)x∈R。定义2设R为n维空间中的一个凸集,R中的点x被称为R的一个极点,