加權隨機選擇:替換與非替換
加權隨機選擇是各種應用中使用的基本技術。它涉及從給定列表中採樣元素,機率分佈由指定權重確定。當選擇具有替換的元素時,每個項目可以被選擇多次,從而導致選擇具有較高權重的項目的可能性更高。相比之下,無替換選擇會在選擇項目後限制其選擇。
尋找有效的加權隨機選擇演算法(尤其是替換演算法)可能具有挑戰性。現有方法(包括修改後的儲層演算法)被證明不適合從小列表大小中選擇顯著分數。
一種有效的方法:別名方法
在此場景中表現出色的一種方法是別名方法。該技術創建一組結構化的箱,每個箱代表加權清單的一部分。透過利用位元操作,可以有效地對容器進行索引,從而避免二進位搜尋。每個 bin 包含原始列表中的兩個元素,從而能夠有效地表示分佈。
例如,考慮五個等權重選擇的清單:(a:1, b:1, c:1, d: 1、e:1)。別名方法建立一組八個箱,每個箱的機率質量為 0.125。
- 歸一化: 調整權重使其總和為 1.0。在這種情況下, (a:0.2 b:0.2 c:0.2 d:0.2 e:0.2).
- 分區: 分配權重低於分區機率(0.125) 的bin,從重量最低。這裡,(p1{a|null,1.0},p2,p3,p4,p5,p6,p7,p8).
- 填滿:用最高的填充分區中的剩餘空間權重變數。例如,(p1{a|null,1.0},p2{a|b,0.6},p3,p4,p5,p6,p7,p8)。
運行時選擇:
在運行時,我們產生一個隨機數並使用位運算來有效地確定與機率分佈相對應的 bin。如果 bin 被分割,我們使用隨機數的小數部分在 bin 中的兩個元素之間進行選擇。
總之,別名方法提供了一種有效的帶有替換的加權隨機選擇技術。它利用位元操作進行快速 bin 索引,並透過仔細地將權重劃分為可管理的 bin 來實現準確的機率分佈。
以上是在加權隨機選擇中何時使用替換與非替換?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

本文解釋瞭如何使用美麗的湯庫來解析html。 它詳細介紹了常見方法,例如find(),find_all(),select()和get_text(),以用於數據提取,處理不同的HTML結構和錯誤以及替代方案(SEL)

Python的statistics模塊提供強大的數據統計分析功能,幫助我們快速理解數據整體特徵,例如生物統計學和商業分析等領域。無需逐個查看數據點,只需查看均值或方差等統計量,即可發現原始數據中可能被忽略的趨勢和特徵,並更輕鬆、有效地比較大型數據集。 本教程將介紹如何計算平均值和衡量數據集的離散程度。除非另有說明,本模塊中的所有函數都支持使用mean()函數計算平均值,而非簡單的求和平均。 也可使用浮點數。 import random import statistics from fracti

本文比較了Tensorflow和Pytorch的深度學習。 它詳細介紹了所涉及的步驟:數據準備,模型構建,培訓,評估和部署。 框架之間的關鍵差異,特別是關於計算刻度的

本文討論了諸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和請求等流行的Python庫,並詳細介紹了它們在科學計算,數據分析,可視化,機器學習,網絡開發和H中的用途

本文指導Python開發人員構建命令行界面(CLIS)。 它使用Typer,Click和ArgParse等庫詳細介紹,強調輸入/輸出處理,並促進用戶友好的設計模式,以提高CLI可用性。

在使用Python的pandas庫時,如何在兩個結構不同的DataFrame之間進行整列複製是一個常見的問題。假設我們有兩個Dat...

文章討論了虛擬環境在Python中的作用,重點是管理項目依賴性並避免衝突。它詳細介紹了他們在改善項目管理和減少依賴問題方面的創建,激活和利益。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

記事本++7.3.1
好用且免費的程式碼編輯器

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),