python實現(xiàn)爬山算法的思路詳解
更新時間:2019年04月09日 13:53:19 作者:小太陽花兒
爬山算法會收斂到局部最優(yōu),解決辦法是初始值在定義域上隨機取亂數(shù)100次,總不可能100次都那么倒霉。這篇文章主要介紹了python實現(xiàn)爬山算法的思路詳解,需要的朋友可以參考下
問題

找圖中函數(shù)在區(qū)間[5,8]的最大值
重點思路
爬山算法會收斂到局部最優(yōu),解決辦法是初始值在定義域上隨機取亂數(shù)100次,總不可能100次都那么倒霉。
實現(xiàn)
import numpy as np
import matplotlib.pyplot as plt
import math
# 搜索步長
DELTA = 0.01
# 定義域x從5到8閉區(qū)間
BOUND = [5,8]
# 隨機取亂數(shù)100次
GENERATION = 100
def F(x):
return math.sin(x*x)+2.0*math.cos(2.0*x)
def hillClimbing(x):
while F(x+DELTA)>F(x) and x+DELTA<=BOUND[1] and x+DELTA>=BOUND[0]:
x = x+DELTA
while F(x-DELTA)>F(x) and x-DELTA<=BOUND[1] and x-DELTA>=BOUND[0]:
x = x-DELTA
return x,F(x)
def findMax():
highest = [0,-1000]
for i in range(GENERATION):
x = np.random.rand()*(BOUND[1]-BOUND[0])+BOUND[0]
currentValue = hillClimbing(x)
print('current value is :',currentValue)
if currentValue[1] > highest[1]:
highest[:] = currentValue
return highest
[x,y] = findMax()
print('highest point is x :{},y:{}'.format(x,y))
運行結(jié)果:

總結(jié)
以上所述是小編給大家介紹的python實現(xiàn)爬山算法的思路詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
您可能感興趣的文章:
- 爬山算法簡介和Python實現(xiàn)實例
- python中K-means算法基礎(chǔ)知識點
- python 圖像增強算法實現(xiàn)詳解
- python 實現(xiàn)Harris角點檢測算法
- Python實現(xiàn)迪杰斯特拉算法并生成最短路徑的示例代碼
- python里反向傳播算法詳解
- python動態(tài)規(guī)劃算法實例詳解
- python的數(shù)學(xué)算法函數(shù)及公式用法
- Python實現(xiàn)冒泡排序算法的完整實例
- python 實現(xiàn)非極大值抑制算法(Non-maximum suppression, NMS)
- Python實現(xiàn)隨機爬山算法
相關(guān)文章
Python數(shù)據(jù)擬合實現(xiàn)最小二乘法示例解析
這篇文章主要為大家介紹了Python數(shù)據(jù)擬合實現(xiàn)最小二乘法的示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2021-10-10
Python實現(xiàn)統(tǒng)計文本文件字數(shù)的方法
這篇文章主要介紹了Python實現(xiàn)統(tǒng)計文本文件字數(shù)的方法,涉及Python針對文本文件讀取及字符串轉(zhuǎn)換、運算等相關(guān)操作技巧,需要的朋友可以參考下2017-05-05

