天辰平台注册登录导航站
 
 

最优化方法(十五)有效集法解凸二次规划

浏览:次    发布日期:2024-05-06
#coding=gbk

'''
程序功能:
Date:2018.11.25
1、约束算法



'''

import sympy as sy
import numpy as np
import numpy.linalg as npl
import re
import matplotlib.pyplot as plt

#定义约束算法的类
class ConstrainedProgramming:
    

    #初始化
    def __init__(self,A,G,r,b,x):
        self.__A=A
        self.__G=G
        self.__r=r
        self.__b=b  #定义私有类变量
        

        self.__x=x
        n=len(self.__r)
        #print(n)
        
        self.__x=np.mat(self.__x).T  
        self.__indexM=self.__G.shape[0]+self.__A.T.shape[0]  #大矩阵的行
        self.__indexN=self.__G.shape[1]+self.__A.shape[1]  #大矩阵的列
        
        self.__calcResult()  

    #子函数计算处理
    def __calcResult(self):
    #fx=np.dot(fx,x)/2 # 
        fx=self.__objectiveFun()
        print('fx=',fx)
        

        
        AA=np.zeros((self.__indexM,self.__indexN))
        #print(AA)
        AA[0:self.__G.shape[0],0:self.__G.shape[1]]=self.__G
        AA[0:self.__G.shape[0],self.__G.shape[1]:self.__indexN]=self.__A 

        AA[self.__G.shape[0]:self.__indexM,0:self.__G.shape[1]]=self.__A.T
    
        #print(AA)
        bb=np.zeros((self.__indexM,1))
        #print(bb)
        bb[0:self.__G.shape[0]]=-self.__r

        bb[self.__G.shape[0]:self.__indexM]=self.__b
        #print(bb)
        self.__xx=npl.inv(AA).dot(bb) #
         
    
    
        
    #目标函数
    def __objectiveFun(self):
        fx=(self.__x.T).dot(self.__G).dot(self.__x)/2+self.__r.T.dot(self.__x)
        return fx
        #print(A)
        #print(b)
        
        
    #显示计算结果
    def show(self):
        print(self.__xx)
        print('---------------------------')
        print('无约束的解:\
',self.__xx[0:self.__G.shape[0]])
        print('无约束的乘因子:\
',self.__xx[self.__G.shape[0]:self.__indexM])

    #-------------------

#------------------------------
#定义约束算法有效集的类
class Youxiaoji:
    #初始化
    def __init__(self,x0,n,x):
        self.__n=n
        self.__x=x
        #print(self.__x)

       
        self.__num=10  #定义迭代次数
        self.__xinit=np.zeros((self.__num,2)) #计算的x点矩阵
        
        self.__xinit[0,:]=x0 #
        self.__d1fx=np.zeros((self.__num,2)) #一阶导数矩阵
        
        self.__calcResult()
    #------------------------------------------------------    
    #原函数的一阶导数   
    def __d1f(self): 
        f=self.__fun()
        y=[]
        for i in range(self.__n):
            y.append(sy.diff(f,self.__x[i]))
        y=np.array(y)
        print('d1f=',y)
        return y
    #------------------------------------------------------    
    #原函数
    def __fun(self):
        f=self.__x[0]**2+self.__x[1]**2-2*self.__x[0]-4*self.__x[1]
        return f
    #------------------------------------------------------
   #计算
    def __calcResult(self):
    
        f=self.__fun()
        print('f=',f)  
        d=self.__d1f()  
        for k in range(2): 
            self.__d1fx[0][k]=d[k].subs(self.__x[k],self.__xinit[0][k])
        print('----------------------')
        print('d1fx=\
',self.__d1fx)  #打印一阶导数值 



     #------------------------------------------------------   
    #显示结果
    def show(self):
       
        pass
     #------------------------------------------------------
 


#主函数
def main():
    
    #print(xx)
    #n=3
    #A=np.array([[1,2,-1],[1,-1,1]]).T
    #G=np.zeros((n,n))
    #r=np.zeros((n,1))
    #b=np.array([[4],[-2]])
    #x=sy.var('x1,x2,x3') #
    #for i in range(n):
    #    G[i][i]=2
    #--------------------------
    #n=2
    #A=np.array([[1,1]]).T
    #G=np.zeros((n,n))
    #r=np.zeros((n,1))
    #b=np.array([[1]])
    #x=sy.var('x1,x2') # 
    #for i in range(n):
    #    G[i][i]=2
    #c=ConstrainedProgramming(A,G,r,b,x) #定义类的对象
    #c.show()
    #---------约束初始条件-----------------
    n=2
    A=np.array([-1,0,0,-1]).reshape(2,2).T
    #print('A=',A)
    G=np.eye(n)*2
    #print('G=',G)
    r=np.array([-2,-4]).reshape(2,1)
    #print('r=',r)
    b=np.array([0,0]).reshape(2,1)
    #print('b=',b)
    x=sy.var('x1,x2') # 
    
    c=ConstrainedProgramming(A,G,r,b,x) #定义类的对象
    c.show()

    #--------------------------
    #有效集的程序初始化
    #x=sy.var('x1,x2') # 定义符号变量
    #n=len(x)
    #x0=np.array([[0,0]]) # 初始点
    #print('xinit=',x0)
    #v=Youxiaoji(x0,n,x)
    

main()


链接:pan.baidu.com/s/1FeSRIn

提取码:qndz


——2021.02.21——

平台注册入口