Python實現(xiàn)曲線的肘部點檢測詳解
肘部法則是經(jīng)常使用的法則。很多時候,可以憑人工經(jīng)驗去找最優(yōu)拐點,但有時需要自動尋找拐點。最近解決了一下這個問題,希望對各位有用。
一. 術(shù)語解釋
**肘形曲線(elbow curve)**類似人胳膊狀的曲線,拐點在肘部。**膝形曲線(knee curve)人腿形的曲線,拐點在膝蓋。這類曲線和二八原則(即帕托累法則)**不謀而合,做決策時,自然選擇肘點或膝點做參考。按照拐點在左還是右側(cè)來分,細(xì)分為:左膝點曲線,右膝點曲線,左肘點曲線,右肘點曲線。
曲線示意圖如下:


左膝點曲線膝點在左邊的曲線(術(shù)語是我自己起的,明白意思就好,膝點在左邊)如下:

從形狀上,四種曲線沒有大的區(qū)別,可以相互轉(zhuǎn)化:
肘曲線與膝曲線相互轉(zhuǎn)化,用曲線最大值減去曲線各點值即可。同類型曲線,左右拐點轉(zhuǎn)化,就是切換升序降序排序即可。
它們都可以計算拐點,其中以左膝點曲線(見下圖)計算拐點最簡單,所以以其為標(biāo)準(zhǔn)曲線。
二. 拐點檢測
左膝點曲線,原理是其二次曲線導(dǎo)數(shù)最大點,如下:
對于離散序列來說,當(dāng)x軸差為1時,二次曲線計算公式為:
f′′(xi?)=f(xi−1?)+f(xi+1?)−2*f(xi?)

推薦一個簡單的包:kneed Github地址
支持:Python 3.7, 3.8, 3.9, and 3.10. 安裝如下:
$ conda install -c conda-forge kneed # 或者 $ pip install kneed # To install only knee-detection algorithm $ pip install kneed[plot] # To also install plotting functions for quick
使用如下:
from kneed import DataGenerator, KneeLocator x, y = DataGenerator.figure2() print([round(i, 3) for i in x]) print([round(i, 3) for i in y]) # out: [0.0, 0.111, 0.222, 0.333, 0.444, 0.556, 0.667, 0.778, 0.889, 1.0] # out: [-5.0, 0.263, 1.897, 2.692, 3.163, 3.475, 3.696, 3.861, 3.989, 4.091] kneedle = KneeLocator(x, y, S=1.0, curve="concave", direction="increasing") print(round(kneedle.knee, 3)) # out: 0.222 print(round(kneedle.elbow, 3)) # out: 0.222
到此這篇關(guān)于Python實現(xiàn)曲線的肘部點檢測詳解的文章就介紹到這了,更多相關(guān)Python曲線肘部點檢測內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python深度學(xué)習(xí)借助多標(biāo)簽分類器進(jìn)行對抗訓(xùn)練
這篇文章主要為大家介紹了python深度學(xué)習(xí)中如何借助多標(biāo)簽分類器進(jìn)行對抗訓(xùn)練,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-01-01
Django DRF認(rèn)證組件流程實現(xiàn)原理詳解
這篇文章主要介紹了Django DRF認(rèn)證組件流程實現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
詳解如何使用pandas進(jìn)行時間序列數(shù)據(jù)的周期轉(zhuǎn)換
時間序列數(shù)據(jù)是數(shù)據(jù)分析中經(jīng)常遇到的類型,為了更多的挖掘出數(shù)據(jù)內(nèi)部的信息,我們常常依據(jù)原始數(shù)據(jù)中的時間周期,將其轉(zhuǎn)換成不同跨度的周期,下面以模擬的K線數(shù)據(jù)為例,演示如何使用pandas來進(jìn)行周期轉(zhuǎn)換,感興趣的朋友可以參考下2024-05-05

