时间:2021-05-22
本文实例讲述了python中黄金分割法实现方法。分享给大家供大家参考。具体实现方法如下:
''' a,b = bracket(f,xStart,h) Finds the brackets (a,b) of a minimum point of the user-supplied scalar function f(x). The search starts downhill from xStart with a step length h. x,fMin = search(f,a,b,tol=1.0e-6) Golden section method for determining x that minimizes the user-supplied scalar function f(x). The minimum must be bracketed in (a,b).''' from math import log, ceildef bracket(f,x1,h): c = 1.618033989 f1 = f(x1) x2 = x1 + h; f2 = f(x2) # Determine downhill direction and change sign of h if needed if f2 > f1: h = -h x2 = x1 + h; f2 = f(x2) # Check if minimum between x1 - h and x1 + h if f2 > f1: return x2,x1 - h # Search loop for i in range (100): h = c*h x3 = x2 + h; f3 = f(x3) if f3 > f2: return x1,x3 x1 = x2; x2 = x3 f1 = f2; f2 = f3 print "Bracket did not find a mimimum" def search(f,a,b,tol=1.0e-9): nIter = int(ceil(-2.078087*log(tol/abs(b-a)))) # Eq. (10.4) R = 0.618033989 C = 1.0 - R # First telescoping x1 = R*a + C*b; x2 = C*a + R*b f1 = f(x1); f2 = f(x2) # Main loop for i in range(nIter): if f1 > f2: a = x1 x1 = x2; f1 = f2 x2 = C*a + R*b; f2 = f(x2) else: b = x2 x2 = x1; f2 = f1 x1 = R*a + C*b; f1 = f(x1) if f1 < f2: return x1,f1 else: return x2,f2希望本文所述对大家的Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
元素一:结构排版网站布局的黄金部分的使用非常重要,即结构部分的使用。黄金分割是一种古老的数学方法。黄金分割的创始人是古希腊的毕达哥拉斯。大胆地断言:如果一个线段
为了更好地不消耗广告图的部位,又能吸引住消费者,制做关键取决于黄金比例占比:1比1.618。应用黄金分割比例做海报图,是最具观赏价值的。除开黄金分割比例外,制做
希腊Web设计师ChristosChiotis发表在CssGlobe的一篇文章,讲述了黄金分割率在CSS中的应用。黄金分割率是一个应用广泛的数学常数,大约为1.
尤其是黄金分割,也被称为神之比例,希腊字母表示其为Φ(phi).本教程会剖析一个网站的布局,以及如何对其黄金分割。网页结构这些是web页面的主要元素。有
黄金比例和使用网格。黄金比例广泛运用于数学和艺术作品,运用黄金比例的设计最具有视觉吸引力。使用黄金分割可以轻松得到一些数据用于网页中的各种元素的宽度、高度等,进