精易论坛

标题: OPENCV 卡尔曼滤波跟踪鼠标位置 [打印本页]

作者: z13228604287    时间: 2024-3-15 19:21
标题: OPENCV 卡尔曼滤波跟踪鼠标位置

  
窗口程序集名保 留  保 留备 注
程序集1   
变量名类 型数组备 注
整数型  
整数型  
鼠标位置坐标二维整型结构  

子程序名返回值类型公开备 注
_启动子程序整数型 本子程序在程序启动后最先执行
变量名类 型静态数组备 注
卡尔曼卡尔曼滤波器类 
状态向量整数型 
测量向量整数型 
状态小数型16
步长小数型时间步长,假设加速度对位置和速度的影响是恒定的
随机随机数类 
测量值数据矩阵类 
数据矩阵类 
预测坐标坐标二维整型结构 
高 = 600
宽 = 800
鼠标位置.初始化 (右移 (宽, 1), 右移 (高, 1))
状态向量 = 4  ' 态向量为4x1: (x, y, △x, △y)
测量向量 = 2  ' 测量向量为2x1: (x, y)
' Kalman滤波器设置
卡尔曼.初始化 (状态向量, 测量向量, 0, #矩阵_小数型 )
' 1 表示当前状态的该元素在下一个时刻将保持不变
' 0 表示当前状态的该元素不受状态向量中其他元素的影响,即它们之间没有直接的转移关系。
状态 = { 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1 }
步长 = 1
如果真 (步长 ≠ 1)
状态 [3] = 步长
状态 [8] = 步长

' 转移矩阵A
卡尔曼.转移.初始化指针 (4, 4, #矩阵_小数型, 取变量数据地址 (状态))
视觉_设置为单位矩阵 (卡尔曼.测量, )  ' 测量矩阵H
视觉_设置为单位矩阵 (卡尔曼.过程协方差, 标量 (1e-005))  ' 系统噪声方差矩阵Q
视觉_设置为单位矩阵 (卡尔曼.测量协方差, 标量 (0.1))  ' 测量噪声方差矩阵R
视觉_设置为单位矩阵 (卡尔曼.后验误差, 标量 (10))  ' 后验错误估计协方差矩阵P
随机.填充 (卡尔曼.校正, #随机_均匀分布, 0, 视觉_取最小值 (宽, 高), )  ' 初始状态值x(0)
测量值.初始化零 (测量向量, 1, #矩阵_小数型 )  ' 初始测量值x'(0)
视觉_创建窗口 (“小白鼠 卡尔曼演示”, 1)
视觉_设置鼠标事件 (“小白鼠 卡尔曼演示”, &鼠标事件, 0)
图.初始化零 (高, 宽, #矩阵_三通道字节型U )
循环判断首 ()
' 卡尔曼预测
卡尔曼.预测 ()
预测坐标.初始化 (到整数 (卡尔曼.预测.取元素 (0, 0)), 到整数 (卡尔曼.预测.取元素 (0, 1)))  ' 预测值 (x', y')
' 更新测量值
测量值.置元素 (0, 0, 鼠标位置.横坐标)
测量值.置元素 (0, 1, 鼠标位置.纵坐标)
' 更新
卡尔曼.更新 (测量值)
' 背景刷新
图.设置 (标量 (255, 255, 255, 0), )
' 绘制
视觉_圆 (图, 预测坐标, 5, 标量 (0, 255, 0), 3, 8, 0)  ' 预测点用绿色表示
视觉_圆 (图, 鼠标位置, 5, 标量 (255, 0, 0), 3, 8, 0)  ' 当前位置用红色表示
视觉_放置文本 (图, “predicted position:(”到文本 (预测坐标.横坐标)“,”到文本 (预测坐标.纵坐标)“)”, 坐标二维整型 (10, 30), #字体_更复杂的手写风格, 1, 标量 (0, 0, 0), 1, 8, )
视觉_放置文本 (图, “current location:(”到文本 (鼠标位置.横坐标)“,”到文本 (鼠标位置.纵坐标)“)”, 坐标二维整型 (10, 60), #字体_更复杂的手写风格, 1, 标量 (0, 0, 0), 1, 8, )
视觉_显示图像 (“小白鼠 卡尔曼演示”, 图)
循环判断尾 (视觉_等待按键 (3)#Esc键 )
返回 (0)  ' 可以根据您的需要返回任意数值
子程序名返回值类型公开备 注
鼠标事件  
参数名类 型参考可空数组备 注
event整数型见 常量 #事件_*
x整数型鼠标事件的 x 坐标
y整数型鼠标事件的 y 坐标
flags整数型见 常量 #事件_标志_*
如果真 (event = #事件_鼠标移动 )
鼠标位置.初始化 (x, y)


i支持库列表   支持库注释   
OpenCV(未知支持库)
spec特殊功能支持库


作者: nunu0530    时间: 2024-3-15 23:21
666666666666666666666
作者: 汉族    时间: 2024-3-16 00:24
支持支持  不知道楼主的免费 动态库 还在更新没
作者: paneldemo    时间: 2024-3-22 18:03
感谢分享,学到了
作者: Angel57124    时间: 2024-3-25 23:12
学习一下
作者: qq977352880    时间: 2024-4-7 20:30
学习了,希望自己的技术能更上一层楼。

作者: 陆白途旅    时间: 2024-4-11 19:27
支持支持支持支持支持支持支持支持支持支持支持
作者: a759077146    时间: 2024-7-4 18:40
卡尔曼滤波器类  这个能发下吗 缺这个运行不了啊
作者: sad123123    时间: 2024-8-27 00:21
卡尔曼滤波牛逼
作者: a1997426zz    时间: 2024-11-12 05:10
支持开源~!感谢分享
作者: a1997426zz    时间: 2024-11-29 01:47
感谢分享~~~~~~~~~~
作者: 陆白途旅    时间: 2024-12-12 12:50
66666666666666666666
作者: a1997426zz    时间: 2025-2-12 17:02
感谢分享,很给力!~
作者: e688    时间: 2025-2-12 17:17
感谢分享
作者: tk0056    时间: 2025-2-16 13:16
卡尔曼滤波器类 和鼠标二维的哪个没有类啊。
作者: wjr    时间: 2025-3-6 15:12
6666666666666666666666666666




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4