线性预测与Levinson-Durbin算法实现

本文介绍了线性预测在信号处理中的应用,并通过Levinson-Durbin算法提供了一个示例Demo,详细展示了算法如何进行线性预测,包括输入信号、预测信号和预测误差的处理,帮助读者直观理解线性预测的工作原理。
摘要由CSDN通过智能技术生成

在学习信号处理的时候,线性预测是一个比较难理解的知识点,为了加快很多朋友的理解,这里给出Levinson-Durbin算法的线性预测实现和一个测试Demo,Demo中很明确的把输入信号、预测信号、预测误差打印了出来,这样就能以最直观的方式,把线性预测的实现与作用展示出来。话不多说,直接上代码!

typedef float OsFlt32;
typedef int  OsInt32;

OsFlt32 lpc(const OsFlt32 *r,OsInt32 p,OsFlt32 *a)
{
    OsInt32 i,j;
    OsFlt32 err;

    if(0 == r[0])
    {
        for(i = 0; i < p; i++) a[i] = 0;
        return 0;
    }
    a[0] = 1.0;
    err = r[0];
    for(i = 0; i < p; i++)
    {
        OsFlt32 lambda = 0.0;
        for(j = 0; j <= i; j++)
            lambda -= a[j]*r[i+1-j];
        lambda /= err;
        // Update LPC coefficients and total error
        for(j = 0; j <= (i+1)/2; j++)
        {
            OsFlt32 temp = a[i+1-j] + lambda * a[j];
            a[j] = a[j]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值