当前位置: 首页>编程笔记>正文

光線追跡matlab編程,matlab智能算法之螢火蟲算法

光線追跡matlab編程,matlab智能算法之螢火蟲算法

智能算法之螢火蟲算法

    • 1.起源
    • 2.螢火蟲發光求偶
      • 2.1 雌雄螢火蟲
      • 2.2 求偶過程
    • 3.原理
      • 3.1 閃光強度
      • 3.2 吸引力
      • 3.3 螢火蟲移動
    • 4.具體流程

1.起源

螢火蟲群優化算法是2005年由 KrishnanandKrishnanandKrishnanandGhoseGhoseGhose 在研究改進蟻群算法求連續型最優化問題時提出的,并且成功將其用于機器人群體協作。算法的起源是來自螢火蟲在夜晚發出光亮進行求偶,雄性螢火蟲發光越亮,越能吸引雌性螢火蟲。

2.螢火蟲發光求偶

2.1 雌雄螢火蟲

一般的雌螢火蟲由于翅膀接近于退化,而且因為雌螢火蟲要產卵,腹部體積會比雄螢火蟲大,所以它們一般都只能趴在一個地方發出求偶的信號,等待別的雄螢火蟲來和它交配;而雄蟲為了有更大的發光亮度吸引雌螢火蟲,且在黑夜中找到雌螢火蟲,所以發光器有兩排光,復眼也比較發達。如果雌螢火蟲的回復得到了雄螢火蟲的答復,那它們就會以同樣的方式進行聯系,直到兩者在一起。雄螢火蟲越亮,對雌螢火蟲的吸引力越強。

2.2 求偶過程

光線追跡matlab編程。一到繁殖季節的時候,雌雄螢火蟲都能通過發光來尋找自己的配偶。在尋找配偶的時候,雌雄雙方都會發出一閃一閃的亮光作為信號。具體為:在一定范圍內,雄螢火蟲在夜色里一邊飛行,一邊發出有節奏的閃光信號,然后趴在原地的雌螢火蟲根據雄螢火蟲發光亮度的強弱進行擇偶,通常都是選擇對發光亮度最強的,也就是看起來最亮的雄螢火蟲做出發光回應。

3.原理

根據螢火蟲的求偶方式,可以發現求偶的關鍵有:閃光強度吸引力。而且標準螢火蟲優化算法遵循三個理想化規則:
1、螢火蟲不分雌雄,假設都為中性;
2、螢火蟲的吸引力和自身的閃光強度成正比,所以閃光亮度弱的螢火蟲,都會被更亮的螢火蟲吸引;
3、螢火蟲的閃光強度受到適應度函數景觀的影響。

3.1 閃光強度

螢火蟲的閃光強度與適應度函數是成正比的;每個螢火蟲都可以看成是問題的一個解,則可以得到 I(r)∝f(x)I(r) \propto f(x)I(r)f(x),其中 f(x)f(x)f(x) 則為 xxx 的目標函數,也就是這里的適應度, I(r)I(r)I(r) 是間隔距離為 rrr 的閃光強度,具體公式如下:I(r)=I0e?γrij2I(r)=I_0e^{-\gamma r^2_{ij}}I(r)=I0?e?γrij2? 其中,I0I_0I0? 為光源處的亮度,γ\gammaγ 為光強吸收系數,rijr_{ij}rij? 表示螢火蟲 iii 和螢火蟲 jjj 之間的歐式距離:rij=∑k=1n(xik?xjk)2r_{ij}=\sqrt {\sum_{k=1}^n(x_{ik}-x_{jk})^2}rij?=k=1n?(xik??xjk?)2? xikx_{ik}xik? 表示螢火蟲 iii 在維度 kkk 上的值。

3.2 吸引力

螢火蟲的吸引力和距離、光強有關,所以函數在這里設計如下單調遞減函數:β(r)=β0e?γrijm,m≥1\beta(r)=\beta_0e^{-\gamma r_{ij}^m}, \quad m \geq 1β(r)=β0?e?γrijm?,m1 其中,β0\beta_0β0? 表示兩螢火蟲距離為 000 時的吸引力,也就是最大吸引力;mmm222,當距離 rrr 變大時,吸引力則變小,反之則變大;對于規模為 Γ\GammaΓ 的螢火蟲群,γ\gammaγ 的初值可以為:γ=1Γm\gamma = \frac{1}{\Gamma^m}γ=Γm1?γ=0\gamma=0γ=0 時, β(r)=β0\beta(r)=\beta_0β(r)=β0?,也就是此時種群十分密集,吸引力達到最大;當 γ\gammaγ 趨于 ∞\infty 時,β(r)=0\beta(r)=0β(r)=0,此時相當于螢火蟲在迷霧發光,其它螢火蟲看不見,吸引力幾乎為 000,所以 γ∈[0.1,10]\gamma \in[0.1,10]γ[0.1,10]

3.3 螢火蟲移動

螢火蟲 iii 被螢火蟲 jjj 吸引后,會發生移動,移動公式為:xi(t+1)=xi(t)+β(r)(xj(t)?xi(t))+s?ix_i(t+1)=x_i(t)+\beta(r)(x_j(t)-x_i(t))+s \epsilon_ixi?(t+1)=xi?(t)+β(r)(xj?(t)?xi?(t))+s?i? 公式分為三部分:螢火蟲 iii 在第 ttt 次的位置項 xi(t)x_i(t)xi?(t),吸引力項 β(r)(xj(t)?xi(t))\beta(r)(x_j(t)-x_i(t))β(r)(xj?(t)?xi?(t)),移動步長項 s?is \epsilon_is?i?;其中 sss 為螢火蟲的移動步長,?i\epsilon_i?i? 為服從正態分布的隨機數向量,通常取值范圍為 [?0.5,0.5][-0.5,0.5][?0.5,0.5]。在實際中,通常取 β0=1,s=0.2\beta_0=1,s=0.2β0?=1,s=0.2

4.具體流程

matlab優化算法 100例、(1)(1)1初始化:初始化螢火蟲優化算法參數 γ,s\gamma,sγ,s,生成初代種群,計算種群每個個體的適應度 f(x)f(x)f(x)
(2)(2)2移動:計算每只螢火蟲相對其它螢火蟲的閃光強度 I(r)I(r)I(r),然后亮度小的螢火蟲向著亮度大螢火蟲的方向移動,得到新的位置 x′x'x,移動完后計算新的個體適應度 f(x′)f(x')f(x)
(3)(3)3終止:判斷是否達到算法的終止條件,若沒有達到,則繼續進行步驟(2)(2)2,直至終止。

https://www.nshth.com/bcbj/211008.html
>

相关文章:

  • 光線追跡matlab編程
  • matlab優化算法 100例
  • 螢火蟲算法應用場景
  • matlab算法有哪些
  • 魚群算法和蟻群算法
  • matlab隨機森林預測算法
  • 智能算法優化pcnnMatlab
  • 螢火蟲發光仿生
  • 編程語言難度排名,8 月最新編程語言排行榜
  • 手機usb調試被禁用怎么恢復,解決安卓手機USB接口被外設占用導致無法調試的問題
  • 手機上的安卓模擬器,連接手機模擬器
  • 搜狗輸入法怎么手寫和拼音一起輸入,零彝輸入法用戶協議
  • ubuntu自帶gcc編譯器嗎,安裝ubuntu20.04(安裝vim、gcc、VMtools、中文輸入法、漢化、修改IP、無法連網問題)
  • 輸入法哪個最好用,android ip格式化輸入法,Android設置默認輸入法
  • blkmov指令使用例子,ORB-SLAM2代碼解析
  • windows補丁kb3033929怎么安裝,Win8.1 kb2919355安裝不上怎么辦?
  • 淘寶店鋪如何增加流量,淘寶賣家開店怎么做有效減少淘寶垃圾流量
  • 商標使用必須加TM或R嗎,商標中R標和TM標的區別
  • 沒有商標可以上速賣通嘛,速賣通商標授權怎么弄?速賣通官方授權模板書分享
  • 商標中R跟C分別代表什么,商標TM和R有什么區別
  • 商標中R跟C分別代表什么,CSDN Markdown 商標標志 C、TM、R
  • 有關向量的重要結論,專題-句向量(Sentence Embedding)
  • 信息安全等級保護的5個級別,信息安全等級保護措施之網絡安全技術
  • 書是黃金屋下一句是什么,書中的“黃金屋”
  • gps定位,定位iowait問題
  • 渲染軟件哪個好用,Android平臺上基于OpenGl渲染yuv視頻
  • C# wpf 通過HwndHost渲染視頻
  • h5商城源碼,H5全新紅包直通車網站源碼 包含多款游戲已對接支付
  • android基礎面試題及答案,安卓手機系統開發教程!BTAJ面試有關散列(哈希)表的面試題詳解,大廠直通車!
  • 中交第一公路勘察設計研究院,緯地道路縱斷面設計教程_直通車 | 中交一公局公路勘察設計院有限公司招聘公告...
  • arduino怎么把程序傳到板上,STM32替換Arduino直通車
  • 記錄2015年年初跳槽的經歷!
  • 什么情況下可以跳槽,記錄 2015 年年初跳槽的經歷!
  • 聚合支付公司前十,聚合支付行業的2019年終總結大會!細品,你細品~
  • mastercam后處理論壇,mastercam2017后處理升級_如何升級Mastercam 9.1版后處理?
  • 動態表情包制作,android 視頻轉表情,視頻怎么轉gif?好用軟件分享,自己也能制作出搞笑表情包...
  • pc頁面怎么打開,頁面的版心html,關于PC端網頁版心及網頁自適應問題
  • webp圖片怎樣改成jpg,如何給圖片更改格式?jpg轉webp怎么操作