亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

純Python實現(xiàn)遺傳算法詳解

 更新時間:2023年08月11日 09:16:31   作者:微小冷  
遺傳算法(GA)是七十年代被霍蘭德提出來的,那還是8086的時代,但在如今的3nm時代,仍然散發(fā)著經(jīng)典的光輝,下面我們就來看看如何利用Python實現(xiàn)遺傳算法吧

遺傳算法(GA)是七十年代被霍蘭德提出來的,那還是8086的時代。但在如今的3nm時代,仍然散發(fā)著經(jīng)典的光輝,故而堪稱跨時代的優(yōu)秀算法了。

GA的核心概念是種群,種群的關(guān)鍵是染色體,隨著自然選擇,染色體通過不斷地復制、交叉、突變,完成一代又一代的進化,最終得到最優(yōu)的結(jié)果。

具體編程時,染色體可用字符串或者二進制進行編碼;自然選擇,就是適應度函數(shù);進化就是迭代。所以技術(shù)上的關(guān)鍵點,就是復制、交叉、突變等過程的函數(shù)實現(xiàn)。

編碼

考慮到二進制編碼存在位數(shù)限制,故而遺傳算法第一步就是確定問題規(guī)模,例如解空間在(0,1)區(qū)間,精度要求為10−6,則共涉及到106個解,需要24位二進制才能表示完全。如果有N個變量,則共計需要24N個0/1組成序列。

接下來實現(xiàn)一個編碼函數(shù),輸入為變量數(shù)組、變量區(qū)間以及精度要求。

# x為變量,xL為解范圍的最小值,pre為精度,N為二進制解的個數(shù)
def codeOne(x, xL, pre, N):
    x = int((x-xL)/pre)
    return [(x//2**i)%2 for i in range(N)]
from itertools import chain
# xs為一組變量, xL, xR為變量區(qū)間, pre為精度
def coding(xs, xL, xR, pre):
    N = int(np.ceil(np.log2((xR-xL)/pre)))
    xs = [codeOne(x, xL, pre, N) for x in xs]
    return np.array(list(chain(*xs)))
# 解碼是編碼的逆過程
def decodeOne(b, xL, pre, N):
    x = np.sum([b[i]*2**i for i in range(N)])
    return xL + x*pre
def decoding(bins, xL, xR, pre):
    N = int(np.ceil(np.log2((xR-xL)/pre)))
    M = int(len(bins)/N)
    return [decodeOne(bins[N*i:N*(i+1)], xL, pre, N) 
        for i in range(M)]

其中,codeOne用于編碼單個變量,coding可編碼多個變量。其中輸入?yún)?shù)xL, xR, pre的數(shù)據(jù)格式可以改寫為列表,從而使得待求解參數(shù)更加靈活。

遺傳

遺傳就是基因的復制和交叉,有的時候可能還會發(fā)生一點突變,其中交叉過程相對復雜,故而封裝成一個函數(shù)

import numpy as np
# b1,b2為編碼后的二進制串
# M為編碼后的二進制長度;index為自然數(shù)列
def cross(b1, b2, M, index):
    np.random.shuffle(index)
    i1 = index[:randint(0,M)]
    np.random.shuffle(index)
    i2 = index[:randint(0,M)]
    b1[i1], b2[i2] = b2[i1], b1[i2]

其中,shuffle相當于是把數(shù)組打亂,index為自然數(shù)列,當然被打亂多次后已經(jīng)面目全非了。cross實現(xiàn)的功能是,對于輸入的b1和b2,任選其中的某幾位進行交換。

下面是進化過程,也就是單步執(zhí)行的程序,主要包括劣種淘汰、交叉以及突變?nèi)齻€過程。

from copy import deepcopy
from random import randint
# rMuta為突變概率;nDie為每一代淘汰掉的個數(shù)
def genetic(xs, func, xL, xR, pre, nMuta, nDie):
    N = len(xs)
    fs = [func(x) for x in xs]
    index = np.argsort(fs)
    fBest = fs[index[0]]
    # 將最差的淘汰掉,將最優(yōu)的提取出來
    xs[index[-nDie:]] = xs[index[:nDie]]
    # 編碼
    bs = [coding(x, xL, xR, pre) for x in xs]
    M = len(bs[0])      # 此為編碼后的參數(shù)長度
    index = np.arange(M)
    # 交叉
    for i in range(N//2):
        cross(bs[i*2], bs[i*2+1], int(M/2), index)
    # 此為突變點個數(shù)
    for b in bs:
        np.random.shuffle(index)
        b[index[:nMuta]] = ~b[index[:nMuta]]
    # 最后解碼并輸出
    xs = [decoding(b, xL, xR, pre) for b in bs]
    return np.array(xs), fBest

主程序

所謂主程序,就是加上一個逐代繁衍的循環(huán)

uniRand = np.random.uniform
# nId為個體數(shù);nDim為參數(shù)維度;nIter為迭代數(shù)
# xRange為x取值范圍,pre是精度
def GA(func, nId, nDim, nIter, 
    xRange, pre, rMuta, nDie):
    xs = [uniRand(*xRange, nDim) for _ in range(nId)]
    xs = np.array(xs)
    for i in range(nIter):
        xs, fBest = genetic(xs, func, xRange[0], xRange[1],
            pre, rMuta, nDie)
        if i%20==0:
            msg = f"第{i}次迭代,最佳結(jié)果為{fBest}"
            print(msg)
    fs = [func(x) for x in xs]
    index = np.argmin(fs)
    msg = "當前參數(shù):" + ",".join([f"{x}" for x in xs[index]])
    print(msg)

測試

最后又到了激動人心的測試環(huán)節(jié),還是用

def test(xs):
    _sum = 0.0
    for i in range(len(xs)):
        _sum = _sum + np.cos((xs[i]*i)/5)*(i+1)
    return _sum
if __name__ == "__main__":
    GA(test, 30, 5, 101, (-5,5), 1e-6, 2, 2)

得到結(jié)果為

>python GA.py
第0次迭代,最佳結(jié)果為-6.109745260005657
第20次迭代,最佳結(jié)果為-11.73854686214257
第40次迭代,最佳結(jié)果為-11.656344079309445
第60次迭代,最佳結(jié)果為-11.366187890697542
第80次迭代,最佳結(jié)果為-11.526653664416903
第100次迭代,最佳結(jié)果為-11.329056280514049
當前參數(shù):8.073827999999999,11.655532000000001,7.032817,4.2005289999999995,-4.371395

到此這篇關(guān)于純Python實現(xiàn)遺傳算法詳解的文章就介紹到這了,更多相關(guān)Python遺傳算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Django使用Celery實現(xiàn)異步發(fā)送郵件

    Django使用Celery實現(xiàn)異步發(fā)送郵件

    這篇文章主要為大家詳細介紹了Django如何使用Celery實現(xiàn)異步發(fā)送郵件的功能,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2023-04-04
  • Python中存取文件的4種不同操作

    Python中存取文件的4種不同操作

    這篇文章主要給大家介紹了關(guān)于Python中存取文件的4種不同操作的相關(guān)資料,分別包括Python內(nèi)置方法、numpy模塊方法、os模塊方法以及csv模塊方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-07-07
  • Python 在OpenCV里實現(xiàn)仿射變換—坐標變換效果

    Python 在OpenCV里實現(xiàn)仿射變換—坐標變換效果

    這篇文章主要介紹了Python 在OpenCV里實現(xiàn)仿射變換—坐標變換效果,本文通過一個例子給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • Python中requests模塊的請求參數(shù)詳解

    Python中requests模塊的請求參數(shù)詳解

    這篇文章主要介紹了Python中requests模塊的請求參數(shù)詳解,requests模塊是一個網(wǎng)絡請求模塊,可以幫助我們模擬成客戶端去請求服務器的數(shù)據(jù),我們今天就是主要針對這個模塊進行學習,需要的朋友可以參考下
    2023-08-08
  • pycharm無法安裝第三方庫的問題及解決方法以scrapy為例(圖解)

    pycharm無法安裝第三方庫的問題及解決方法以scrapy為例(圖解)

    這篇文章主要介紹了pycharm無法安裝第三方庫的解決辦法以scrapy為例,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • Python 專題二 條件語句和循環(huán)語句的基礎(chǔ)知識

    Python 專題二 條件語句和循環(huán)語句的基礎(chǔ)知識

    本文主要介紹了Python條件語句和循環(huán)語句的基礎(chǔ)知識。主要內(nèi)容包括: 1.條件語句:包括單分支、雙分支和多分支語句,if-elif-else;2.循環(huán)語句:while的使用及簡單網(wǎng)絡刷博器爬蟲;3.循環(huán)語句:for的使用及遍歷列表、元組、文件和字符串。
    2017-03-03
  • python、java等哪一門編程語言適合人工智能?

    python、java等哪一門編程語言適合人工智能?

    哪一門編程語言適合人工智能?這篇文章主要為大家詳細介紹了python編程語言適合人工智能的原因、優(yōu)點,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • pytorch程序異常后刪除占用的顯存操作

    pytorch程序異常后刪除占用的顯存操作

    今天小編就為大家分享一篇pytorch程序異常后刪除占用的顯存操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python從MP3文件獲取id3的方法

    Python從MP3文件獲取id3的方法

    這篇文章主要介紹了Python從MP3文件獲取id3的方法,實例分析了Python操作文件屬性的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • Python Sphinx使用實例及問題解決

    Python Sphinx使用實例及問題解決

    這篇文章主要介紹了Python Sphinx使用實例及問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01

最新評論