2021年全国大学生电子设计竞赛D题——基于互联网的摄像测量系统(一)

01 D题实现效果演示

视频参考微信原文:2021年全国大学生电子设计竞赛D题——基于互联网的摄像测量系统(一)

02 D题任务要求

(D题原文件参见本文附录)

设计并制作一个图中所示的基于互联网的摄像测量系统。图中边长为1米的正方形区域三个顶点分别为A、B和O。系统有两个独立的摄像节点分别放置在A和B,两个摄像节点拍摄尽量沿AO、BO方向正交,并通过一个百兆/千兆以太网交换机与连接在该交换机的一个终端节点实现网络互联。交换机必须为互联网通用交换机,使用的网口可以任意指定。

在O点上方悬挂一个用柔性透明细线吊起的激光笔,透明细线长度为 l,激光笔常亮向下指示,静止下垂时的指示光点与O点重合。

拉动激光笔偏离静止点的距离小于10cm,松开后激光笔自由摆动。应保证激光笔指示光点的轨迹经O点往复直线运动,轨迹与OA边的夹角为 θ。

利用该系统实现对长度 l 角度 θ 的测量。

基本要求分析

  1. 设计并制作两个独立的摄像节点。每个节点由一个摄像头和相应的电路组成,两个摄像节点均可以拍摄到激光笔的运动视频并显示。

  2. 设计并制作终端节点。在终端显示器上可以分别和同时显示两个摄像节点拍摄的实时视频。在视频中可以识别出激光笔,并在视频中用红色方框实时框住激光笔轮廓。

  3. 测量系统在终端节点设置一键启动。从激光笔摆动开始计时,测量系统通过对激光笔周期摆动视频信号的处理,自动测量长度 l。(50cm ≤ l ≤ 150cm,θ角度自定)  测量完成时,终端声光提示并显示长度 l。要求测量误差绝对值小于 2cm,测量时间小于 30 秒。

题目发挥部分

  1. 一键启动后,测量系统通过两个独立摄像节点的网络协同工作。当 θ = 0° 和 θ = 90° 时,能自动测量长度 l( 50cm ≤ l ≤ 150cm )。要求测量误差绝对值小于 2cm,测量时间小于 30 秒。

  2. 一键启动后,可以测量 θ ( 0° ≤ θ ≤ 90° ) 。要求测量误差绝对值小于 5°,测量时间小于 30 秒。

  3. 其他。

03 硬件方案选择

摄像节点由一个摄像头和相应的电路组成,需要拍摄到激光笔的运动视频并显示。可以使用下面两种方案:

方案一:USB摄像头 + 树莓派

树莓派调用OpenCV库从USB摄像头获取实时图像并显示在HDMI显示器上,然后调用OpenCV库中的图像处理算法识别激光笔,然后在原图像上用红框框住激光笔轮廓,再将激光笔的位置信息和图像通过网络传输到终端节点。

方案二:D8M摄像头 + DE10-Nano开发板

D8M摄像头可通过GPIO接口连接到DE10-Nano开发板上,使用Terasic Camera IP从D8M获取实时视频流数据并显示在HDMI显示器上,再对视频流数据进行处理识别激光笔,然后在原图像上用红框框住激光笔轮廓,再将激光笔的位置信息和图像通过网络传输到终端节点。

方案比较:

方案一采用USB摄像头可以直接使用OpenCV库进行操作,代码简单,但是只能用CPU进行处理,处理效率不够高。

方案二采用GPIO接口的D8M摄像头,直接与DE10-Nano开发板连接,可通过FPGA进行算法加速,CPU只需要读取FPGA端处理好的结果图像再进行简单的计算,可提高处理效率。

综上所述,为了提高处理效率、缩短测量时间,选择方案二作为摄像节点方案。其系统框图如下:

04 检测方案选择

运动目标的检测一般有三种方法:背景差分法、帧间差分法和光流法。

背景差分法

背景差分法是采用图像序列中的当前帧和背景参考模型比较来检测运动物体的一种方法,其性能依赖于所使用的背景建模技术,背景图像的建模和模拟的准确程度,直接影响到检测的效果。

帧间差分法

帧间差分法通过对视频或图像序列中相邻两帧做差分运算来获得运动目标的轮廓,可很好地适用于存在多个运动目标和摄像机移动的情况。

当场景中出现物体运动时,帧与帧之间会出现较为明显的差别,两帧相减,得到两帧图像亮度差的绝对值,判断它是否大于阈值来分析视频或图像序列的运动特性,确定图像序列中有无物体运动。

光流法

光流是关于视域中的物体运动检测中的概念,用来描述相对于观察者的运动所造成的观测目标、表面或边缘的运动。光流法的主要任务就是计算光流场,即在适当的平滑性约束条件下,根据图像序列的时空梯度估算

运动场,通过分析运动场的变化对运动目标和场景进行检测与分割。

方案比较:

背景差分法检测运动目标速度快,检测准确,但对于背景的建模和模拟却比较困难,而要提升准确度就会导致算法的计算量增大,实时性不够好;

帧间差分法对包含运动目标的场景有着比较强的鲁棒性,且运算速度快,实时性好,但该方法一般不能完全检测出运动物体的所有像素点,常常在检测到的运动物体内部出现“空洞”现象,因此仅适用于简单的运动物体检测的情况;

光流法不需要预先知道场景的任何信息,就能够检测到运动对象,可处理背景运动的情况,但噪声、多光源、阴影和遮挡等因素会对光流场分布的计算结果造成严重影响,而且光流法计算复杂,也很难实现实时处理。

综上所述,为了能够实时识别到激光笔,且激光笔内部少量像素点的缺失不会影响检测结果,选择帧间差分法作为运动目标检测算法。

05 长度L的理论计算

单摆的定义

将无重细杆或不可伸长的细柔绳一端悬于重力场内一定点,另一端固定一个重小球,就构成单摆。

小角近似简谐运动(一般认为10°以下可以这样近似),单摆能够往复摆动,在非常小的振幅/角度下,单摆做简谐运动,简谐运动方程式如下所示:

其中,A、 φ 为任意常数,由初值条件给定;而T等于:

其中 l 为无重细杆或细柔绳的长度, g 为当地的重力加速度。

如果已知简谐运动的周期 T,那么就可以计算得到无重细杆或细柔绳的长度 l:

那怎样得到简谐运动的周期T呢?这里采用拟合cos函数。

06 拟合cos函数

获取数据集

采用拟合cos函数的第一步,就是要获取数据集。

以摄像节点A为例进行介绍,这是摄像节点A拍摄到的画面,将左上角作为坐标原点,通过目标检测算法识别激光笔的位置,然后采集在t时刻对应的激光笔轮廓左上角顶点的坐标值x,y以及长和宽,再计算得到中心点的横坐标xt,将中心点的坐标作为激光笔的坐标。

这样就得到了拟合cos函数所需的一组数据,通过测量不同时刻对应的激光笔的位移xt就可以得到一组数据集。

最小二乘法

最小二乘法是解决曲线拟合问题最常用的方法,通过最小化误差的平方和来寻找数据的最佳函数匹配。

余弦曲线表示为:

其中包含4个参数,分别是振幅(A)、周期(T)、初相(φ)和偏距(k)。

设(x, y)是一对观测量,且 x和y满足理论函数:y=f(x, ω),其中ω为待定参数。

为了寻找函数f(x,ω)中参数ω的最优估计值,对于给定m组观测数据(x_i,y_i)(i=1, 2,⋯,m),求解目标函数

L取最小值时对应的参数ω为最优估计值。

07 角度 θ 的理论计算

接下来进行角度θ的理论计算,这是测量系统的俯视图:

图中红色实线CD是激光笔的运动轨迹,其与OA边的夹角为θ,过点C画OA的平行线,过点D画OB的平行线,交于点E,CE的长度为Xb,DE的长度为Xa。这样就可以得到摄像节点A处拍摄到的激光笔运动轨迹的横向分量DE的运动方程式和分量CE的运动方程式为:

又由于每次拉动激光笔后,角度θ是一个固定值,sinθ和cosθ为常量,所以横向分量和竖直分量也都是简谐运动,而DE的长度为Xa,振幅为Xa/2,所以Xa和Xb可以表示为:

我们将这两个式子相比,可以得到tanθ=Xa/Xb,则由反三角函数的正切公式可以计算得到:

08 附录

1. D题源码:socfpga demo: 分享socfpga 相关 demo - Gitee.com

2. Linux image文件:联系微信TerasicNicole

3. D题原始文件

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/824836.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Python】异常处理结构

文章目录 1.python异常2.try_except异常处理结构3.try... 多个except异常处理4.try_except_else异常处理结构5.try_except_finally异常处理结构6.常见报错类型 在运行代码时,总是遇到各种异常,且出现异常时,脚本就会自动的的停止运行&#xf…

就业班 第三阶段(nginx) 2401--4.17 day1 nginx1

负载均衡集群 1、集群是什么? 1 集群(cluster)技术是一种较新的技术,通过集群技术,可以在付出较低成本的情况下获得在性能、可靠性、灵活性方面的相对较高的收益,其任务调度则是集群系统中的核心技术。 …

FinalShell 远程连接 Linux(Ubuntu)系统

Linux 系列教程: VMware 安装配置 Ubuntu(最新版、超详细)FinalShell 远程连接 Linux(Ubuntu)系统Ubuntu 系统安装 VS Code 并配置 C 环境 ➡️➡️➡️提出一个问题:为什么使用 FinalShell 连接&#xff0…

初识ansible服务及ansible主机清单配置

目录 1、什么是自动化批量管理 2、自动化工具ansible架构 3、ansible服务专用术语对照表 4、设置主机清单(inventory) 4.1实验环境准备 4.2配置主机清单 4.2.1分组基本格式 4.2.2指定用户名,密码。端口 4.2.3子组 4.3查看 4.3.1看…

LeetCode———144—— 二叉树的前序遍历

目录 ​编辑 1.题目 2.解答 1.首先计算二叉树的节点个数: 2.以先序遍历(Preorder Traversal)的方式遍历一个二叉树,并将遍历到的节点的值存储在一个整数数组中 3.最终代码 1.题目 . - 力扣(LeetCode) 给…

双碳目标下基于“遥感+”集成技术的碳储量、碳排放、碳循环、温室气体等多领域监测与模拟

以全球变暖为主要特征的气候变化已成为全球性环境问题,对全球可持续发展带来严峻挑战。2015年多国在《巴黎协定》上明确提出缔约方应尽快实现碳达峰和碳中和目标。2019年第49届 IPCC全会明确增加了基于卫星遥感的排放清单校验方法。随着碳中和目标以及全球碳盘点的现…

[stm32]DMA使用

自动重装和M2M(软件trig)不能一起使用,否则会停不下来 void MyDMA_Init(uint32_t AddrA,uint32_t AddrB,uint16_t Size){RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1,ENABLE);DMA_InitTypeDef DMA_InitStructure;DMA_InitStructure.DMA_PeripheralBaseAddrAddrA;//外…

爬楼梯(c)

文章目录 描述分析思路关键代码运行结果 描述 给定一个整数数组 cost ,其中 cost[i]是从楼梯第i 个台阶向上爬需要支付的费用,下标从0开始。-旦你支付此费用,即可选择向上爬一个或者两个台阶 要求:请你计算并返回达到楼梯顶部的…

在使用lombok的@Slf4j时,启动项目报错。java:找不到符号

问题背景: 在使用lombok的Slf4j时,启动项目报错。 java:找不到符号符号: 方法info(java.lang.String,java.lang.String)位置: 类型为org.apache.ibatis.logging.Log的变量 log解决方式: 在如图所示位置加…

在线预约家政服务小程序上门服务源码系统 带完整的安装代码包以及搭建教程

随着互联网的快速发展,家政服务行业也逐渐向线上化、智能化转型。为了满足广大用户的需求,罗峰给大家分享一款在线预约家政服务小程序上门服务源码系统。该系统不仅功能完善,而且操作简单,是您打造高效、便捷的家政服务平台的首选…

MySql 表中的id突然变很大,如何给id重新排序

目录 一、场景 二、解决方法 一、场景 我们在开发过程中,难免遇到id突然增大的情况。 由于id突然增大很多,我们重新增加数据时候id会默认加1 那么如何让id 重新从1按顺序排序呢 二、解决方法 点击编辑表,然后新建一个字段id2,将…

探索分布式系统监控zabbix-------------监控Windows

扩展windows 10 server2012 server2016 server2019 监控 一、在虚拟机中安装zabbix的客户端 下载网站 Download and install Zabbix 安装系统一直托不进虚拟机中;因为没安装Tools组件 点击虚拟机,选择安装VMware Tools 查看主机名 二、在web页…

每天五分钟计算机视觉:基于卷积操作完成滑动窗口的图片分类?

本文重点 我们前面学习了使用不同大小的滑动窗口来滑动图片,然后切分成许多小的图片,然后依次应用到我们已经训练好的图像分类模型中,但是这种方式效率太低了,本节课程我们学习一种新的方式,来看一下如何并行识别这些剪切的图片。 原始结构 首先我们先来看一下,如何把…

InCopy2024安装包(亲测可用)

目录 一、软件简介 二、软件下载 一、软件简介 InCopy是一种专业的文字处理软件,由Adobe公司开发。它通常与Adobe InDesign一起使用,主要用于协作式工作流程中的文本编辑和校对。通过与InDesign的集成,InCopy实现了文本编辑和设计分离&#…

初步了解InnoDB存储引擎的架构设计

1. 更新语句在MySQL中是如何执行的? 之前我们已经分析了MySQL架构上的整体设计原理,现在对一条SQL语句从我们的系统层面发送到MySQL中,然后一步一步执行这条SQL的流程,都有了一个整体的了解。 我们已经知道了,MVSQL最…

Springboot 初始化操作

在使用Springboot过程中,或多或少我们会遇到在Springboot启动时要初始化类,或者加载文件之类的一些操作。关于初始化,主要分为两类,一类是在程序启动后的执行初始化操作,另一类是Bean实例化时执行初始化操作&#xff0…

3D Tiles 规范(一概述)

3D Tiles 专为流式传输和渲染大量 3D 地理空间内容而设计,例如摄影测量、3D 建筑、BIM/CAD、实例化要素和点云。它定义了分层数据结构和一组提供可渲染内容的Tile格式。3D Tiles 没有定义内容可视化的明确规则;客户可以根据自己认为合适的方式可视化 3D …

如何理解Vue 3组件的component关键字

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Verilog仿真跨模块调用内部信号的方法

在Verilog仿真时如果需要调用某子模块中的信号在本模块中使用可以使用层次化引用的方法,而不需要在rtl部分用端口引出来。 引用方式:当前例化模块名.子例化模块名.子子例化模块名.参数 将需要的信号引出。 注意是用例化模块名而不是用子模块名&#xff…

【C++】二维数组传参方式

最近刚开始刷剑指offer,刚做到第三题的时候,发现C二维数组的传参方式和C语言略有些不同,所以在这篇博客中,会列出C/C常见的二维数组传参方式。(本方式和代码都是基于vs环境所编写) 一.C语言二维数组传参方式…