通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

python如何给曲线做包络线

python如何给曲线做包络线

要给曲线做包络线,可以使用信号处理中的包络线检测方法、求解局部极值点、使用数学拟合方法等。下面详细介绍如何使用这些方法来给曲线做包络线。

一、包络线检测方法

包络线检测是一种常见的信号处理技术,用于提取信号的包络。可以使用希尔伯特变换来计算信号的包络。希尔伯特变换是一种将实信号转换为复信号的方法,复信号的幅度即为包络。下面是使用Python实现希尔伯特变换的示例代码:

import numpy as np

import matplotlib.pyplot as plt

from scipy.signal import hilbert

生成示例信号

t = np.linspace(0, 1, 500)

signal = np.sin(2 * np.pi * 5 * t) + 0.5 * np.sin(2 * np.pi * 10 * t)

计算希尔伯特变换

analytic_signal = hilbert(signal)

envelope = np.abs(analytic_signal)

绘制原始信号和包络线

plt.plot(t, signal, label='Original Signal')

plt.plot(t, envelope, label='Envelope', linestyle='--', color='red')

plt.legend()

plt.xlabel('Time [s]')

plt.ylabel('Amplitude')

plt.title('Envelope Detection using Hilbert Transform')

plt.show()

在这段代码中,生成了一个示例信号,该信号由两个不同频率的正弦波组成。然后使用希尔伯特变换计算信号的包络线,并将包络线绘制在原始信号上。

二、求解局部极值点

另一种方法是通过求解曲线的局部极值点(即局部最大值和最小值),然后使用插值方法连接这些极值点以形成包络线。下面是一个实现该方法的示例代码:

import numpy as np

import matplotlib.pyplot as plt

from scipy.signal import find_peaks

from scipy.interpolate import interp1d

生成示例信号

t = np.linspace(0, 1, 500)

signal = np.sin(2 * np.pi * 5 * t) + 0.5 * np.sin(2 * np.pi * 10 * t)

查找局部最大值和最小值

peaks, _ = find_peaks(signal)

troughs, _ = find_peaks(-signal)

对局部最大值和最小值进行插值

peak_interp = interp1d(t[peaks], signal[peaks], kind='cubic', fill_value="extrapolate")

trough_interp = interp1d(t[troughs], signal[troughs], kind='cubic', fill_value="extrapolate")

生成插值包络线

envelope_upper = peak_interp(t)

envelope_lower = trough_interp(t)

绘制原始信号和包络线

plt.plot(t, signal, label='Original Signal')

plt.plot(t, envelope_upper, label='Upper Envelope', linestyle='--', color='red')

plt.plot(t, envelope_lower, label='Lower Envelope', linestyle='--', color='blue')

plt.legend()

plt.xlabel('Time [s]')

plt.ylabel('Amplitude')

plt.title('Envelope Detection using Local Extrema')

plt.show()

在这段代码中,使用 find_peaks 函数查找信号的局部最大值和最小值,然后使用三次样条插值方法连接这些极值点以形成包络线。

三、使用数学拟合方法

可以使用数学拟合方法来拟合包络线。比如使用多项式拟合方法。下面是一个示例代码:

import numpy as np

import matplotlib.pyplot as plt

from numpy.polynomial.polynomial import Polynomial

生成示例信号

t = np.linspace(0, 1, 500)

signal = np.sin(2 * np.pi * 5 * t) + 0.5 * np.sin(2 * np.pi * 10 * t)

查找局部最大值和最小值

peaks, _ = find_peaks(signal)

troughs, _ = find_peaks(-signal)

使用多项式拟合局部最大值和最小值

poly_upper = Polynomial.fit(t[peaks], signal[peaks], deg=10)

poly_lower = Polynomial.fit(t[troughs], signal[troughs], deg=10)

计算拟合包络线

envelope_upper = poly_upper(t)

envelope_lower = poly_lower(t)

绘制原始信号和包络线

plt.plot(t, signal, label='Original Signal')

plt.plot(t, envelope_upper, label='Upper Envelope', linestyle='--', color='red')

plt.plot(t, envelope_lower, label='Lower Envelope', linestyle='--', color='blue')

plt.legend()

plt.xlabel('Time [s]')

plt.ylabel('Amplitude')

plt.title('Envelope Detection using Polynomial Fitting')

plt.show()

在这段代码中,使用 Polynomial.fit 函数对局部最大值和最小值进行多项式拟合,然后计算并绘制包络线。

四、使用信号包络线检测工具包

此外,还可以使用现有的信号处理工具包,如 scipynumpy 等,来检测信号的包络线。下面是一个示例代码:

import numpy as np

import matplotlib.pyplot as plt

from scipy.signal import hilbert, find_peaks

生成示例信号

t = np.linspace(0, 1, 500)

signal = np.sin(2 * np.pi * 5 * t) + 0.5 * np.sin(2 * np.pi * 10 * t)

计算希尔伯特变换

analytic_signal = hilbert(signal)

envelope = np.abs(analytic_signal)

查找局部最大值

peaks, _ = find_peaks(signal)

绘制原始信号和包络线

plt.plot(t, signal, label='Original Signal')

plt.plot(t, envelope, label='Envelope', linestyle='--', color='red')

plt.scatter(t[peaks], signal[peaks], color='blue', zorder=5)

plt.legend()

plt.xlabel('Time [s]')

plt.ylabel('Amplitude')

plt.title('Envelope Detection using Hilbert Transform and Peak Detection')

plt.show()

在这段代码中,结合使用希尔伯特变换和局部最大值检测方法来计算并绘制信号的包络线。

总结

通过上述方法,可以有效地给曲线做包络线。可以根据具体应用场景选择合适的方法,如使用希尔伯特变换进行包络线检测、求解局部极值点并进行插值、使用多项式拟合方法拟合包络线等。选择合适的方法可以帮助更好地提取信号的特征和趋势。

相关问答FAQs:

如何用Python绘制曲线的包络线?

绘制包络线的过程通常涉及对原始曲线数据进行处理。可以使用numpy和matplotlib库来实现。首先,使用numpy生成数据点,然后通过计算导数或使用平滑技术来确定包络线的上下边界。最后,利用matplotlib进行可视化。

在Python中,使用哪些库可以帮助我绘制包络线?

Python中可以使用多个库来绘制包络线,常用的包括numpy、scipy和matplotlib。numpy用于数据处理,scipy提供一些信号处理工具,可以帮助计算包络线,而matplotlib则用于绘制和展示结果。此外,pandas库也可以用于处理数据集,以便更好地管理和分析曲线数据。

如何提高包络线绘制的精度和效果?

提高包络线的精度可以通过选择适当的平滑算法来实现。例如,可以使用局部加权回归(LOWESS)或样条插值等方法来平滑原始数据,从而更准确地提取包络线。此外,调整采样频率和数据预处理步骤也能显著影响结果的质量。在可视化时,可以通过设置合适的图形参数来增强可读性和美观性。

相关文章