国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python編程實現粒子群算法(PSO)詳解

2020-02-16 10:41:42
字體:
來源:轉載
供稿:網友

1 原理

粒子群算法是群智能一種,是基于對鳥群覓食行為的研究和模擬而來的。假設在鳥群覓食范圍,只在一個地方有食物,所有鳥兒看不到食物(不知道食物的具體位置),但是能聞到食物的味道(能知道食物距離自己位置)。最好的策略就是結合自己的經驗在距離鳥群中距離食物最近的區域搜索。

利用粒子群算法解決實際問題本質上就是利用粒子群算法求解函數的最值。因此需要事先把實際問題抽象為一個數學函數,稱之為適應度函數。在粒子群算法中,每只鳥都可以看成是問題的一個解,這里我們通常把鳥稱之為粒子,每個粒子都擁有:

位置,可以理解函數的自變量的值;
經驗,也即是自身經歷過的距離食物最近的位置;
速度,可以理解為自變量的變化值;
適應度,距離食物的位置,也就是函數值。

粒子群算法的過程

                                              PSO流程圖

初始化。包括根據給定的粒子個數,初始化粒子,包括初始化一下的值:

位置:解空間內的隨機值;
經驗:與初始位置相等;
速度:0;
適應度:根據位置,帶入適應度函數,得到適應度值。
更新。包括兩部分:
粒子自身信息:包括根據下面的公式更新粒子的速度、位置,根據適應度函數更新適應度,然后和用更新后的適應度和自身經驗進行比較,如果新的適應度由于經驗的適應度,就利用當前位置更新經驗;

速度更新公式

位置更新公式

上面公式中:i表示粒子編號;t表示時刻,反映在迭代次數上;w是慣性權重,一般設置在0.4左右;c表示學習因子,一般都取值為2;Xpbest表示的是粒子i的經驗,也即是粒子i所到過最佳位置;Xgbest代表的是全局最優粒子的位置;r是0到1之間的隨機值。

種群信息:把當前適應度和全局最優位置的適應度進行比較,如果當前適應度優于全局最優的適應度,那么久用當前粒子替換群居最優。

判斷結束條件。結束條件包括最大迭代次數和適應度的閾值。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 交城县| 德昌县| 将乐县| 南部县| 文成县| 昌平区| 湘潭县| 江陵县| 许昌县| 西充县| 云和县| 开阳县| 滁州市| 来凤县| 庆安县| 华坪县| 青岛市| 南平市| 东明县| 溧阳市| 涡阳县| 加查县| 大冶市| 洛川县| 宁武县| 徐水县| 旬邑县| 横峰县| 华宁县| 高要市| 建昌县| 双江| 上饶市| 灌南县| 兴宁市| 乌鲁木齐市| 奉化市| 徐闻县| 喀什市| 龙泉市| 南安市|