Python-openCV, Kalman filter实战

1.0 什么是卡尔曼模型

理论推导过于复杂,看个知乎上的解释吧
假设你有两个传感器,测的是同一个信号。可是它们每次的读数都不太一样,怎么办?
取平均
再假设你知道其中贵的那个传感器应该准一些,便宜的那个应该差一些。那有比取平均更好的办法吗?
加权平均
怎么加权?假设两个传感器的误差都符合正态分布,假设你知道这两个正态分布的方差,用这两个方差值,(此处省略若干数学公式),你可以得到一个“最优”的权重。
接下来,重点来了:假设你只有一个传感器,但是你还有一个数学模型。模型可以帮你算出一个值,但也不是那么准。怎么办?
把模型算出来的值,和传感器测出的值,(就像两个传感器那样),取加权平均。
OK,最后一点说明:你的模型其实只是一个步长的,也就是说,知道x(k),我可以求x(k+1)。问题是x(k)是多少呢?答案:x(k)就是你上一步卡尔曼滤波得到的、所谓加权平均之后的那个、对x在k时刻的最佳估计值。
于是迭代也有了。
这就是卡尔曼滤波。

作者:Kent Zeng
链接:https://www.zhihu.com/question/23971601/answer/26254459
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

总而言之,kalman滤波用在当测量值与模型预测值均不准确的情况下,用来计算预测真值的一种滤波方法。这在目标识别与追踪任务中经常用到。

2.0 Python实战–2维位置跟踪

在这个例子中,我们知道2维位置测量值mes_x,mes_y。并且我们的先验模型预测值为model_x,model_y。我们通过kalman filter来预测真值的大小。首先来建立2维运动追踪模型,即上的model。在这个例子中,我们的model位置预测值设定为n时刻的位置由n-1时刻的位置加上一个随机噪声决定,如下图所示。
这里写图片描述

python 程序如下

  • 8
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是使用PythonOpenCV实现卡尔曼滤波的示例代码: ```python import numpy as np import cv2 # 初始化卡尔曼滤波器 kalman = cv2.KalmanFilter(4, 2) kalman.measurementMatrix = np.array([[1, 0, 0, 0], [0, 1, 0, 0]], np.float32) kalman.transitionMatrix = np.array([[1, 0, 1, 0], [0, 1, 0, 1], [0, 0, 1, 0], [0, 0, 0, 1]], np.float32) kalman.processNoiseCov = np.array([[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 1, 0], [0, 0, 0, 1]], np.float32) * 0.03 kalman.measurementNoiseCov = np.array([[1, 0], [0, 1]], np.float32) * 0.1 # 初始化视频捕捉 cap = cv2.VideoCapture(0) while True: # 读取一帧 ret, frame = cap.read() # 对帧进行预处理 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) gray = cv2.GaussianBlur(gray, (5, 5), 0) # 检测边缘 edges = cv2.Canny(gray, 50, 150, apertureSize=3) # 检测直线 lines = cv2.HoughLinesP(edges, 1, np.pi/180, 100, minLineLength=100, maxLineGap=10) # 如果检测到直线 if lines is not None: for line in lines: x1, y1, x2, y2 = line[0] # 使用卡尔曼滤波器估计下一帧的线段 prediction = kalman.predict() measurement = np.array([[np.float32(x1)], [np.float32(y1)]]) kalman.correct(measurement) # 绘制估计线段 x1p, y1p, x2p, y2p = np.int32(prediction) cv2.line(frame, (x1p, y1p), (x2p, y2p), (0, 255, 0), 2) # 显示结果 cv2.imshow('frame', frame) # 按下Esc键退出 if cv2.waitKey(1) == 27: break # 清理 cap.release() cv2.destroyAllWindows() ``` 这段代码使用OpenCV捕获实时视频流,并使用卡尔曼滤波器对检测到的直线进行估计。卡尔曼滤波器的参数在初始化时设置。首先,我们设置卡尔曼滤波器的状态向量和观测向量的维数(在本例中为4和2)。然后,我们设置测量矩阵、转移矩阵和过程噪声协方差矩阵。最后,我们设置测量噪声协方差矩阵。在每一帧中,我们使用卡尔曼滤波器来估计下一帧的线段,并绘制估计线段。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值