国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

python實現最速下降法

瀏覽:8日期:2022-08-01 13:05:39

本文實例為大家分享了python實現最速下降法的具體代碼,供大家參考,具體內容如下

代碼:

from sympy import *import numpy as npdef backtracking_line_search(f,df,x,x_k,p_k,alpha0): rho=0.5 c=10**-4 alpha=alpha0 replacements1=zip(x,x_k) replacements2=zip(x,x_k+alpha*p_k) f_k=f.subs(replacements1) df_p=np.dot([df_.subs(replacements1) for df_ in df],p_k) while f.subs(replacements2)>f_k+c*alpha*df_p: alpha=rho*alpha replacements2 = zip(x, x_k +alpha * p_k) return alphadef stepest_line_search(f,x,x0,alpha0): df = [diff(f, x_) for x_ in x] x_k=x0 alpha=alpha0 replacements=zip(x,x_k) len_df = sqrt(np.sum([df_.subs(replacements) ** 2 for df_ in df])) while len_df>1e-6: p_k=-1*np.array([df_.subs(replacements) for df_ in df]) alpha = backtracking_line_search(f, df, x, x_k, p_k, alpha) x_k=x_k+alpha*p_k replacements = zip(x, x_k) len_df=np.sum([df_.subs(replacements)**2 for df_ in df]) return x_kif __name__=='__main__': init_printing(use_unicode=True) x1 = symbols('x1') x2 = symbols('x2') x = np.array([x1, x2]) f = 100 * (x2 - x1 ** 2)**2 + (1 - x1) ** 2 ans=stepest_line_search(f, x, np.array([1.2, 1]), 1) print 'the minimal value in point:',ans

分析:

這個采用的是backtracking line search來尋找alpha。

python實現最速下降法

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 宝坻区| 喜德县| 富顺县| 大安市| 禹城市| 黔西| 工布江达县| 调兵山市| 抚州市| 高雄市| 双峰县| 神农架林区| 宁安市| 偃师市| 诸城市| 海宁市| 襄城县| 申扎县| 宿松县| 达日县| 应城市| 秭归县| 临海市| 边坝县| 锡林郭勒盟| 潜江市| 双桥区| 罗甸县| 临朐县| 淮安市| 教育| 汶上县| 桂东县| 卫辉市| 扶余县| 米脂县| 嘉祥县| 彩票| 长海县| 隆德县| 阜宁县|