python波形分割_用Python裁剪波形顶部

最简单的方法是创建一个引入“软剪裁”的映射,值是1:1线性的,直到接近阈值,然后压缩,直到达到某个更大的阈值。在

编辑:这个想法是合理的,但是实现还有一点不尽如人意。我又想了想,换了个更好的。在

目标是使从压缩开始到硬剪裁限制的平滑过渡。线性变换的斜率为1,截断信号的斜率为0。从斜率1转换为斜率0的最干净的方法是使用四分之一的正弦波,因此更新后的函数基于sin。在from math import *

hard_limit = 32767

linear_limit = 23197 # -3 dB

clip_limit = linear_limit + int(pi/2 * (hard_limit - linear_limit))

def soft_clip(n):

amplitude, sign = abs(n), 1 if n >= 0 else -1

if amplitude <= linear_limit:

return n

if amplitude >= clip_limit:

return hard_limit * sign

scale = hard_limit - linear_limit

compression = scale * sin(float(amplitude - linear_limit) / scale)

return (linear_limit + int(compression)) * sign

下面是一个在振幅为40000的正弦波上使用上述方法的示例,背景是未夹持的版本。在

bd1db8bf1fb95e2e30463805b0659993.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值