網站首頁 編程語言 正文
肘部法則是經常使用的法則。很多時候,可以憑人工經驗去找最優拐點,但有時需要自動尋找拐點。最近解決了一下這個問題,希望對各位有用。
一. 術語解釋
**肘形曲線(elbow curve)**類似人胳膊狀的曲線,拐點在肘部。**膝形曲線(knee curve)人腿形的曲線,拐點在膝蓋。這類曲線和二八原則(即帕托累法則)**不謀而合,做決策時,自然選擇肘點或膝點做參考。按照拐點在左還是右側來分,細分為:左膝點曲線,右膝點曲線,左肘點曲線,右肘點曲線。
曲線示意圖如下:
左膝點曲線膝點在左邊的曲線(術語是我自己起的,明白意思就好,膝點在左邊)如下:
從形狀上,四種曲線沒有大的區別,可以相互轉化:
肘曲線與膝曲線相互轉化,用曲線最大值減去曲線各點值即可。同類型曲線,左右拐點轉化,就是切換升序降序排序即可。
它們都可以計算拐點,其中以左膝點曲線(見下圖)計算拐點最簡單,所以以其為標準曲線。
二. 拐點檢測
左膝點曲線,原理是其二次曲線導數最大點,如下:
對于離散序列來說,當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
原文鏈接:https://blog.csdn.net/mantoureganmian/article/details/129237755
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-06-25 分享Pytest?fixture參數傳遞的幾種方式_python
- 2023-05-06 Flutter學習之SliverList和SliverGird的使用詳解_Android
- 2022-06-16 Linux系統下Go語言開發環境搭建_Golang
- 2024-03-14 SpringBoot中配置nacos
- 2022-09-21 android實現簡單底部導航欄_Android
- 2023-01-17 Linux?ps命令詳解及Linux查看進程的操作方法_linux shell
- 2022-07-26 二分搜索防止整形溢出
- 2021-12-06 centos7.6批量增加修改刪除虛擬網卡操作介紹_Linux
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支