如何解决如何在树莓派上使用 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 举报,一经查实,本站将立刻删除。