日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

基于Python共軛梯度法與最速下降法之間的對比

瀏覽:33日期:2022-07-31 10:16:11

在一般問題的優化中,最速下降法和共軛梯度法都是非常有用的經典方法,但最速下降法往往以”之”字形下降,速度較慢,不能很快的達到最優值,共軛梯度法則優于最速下降法,在前面的某個文章中,我們給出了牛頓法和最速下降法的比較,牛頓法需要初值點在最優點附近,條件較為苛刻。

算法來源:《數值最優化方法》高立,P111

我們選用了64維的二次函數來作為驗證函數,具體參見上書111頁。

采用的三種方法為:

共軛梯度方法(FR格式)、共軛梯度法(PRP格式)、最速下降法

# -*- coding: utf-8 -*-'''Created on Sat Oct 01 15:01:54 2016@author: zhangweiguo'''import sympy,numpyimport mathimport matplotlib.pyplot as plfrom mpl_toolkits.mplot3d import Axes3D as ax3import SD#這個文件里有最速下降法SD的方法,參見前面的博客#共軛梯度法FR、PRP兩種格式def CG_FR(x0,N,E,f,f_d): X=x0;Y=[];Y_d=[]; n = 1 ee = f_d(x0) e=(ee[0]**2+ee[1]**2)**0.5 d=-f_d(x0) Y.append(f(x0)[0,0]);Y_d.append(e) a=sympy.Symbol(’a’,real=True) print ’第%2s次迭代:e=%f’ % (n, e) while n<N and e>E: n=n+1 g1=f_d(x0) f1=f(x0+a*f_d(x0)) a0=sympy.solve(sympy.diff(f1[0,0],a,1)) x0=x0-d*a0 X=numpy.c_[X,x0];Y.append(f(x0)[0,0]) ee = f_d(x0) e = math.pow(math.pow(ee[0,0],2)+math.pow(ee[1,0],2),0.5) Y_d.append(e) g2=f_d(x0) beta=(numpy.dot(g2.T,g2))/numpy.dot(g1.T,g1) d=-f_d(x0)+beta*d print ’第%2s次迭代:e=%f’%(n,e) return X,Y,Y_ddef CG_PRP(x0,N,E,f,f_d): X=x0;Y=[];Y_d=[]; n = 1 ee = f_d(x0) e=(ee[0]**2+ee[1]**2)**0.5 d=-f_d(x0) Y.append(f(x0)[0,0]);Y_d.append(e) a=sympy.Symbol(’a’,real=True) print ’第%2s次迭代:e=%f’ % (n, e) while n<N and e>E: n=n+1 g1=f_d(x0) f1=f(x0+a*f_d(x0)) a0=sympy.solve(sympy.diff(f1[0,0],a,1)) x0=x0-d*a0 X=numpy.c_[X,x0];Y.append(f(x0)[0,0]) ee = f_d(x0) e = math.pow(math.pow(ee[0,0],2)+math.pow(ee[1,0],2),0.5) Y_d.append(e) g2=f_d(x0) beta=(numpy.dot(g2.T,g2-g1))/numpy.dot(g1.T,g1) d=-f_d(x0)+beta*d print ’第%2s次迭代:e=%f’%(n,e) return X,Y,Y_dif __name__==’__main__’: ’’’ G=numpy.array([[21.0,4.0],[4.0,15.0]]) #G=numpy.array([[21.0,4.0],[4.0,1.0]]) b=numpy.array([[2.0],[3.0]]) c=10.0 x0=numpy.array([[-10.0],[100.0]]) ’’’ m=4 T=6*numpy.eye(m) T[0,1]=-1;T[m-1,m-2]=-1 for i in xrange(1,m-1): T[i,i+1]=-1 T[i,i-1]=-1 W=numpy.zeros((m**2,m**2)) W[0:m,0:m]=T W[m**2-m:m**2,m**2-m:m**2]=T W[0:m,m:2*m]=-numpy.eye(m) W[m**2-m:m**2,m**2-2*m:m**2-m]=-numpy.eye(m) for i in xrange(1,m-1): W[i*m:(i+1)*m,i*m:(i+1)*m]=T W[i*m:(i+1)*m,i*m+m:(i+1)*m+m]=-numpy.eye(m) W[i*m:(i+1)*m,i*m-m:(i+1)*m-m]=-numpy.eye(m) mm=m**2 mmm=m**3 G=numpy.zeros((mmm,mmm)) G[0:mm,0:mm]=W;G[mmm-mm:mmm,mmm-mm:mmm]=W; G[0:mm,mm:2*mm]=-numpy.eye(mm) G[mmm-mm:mmm,mmm-2*mm:mmm-mm]=-numpy.eye(mm) for i in xrange(1,m-1): G[i*mm:(i+1)*mm,i*mm:(i+1)*mm]=W G[i*mm:(i+1)*mm,i*mm-mm:(i+1)*mm-mm]=-numpy.eye(mm) G[i*mm:(i+1)*mm,i*mm+mm:(i+1)*mm+mm]=-numpy.eye(mm) x_goal=numpy.ones((mmm,1)) b=-numpy.dot(G,x_goal) c=0 f = lambda x: 0.5 * (numpy.dot(numpy.dot(x.T, G), x)) + numpy.dot(b.T, x) + c f_d = lambda x: numpy.dot(G, x) + b x0=x_goal+numpy.random.rand(mmm,1)*100 N=100 E=10**(-6) print ’共軛梯度PR’ X1, Y1, Y_d1=CG_FR(x0,N,E,f,f_d) print ’共軛梯度PBR’ X2, Y2, Y_d2=CG_PRP(x0,N,E,f,f_d) figure1=pl.figure(’trend’) n1=len(Y1) n2=len(Y2) x1=numpy.arange(1,n1+1) x2=numpy.arange(1,n2+1) X3, Y3, Y_d3=SD.SD(x0,N,E,f,f_d) n3=len(Y3) x3=range(1,n3+1) pl.semilogy(x3,Y3,’g*’,markersize=10,label=’SD:’+str(n3)) pl.semilogy(x1,Y1,’r*’,markersize=10,label=’CG-FR:’+str(n1)) pl.semilogy(x2,Y2,’b*’,markersize=10,label=’CG-PRP:’+str(n2)) pl.legend() #圖像顯示了三種不同的方法各自迭代的次數與最優值變化情況,共軛梯度方法是明顯優于最速下降法的 pl.xlabel(’n’) pl.ylabel(’f(x)’) pl.show()

最優值變化趨勢:

基于Python共軛梯度法與最速下降法之間的對比

從圖中可以看出,最速下降法SD的迭代次數是最多的,在與共軛梯度(FR與PRP兩種方法)的比較中,明顯較差。

補充知識:python實現牛頓迭代法和二分法求平方根,精確到小數點后無限多位-4

首先來看一下牛頓迭代法求平方根的過程:計算3的平方根

基于Python共軛梯度法與最速下降法之間的對比

如圖,是求根號3的牛頓迭代法過程。這里使用的初始迭代值(也就是猜測值)為1,其實可以為任何值最終都能得到結果。每次開始,先檢測猜測值是否合理,不合理時,用上面的平均值來換掉猜測值,依次繼續迭代,直到猜測值合理。

原理:現在取一個猜測值 a, 如果猜測值合理的話,那么就有a^2=x,即x/a=a ,x為被開方數。不合理的話呢,就用表中的猜測值和商的平均值來換掉猜測值。當不合理時,比如 a>真實值,那么x/a<真實值,這時候取a 與 x/a 的平均值來代替a的話,那么新的a就會比原來的a要更接近真實值。同理有 a<真實值 的情況。于是,這樣不斷迭代下去最終是一個a不斷收斂到真實值的一個過程。于是不斷迭代就能得到真實值,證明了迭代法是正確的。

附上我的python代碼:

利用python整數運算,python整數可以無限大,可以實現小數點后無限多位

#二分法求x的平方根小數點下任意K位數的精準值,利用整數運算 #思想:利用二分法,每次乘以10,取中間值,比較大小,從而定位精確值的范圍,將根擴大10倍,則被開方數擴大100倍。 #quotient(商)牛頓迭代法:先猜測一個值,再求商,然后用猜測值和商的中間值代替猜測值,擴大倍數,繼續進行。

import mathfrom math import sqrt def check_precision(l,h,p,len1):#檢查是否達到了精確位 l=str(l);h=str(h) if len(l)<=len1+p or len(h)<=len1+p: return False for i in range(len1,p+len1):#檢查小數點后面的p個數是否相等 if l[i]!=h[i]: #當l和h某一位不相等時,說明沒有達到精確位 return False return True def print_result(x,len1,p): x=str(x) if len(x)-len1<p:#沒有達到要求的精度就已經找出根 s=x[:len1]+'.'+x[len1:]+’0’*(p-len(x)+len1) else:s=x[:len1]+'.'+x[len1:len1+p] print(s) def binary_sqrt(x,p): x0=int(sqrt(x)) if x0*x0==x: #完全平方數直接開方,不用繼續進行 print_result(x0,len(str(x0)),p) return len1=len(str(x0))#找出整數部分的長度 l=0;h=x while(not check_precision(l,h,p,len1)):#沒有達到精確位,繼續循環 if not l==0:#第一次l=0,h=x時不用乘以10,直接取中間值 h=h*10 #l,h每次擴大10倍 l=l*10 x=x*100 #x每次要擴大100倍,因為平方 m=(l+h)//2 if m*m==x: return print_result(m,len1,p) elif m*m>x: h=m else: l=m return print_result(l,len1,p)#當達到了要求的精度,直接返回l #牛頓迭代法求平方根def newton_sqrt(x,p): x0=int(sqrt(x)) if x0*x0==x: #完全平方數直接開方,不用繼續進行 print_result(x0,len(str(x0)),p) return len1=len(str(x0))#找出整數部分的長度 g=1;q=x//g;g=(g+q)//2 while(not check_precision(g,q,p,len1)): x=x*100 g=g*10 q=x//g #求商 g=(g+q)//2 #更新猜測值為猜測值和商的中間值 return print_result(g,len1,p) while True: x=int(input('請輸入待開方數:')) p=int(input('請輸入精度:')) print('binary_sqrt:',end='') binary_sqrt(x,p) print('newton_sqrt:',end='') newton_sqrt(x,p)

以上這篇基于Python共軛梯度法與最速下降法之間的對比就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品一区二区精品| 久久精品国内一区二区三区| 色爱综合网欧美| 国产成人免费精品| 久久久久久网| 日本高清不卡一区二区三区视频 | 日本久久一区| 国产精品久久久久av蜜臀| 欧美aa在线视频| 日韩精品2区| 免费中文字幕日韩欧美| 欧美日韩国产高清| 婷婷精品久久久久久久久久不卡| 国产欧美日韩一区二区三区四区| 久久中文精品| 婷婷综合网站| 欧美日韩一区二区三区四区在线观看 | 国产日韩高清一区二区三区在线| 麻豆一区二区在线| 久久久9色精品国产一区二区三区| 在线视频精品| 日韩美女精品| 国产极品模特精品一二| 久久中文字幕av一区二区不卡| 蜜桃伊人久久| 国产日本精品| 成人在线视频区| 欧美日韩水蜜桃| 日韩精品亚洲一区二区三区免费| 久久久久久自在自线| 亚洲欧美日本日韩| 麻豆视频久久| 婷婷中文字幕一区| 国产另类在线| 亚洲激情二区| 免费在线亚洲欧美| 亚洲激情黄色| 国产调教精品| 国产综合欧美| 国产日本精品| 中文精品在线| 性欧美videohd高精| 日韩高清中文字幕一区| 久久免费大视频| 国产精品天天看天天狠| 亚洲自拍另类| 欧美国产小视频| 亚洲精品美女91| 国产99久久| 精品72久久久久中文字幕| 美女久久网站| 99久久亚洲精品| 日韩激情一区二区| 国产精品7m凸凹视频分类| 欧美国产极品| 日韩精品国产欧美| 国内激情久久| 综合日韩av| 国产剧情在线观看一区| 视频一区在线视频| 欧美不卡高清一区二区三区| 国产欧美久久一区二区三区| 影院欧美亚洲| 欧美好骚综合网| 亚洲精品欧洲| 欧美69视频| 91日韩免费| 在线亚洲观看| 欧美日韩一二三四| 国产精品一站二站| 日韩国产一区二| a日韩av网址| 欧美另类中文字幕| 在线综合亚洲| 日韩中文在线播放| 久久精品国产一区二区| 国产九九精品| 国产剧情在线观看一区| 久久精品凹凸全集| 亚洲欧美在线综合| 视频一区二区国产| 久久av一区| 欧美在线亚洲| 激情久久久久久久| 999国产精品| 国产精品亚洲一区二区三区在线观看| 国产在线不卡一区二区三区| 国产欧美在线观看免费| 青青草国产精品亚洲专区无| 日本亚洲视频| 婷婷综合成人| 色综合视频一区二区三区日韩| 蜜桃视频第一区免费观看| 免费成人在线影院| 偷拍亚洲精品| 日韩激情视频网站| 日本强好片久久久久久aaa| 美女久久久久| 国产免费成人| 日韩国产在线不卡视频| 国产精品香蕉| 久久精品国内一区二区三区| 97精品国产一区二区三区 | 亚洲精品乱码久久久久久蜜桃麻豆| 在线一区二区三区视频| 日韩国产欧美在线视频| 欧美国产精品| 久久精品国产精品亚洲毛片| 成人精品国产亚洲| 97精品在线| 成人午夜精品| 欧美资源在线| 国产午夜一区| 韩国女主播一区二区三区| 婷婷综合六月| 老司机久久99久久精品播放免费| 日本中文字幕一区二区| 国产精品videosex极品| 成人污污视频| 午夜欧美精品久久久久久久| 日韩中文字幕不卡| 国产精品综合色区在线观看| 国产va在线视频| 亚洲一区黄色| 欧美亚洲自偷自偷| 成人在线超碰| 国产亚洲亚洲| 国产欧美成人| 久久久久久久久久久妇女| 免费一级片91| 国产91欧美| 久久先锋影音| 国产精品mv在线观看| 日韩欧美三级| 久久亚洲影院| 久久三级毛片| 日韩视频精品在线观看| 国产精品调教| 激情综合激情| 亚洲免费一区三区| 国产一区二区三区四区五区传媒| 欧美 日韩 国产一区二区在线视频| 日本视频一区二区| 亚洲成人一区在线观看| 影音先锋久久精品| 精品亚洲免a| 日韩中文字幕麻豆| zzzwww在线看片免费| 亚洲三级观看| 丝袜av一区| 国产精品亚洲人成在99www | 福利精品在线| 亚洲区欧美区| 精品资源在线| 亚洲神马久久| 欧美国产小视频| 91精品视频一区二区| 欧美va天堂| 精品视频黄色| 亚洲综合专区| 亚洲午夜在线| 91亚洲人成网污www| 日韩久久99| 中文字幕在线看片| 97久久超碰| 中文精品视频| 97视频热人人精品免费| 亚洲青青久久| 日本久久黄色| 日本一区二区三区中文字幕| 欧美日韩中文一区二区| 国产精品任我爽爆在线播放| 国产亚洲精品v| 播放一区二区| 久久久国产精品入口麻豆 | 在线视频日韩| 日韩毛片视频| 精品久久91| 国产三级精品三级在线观看国产| 久久亚洲视频| 日韩视频中文| 国产精品毛片一区二区在线看| 日本成人中文字幕| 水野朝阳av一区二区三区| 激情综合网站| 天堂资源在线亚洲| 亲子伦视频一区二区三区| 国产在线观看91一区二区三区| 日韩不卡在线观看日韩不卡视频| 一区二区视频欧美| 激情丁香综合| 亚洲www啪成人一区二区| 成人日韩av| 国产精品二区不卡| 精品国产乱码久久久| 国产精品亚洲片在线播放| 一区二区三区四区日韩| 性一交一乱一区二区洋洋av| 午夜精品一区二区三区国产| 精品在线播放|