Python 如何以编程方式确定钟形曲线上的第一个和第二个极小值点以及峰值点

Python 如何以编程方式确定钟形曲线上的第一个和第二个极小值点以及峰值点

问题描述

我正在处理一个呈钟形(类正态)分布的数据集。我试图找到这个分布中的三个特定点:

  1. 曲线上升之前的第一个极小值点。
  2. 曲线的峰值点(最大点)。
  3. 峰值点后曲线下降时的第二个极小值。

挑战在于曲线尾部的“最小值”点不太明确(数据变平),因此精确确定这些点是困难的。我了解到,对于第一个极小值,我可能需要找到曲线开始上升的位置(第一导数从负变为正),并且对于第二个极小值,我可能需要找到峰值后曲线开始下降的位置(第一导数从正变为负)。

以下是图表,图表的数据如下:
Python 如何以编程方式确定钟形曲线上的第一个和第二个极小值点以及峰值点

这是使用pandas加载后的我的数据的简化结构:

# ... (data loading code) ...
print(df.head())

纵坐标值:

0    0.000006775275118
1    0.000002841071152
2    0.000002331050869
3    0.000002098089639
4    0.000001958793763
5    0.000001882957831
6    0.000001817511261
7    0.000001778793930
8    0.000001747600657
9    0.000001726581760
10   0.000001736836910
11   0.000001725393807
12   0.000001735801905
13   0.000001722637070
14   0.000001749210289
15   0.000001743336865
16   0.000001773540895
17   0.000001758737558
18   0.000001792945553
19   0.000001789850672
20   0.000001779160328
21   0.000001807576901
22   0.000001808267621
23   0.000001818196607
24   0.000001811775275
25   0.000001818907290
26   0.000001807848091
27   0.000001836718285
28   0.000001808366208
29   0.000001808187769
30   0.000001782767490
31   0.000001769246699
32   0.000001775707035
33   0.000001759920903
34   0.000001737253676
35   0.000001722037872
36   0.000001727249139
37   0.000001693093662
38   0.000001701267438
39   0.000001692311112
40   0.000001678170239
41   0.000001661488536
42   0.000001668086770
43   0.000001667761220
44   0.000001662043200
45   0.000001667680139
46   0.000001659051206
47   0.000001708371198
48   0.000001732222077
49   0.000001774399919
50   0.000001876523600
51   0.000002025685347
52   0.000002259535699
53   0.000002560415994
54   0.000003055340098
55   0.000003727916538
56   0.000004705124476
57   0.000005971950809
58   0.000007664882924
59   0.000009665827809
60   0.000012083860418
61   0.000014769510653
62   0.000017550004674
63   0.000020119588986
64   0.000022386885842
65   0.000024171012583
66   0.000025206126640
67   0.000025491871789
68   0.000024878712706
69   0.000023424992853
70   0.000021276252458
71   0.000018607410922
72   0.000015824313725
73   0.000012923828210
74   0.000010311275904
75   0.000008025889954
76   0.000006292151302
77   0.000004904108668
78   0.000003974381668
79   0.000003333372577
80   0.000002833383398
81   0.000002537387898
82   0.000002308652989
83   0.000002216008051
84   0.000002145439742
85   0.000002146526344
86   0.000002167240574
87   0.000002248661389
88   0.000002323548464
89   0.000002430060014
90   0.000002537689493
91   0.000002347846822
Name:  diff_current, dtype: float64

我目前正在使用SciPy中的find_peaks函数来定位峰值和最小值(通过反转y值)。但是我仍然无法仅获取第一个最小值、峰值和第二个最小值的数值。

是否有人可以指导我如何确定这三个点的位置?对于逻辑或代码的任何帮助将不胜感激。

解决方案

根据最大值的位置进行切片:

peak = data.argmax()
print(f'Maximum: {data[peak]} at {peak}')
print(f'Left minimum: {data[:peak].min()}')
print(f'Right minimum: {data[peak:].min()}')          
Maximum: 2.5491871789e-05 at 67
Left minimum: 1.659051206e-06
Right minimum: 2.145439742e-06

Camera课程

Python教程

Java教程

Web教程

数据库教程

图形图像教程

办公软件教程

Linux教程

计算机教程

大数据教程

开发工具教程