微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在树莓派上使用 scipy 实现巴特沃斯带滤波器

如何解决如何在树莓派上使用 scipy 实现巴特沃斯带滤波器

嗨,我正在尝试运行代码来验证 RPI4 上的加速计传感器。似乎我的库没有采样率选项,“fs”,因为我不断收到错误

TypeError: butter() 得到了一个意外的关键字参数 'fs'

有什么想法可以解决这个问题吗?

def imu_integrator():
#############################
# Main Loop to Integrate IMU
#############################
#
data_indx = 1 # index of variable to integrate
dt_stop = 5 # seconds to record and integrate

plt.style.use('ggplot')
plt.ion()
fig,axs = plt.subplots(3,1,figsize=(12,9))
break_bool = False
while True:
    #
    ##################################
    # Reading and Printing IMU values 
    ##################################
    #
    accel_array,t_array = [],[]
    print("Starting Data Acquisition")
    [axs[ii].clear() for ii in range(0,3)]
    t0 = time.time()
    loop_bool = False
    while True:
        try:
            ax,ay,az,wx,wy,wz = mpu6050_conv() # read and convert mpu6050 data
            mx,my,mz = AK8963_conv() # read and convert AK8963 magnetometer data
            t_array.append(time.time()-t0)
            data_array = [ax,wz,mx,mz]
            accel_array.append(accel_fit(data_array[data_indx],*accel_coeffs[data_indx]))
            if not loop_bool:
                loop_bool = True
                print("Start Moving IMU...")
        except:
            continue
        if time.time()-t0>dt_stop:
            print("Data Acquisition Stopped")
            break
        
    if break_bool:
        break
    #
    ##################################
    # Signal Filtering
    ##################################
    #
    Fs_approx = len(accel_array)/dt_stop
    b_filt,a_filt = signal.butter(4,5,'low',fs=Fs_approx)
    accel_array = signal.filtfilt(b_filt,a_filt,accel_array)
    accel_array = np.multiply(accel_array,9.80665)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。