基于霍夫变换的航迹起始算法研究(Matlab代码实现)

news2024/12/23 16:47:01

     目录

💥1 概述

📚2 运行结果

🎉3 参考文献

👨‍💻4 Matlab代码

💥1 概述

一、设计内容

利用Hough变换处理量测得到的含杂波的二维坐标,解决多目标航迹起始问题。使用Matlab进行仿真,用离散点绘制原始数据,用连线绘制处理结果。

二、主要技术指标

1、掌握标准Hough变换检测直线的基本原理,以及一些改进的Hough变换算法。

2、用Matlab实现Hough变换算法,并绘制处理结果。

航迹起始是航迹处理中的首要问题,在各种航迹处理的情况下都存在,对于多目标航迹处理来说,航迹起始是第一步,是进行航迹跟踪的基础。 由于被探测目标一般都是由远到近的出现在搜索雷达的有效探测范围内的,在航迹起始时,目标一般距离雷达较远,此时雷达分辨力低、测量精度差,加之真假目标的出现无真正的统计规律,因此在搜索雷达数据处理技术中,航迹起始问题是一个难题。 现有的航迹起始算法可分为顺序处理技术和批处理技术两大类。通常,顺序数据处理技术适用于弱杂波环境中的航迹起始,主要包括启发式规则方法和基于逻辑方法;批处理技术则更适用于强杂波环境,主要包括Hough变换等方法。基于逻辑的方法在虚警概率比较低的情况下,起始航迹的效果比较好,但在复杂环境下虚假航迹比较多;Hough变换法则适用于强杂波背景下航迹成直线的环境,但是Hough变换法通常需要多次的扫描才能较好地起始航迹,且计算量大不符合工程应用的需要。

低信噪比、低信杂比下的航迹起始是多目标航迹起始的关键问题。Hough变换具有对局部缺损的不敏感性、对随机噪声的鲁棒性以及适于并行处理、实时应用等特点,特别史和解决多目标航迹起始问题。本文对Hough变换航迹起始算法进行了研究,主要工作如下:

1.概述了主要的航迹起始方法,介绍了Hough变换基本原理、Hough变换的特点,指出了Hough变换在航迹起始中存在的问题。

2.研究与分析了标准Hough变换、修正Hough变换和序列Hough变换三种典型航迹起始算法。通过仿真分析,总结出每种算法的适用环境。

Hough变换用于航迹起始具有以下特点:

(1)将量测空间中的检测问题转换到参数空间进行,具有很强的抗干扰能力,对随机噪声具有一定的鲁棒性;

(2)量测中的每一个点都参加“投票”,所以它特别适合并行处理;

(3)一种变换方程只对某一种特定的曲线进行检测,针对性强;

(4)不受空间和曲线形状的影响:广义Hough变换可以检测任意形状的曲线,三维空间Hough变换可以检测空间曲线。

Hough变换用于航迹起始具有以下优点:

(1)Hough变换可以检测任意已知形状的曲线,从而能够起始某类特定航迹,作为先验信息,特定航迹的选定提高了信号相干累积的效率,避免了大量杂波引起的虚假航迹问题;

(2)Hough变换不要求曲线连续或可导,并且对局部缺损和随机噪声鲁棒,适于低检测率和低量测精度下的起始;

(3)Hough变换用于航迹起始不需要目标状态初值,可实现全自动起始。

本文通过大量仿真实验体会到Hough变换航迹起始算法存在若干问题,严重地影响这航迹起始的性能,具体体现在:

(1)标准Hough变换的计算量庞大,并且需要很大的存储空间,在低信噪比环境下表现得特别明显,延长了航迹起始时间,达不到快速性起始的要求。

(2)Hough变换航迹起始算法在提取航迹参数时一般使用阈值法,这就不可避免的出现航迹簇拥现象,即一个目标产生了参数近似的多条轨迹。如何选择峰值提取方法既能准确地提取峰值,同时又能有效地解决航迹簇拥现象,是亟待解决的问题。

(3)Hough变换航迹起始算法应用于工程实际带来了诸多问题,如:实际系统中涉及参数众多,如何对这些参数进行全面有效地利用,是急需解决地问题;针对不同地起始环境应该研究不同地专用算法与之相匹配;实际系统中,很多参数地选取都不能由理论公式推导得出,而要通过大量得仿真实验得出。

📚2 运行结果

主函数部分代码:

%标准Hough变换
%Author:Shen Baoyin
%Time:2018/8/1
close all
clear all
​
target=2;%目标数
n=15;%起始拍数
k=90;%sig分的个数
m=500;%p分的个数
Monte_Carlo=100;%Monte_Carlo仿真次数
L=150;%雷达量测距离
Pd=1;%检测概率
​
%目标起始坐标及速度
x1=40;y1=20;vx1=0.3;vy1=0.18;%单位km,km/s
x2=20;y2=80;vx2=0.3;vy2=-0.18;
Ts=4;%采样周期,单位s
​
success=zeros(Monte_Carlo,target);%目标航迹成功起始矩阵
fake(1:Monte_Carlo)=0;%目标航迹虚假起始矩阵
track_number(1:Monte_Carlo)=0;%总航迹起始数
​
N=0:n-1;
X1_init=x1+Ts*N*vx1;%真实航迹1
Y1_init=y1+Ts*N*vy1;
Y1_0=y1-vy1*x1/vx1;
offset(1)=Y1_0*cos(atan(abs(vy1)/abs(vx1)));%航迹1真实垂距
X2_init=x2+Ts*N*vx2;%真实航迹2
Y2_init=y2+Ts*N*vy2;
Y2_0=y2-vy2*x2/vx2;
offset(2)=Y2_0*cos(atan(abs(vy2)/abs(vx2)));%航迹2真实垂距
​
Np=1:k;
dNp=pi/k;%参数空间角度间隔
angle=(Np-1/2)*dNp;
​
dMp=6*0.1;%%参数空间垂距间隔
​
for monte=1:Monte_Carlo
    clear R Rn A0 P0 R X_za Y_za noisex noisey
    R = poissrnd(50,1,n);%每拍杂波个数,服从泊松分布
    Rn=R(1);
    X_za=unifrnd (0, 100, 1, R(1));%随机产生(x,y)坐标,服从0-100的均匀分布
    Y_za=unifrnd (0, 100, 1, R(1));
    for i=2:n
        X_za(Rn+1:Rn+R(i))=unifrnd (0, 100, 1, R(i));
        Y_za(Rn+1:Rn+R(i))=unifrnd (0, 100, 1, R(i));
        Rn=Rn+R(i);
    end
​
    noisex=normrnd(0,0.1,1,n);%x量测噪声
    noisey=normrnd(0,0.1,1,n);
​
    X1=X1_init+noisex;X2=X2_init+noisex;%实际量测
    Y1=Y1_init+noisey;Y2=Y2_init+noisey;
​
    A=zeros(k,2*m);%积累矩阵
​
    %航迹1 Hough变换
    for i=1:n
        for j=1:k
            P(i,j)=X1(i)*cos(angle(j))+Y1(i)*sin(angle(j));
        end
    end
    
    %航迹2 Hough变换
    for i=(n+1):(2*n)
        for j=1:k
            P(i,j)=X2(i-n)*cos(angle(j))+Y2(i-n)*sin(angle(j));
        end
    end
​
    %杂波的Hough变换
    for i=2*n+1:(2*n+Rn)
        for j=1:k
            P(i,j)=X_za(i-2*n)*cos(angle(j))+Y_za(i-2*n)*sin(angle(j));
        end
    end
​
    %对积累矩阵投票
    for i=1:k
        for j=1:2*m
            a=-L+(j-1)*dMp;
            b=-L+j*dMp;
           for h=1:2*n+Rn
               if (P(h,i)>=a && P(h,i)<b) 
                   A(i,j)=A(i,j)+1;
               end
           end
        end
    end

🎉3 参考文献

​[1]高国琴,李明.基于K-means算法的温室移动机器人导航路径识别[J].农业工程学报,2014,30(07):25-33.

部分理论引用网络文献,若有侵权联系博主删除。

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

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

相关文章

设计模式详解(一):工厂方法——Factory Method

目录导航 工厂方法及其作用工厂方法的好处工厂方法的实现关系图实现步骤 工厂方法的适用场景工厂方法举例 工厂方法及其作用 工厂方法是一种创建型设计模式。所谓创建型设计模式是说针对创建对象方面的设计模式。在面向对象的编程语言里&#xff0c;我们通过对象间的相互协作&…

【聚类算法】密度峰值聚类算法DPC(Density Peak Clustering Algorithm)

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 密度峰值聚类算法&#xff08;Density Peak Clustering Algorithm&#xff09;&#xff0c;能够自动发现数据中的密度峰值点&#xff0c;并根据峰值点将数…

Java:创建文件夹并输出内容到文件中

前言 在实际开发当中我们往往会遇到需要用 Java 代码来进行在我们项目的部署的服务器上创建一个文件并向里面写入想要的数据&#xff0c;下面就是具体的实现方式&#xff0c;希望对小伙伴们有用。 代码 这里我把这个操作封装成了一个工具类&#xff0c;方便根据不同业务场景…

中国品牌在海外做独立站有什么优势?

从人口红利驱动转向消费升级驱动——品牌出海行业的变局正在上演&#xff0c;低价不再是适用于所有出海企业的策略。从产品出海走向真正意义上的品牌出海&#xff0c;正在成为一部分中国商家的选择。 无论是做品牌还是做全球化&#xff0c;都不容易。消费者购买的不止产品&…

从零开始 verilog 以太网交换机(六)帧处理单元设计与实现

从零开始 verilog 以太网交换机&#xff08;六&#xff09;帧处理单元设计与实现 &#x1f508;声明&#xff1a; &#x1f603;博主主页&#xff1a;王_嘻嘻的CSDN主页 &#x1f9e8; 从零开始 verilog 以太网交换机系列专栏&#xff1a;点击这里 &#x1f511;未经作者允许&a…

Android Java代码与JNI交互 JNI访问Java构造方法(九)

🔥 Android Studio 版本 🔥 🔥 创建包含JNI的类 JNIConstructorClass.java 🔥 package com.cmake.ndk1.jni;import com.cmake.ndk1.model.Animal;public class JNIConstructorClass {static {System.loadLibrary("constructor-class-lib");}public native…

深度学习——CNN卷积神经网络

基本概念 概述 卷积神经网络&#xff08;Convolutional Neural Network&#xff0c;CNN&#xff09;是一种深度学习中常用于处理具有网格结构数据的神经网络模型。它在计算机视觉领域广泛应用于图像分类、目标检测、图像生成等任务。 核心思想 CNN 的核心思想是通过利用局部…

环形链表(快慢指针)

给你一个链表的头节点 head &#xff0c;判断链表中是否有环。如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置&#xff08;索…

C++ | 继承

目录 前言 一、继承的基本概念与使用 1、继承的概念 2、继承的定义 3、继承的访问限定符与继承方式 二、基类与派生类之间的赋值转换&#xff08;切片&#xff09; 三、继承中的作用域 1、继承中的作用域 2、隐藏&#xff08;重定义&#xff09; 四、派生类的默认构…

知识付费小程序怎么做

知识付费小程序是一种通过在线平台提供知识和教育内容的应用程序。下面将详细介绍其功能&#xff1a; 1. 音频视频课程&#xff1a; 知识付费小程序提供了丰富的音频和视频课程&#xff0c;在这些课程中&#xff0c;用户可以通过观看或听取专业讲师的讲解来学习各种知识领域。…

【文章系列解读】Nerf

1. Nerf NeRF: Representing Scenes as Neural Radiance Fields for View Synthesis 2020年8月3日 &#xff08;0&#xff09;总结 NeRF工作的过程可以分成两部分&#xff1a;三维重建和渲染。&#xff08;1&#xff09;三维重建部分本质上是一个2D到3D的建模过程&#xff…

Java习题之实现平方根(sqrt)函数

目录 前言 二分查找 牛顿迭代法 总结 &#x1f381;博主介绍&#xff1a;博客名为tq02&#xff0c;已学C语言、JavaSE&#xff0c;目前学了MySQL和JavaWed &#x1f3a5;学习专栏&#xff1a; C语言 JavaSE MySQL基础 &#x1f384;博主链接&#xff1a;tq02的…

【第四章 flutter-初识flutter】

文章目录 一、目录结构二、创建一个flutter项目三、创建自定义组件四、Container组件 就是divalignment 内容对齐方式decoration 类似border 为BoxDecoration的类 五、Text属性六、image组件总结、 一、目录结构 android、ios各自平台的资源文件 lib 项目目录 linux macos PC平…

Linux宝塔Mysql读写分离配置,两台服务器,服务器存在多个库

Linux宝塔Mysql读写分离配置&#xff0c;两台服务器&#xff0c;服务器存在多个库 一、主库操作 #登录数据库&#xff0c;用root登录方便&#xff0c;用其他账号会提示权限不足&#xff0c;需要登录root给予权限 mysql -u root -p 密码#创建一个账号&#xff0c;供从库用该账…

电商企业需要部署WMS仓储管理系统吗

随着电子商务行业的迅速发展&#xff0c;电商企业面临着日益增长的订单量和复杂的物流流程。为了提高仓储管理的效率和准确性&#xff0c;许多电商企业开始考虑部署WMS仓储管理系统。然而&#xff0c;是否真的需要部署WMS仓储管理系统&#xff0c;仍然是一个值得探讨的问题。本…

vLLM大模型推理加速方案原理(PagedAttention)

一、vLLM 简介 vLLM 用于大模型并行推理加速&#xff0c;核心是 PagedAttention 算法&#xff0c;官网为&#xff1a;https://vllm.ai/。 vLLM 主要特性&#xff1a; 先进的服务吞吐量通过 PagedAttention 对注意力 key 和 value 进行内存管理对传入请求的批处理针对 CUDA 内…

纯代码和低代码的本质区别

一、前言 纯代码和低代码是现代软件开发中两种不同的方法。 纯代码需要专业的编程技能&#xff0c;掌握编程语言、算法和数据结构等专业知识。而低代码则是一种新兴的开发方法&#xff0c;它大大降低了对编程技能的要求&#xff0c;让非技术人员也能够创建应用程序。随着低代码…

【SpringBoot】--03.数据访问、基础特性(外部化和内部外配置、整合JUnit)

文章目录 SpringBoot3-数据访问1.整合SSM场景1.1创建SSM整合项目1.2配置数据源1.3配置MyBatis1.4CRUD编写 2.自动配置原理3.扩展&#xff1a;整合其他数据源3.1 Druid 数据源 SpringBoot3-基础特性1. SpringApplication1.1 自定义 banner1.2.自定义 SpringApplication1.3Fluent…

nvm 管理node 环境配置

nvm安装&#xff1a; nvm&#xff08;Node Version Manager&#xff09;是一个用来管理node版本的工具。我们之所以需要使用node&#xff0c;是因为我们需要使用node中的npm(Node Package Manager)&#xff0c;使用npm的目的是为了能够方便的管理一些前端开发的包&#xff01;…

ColorOS凭什么夺冠?

摘要&#xff1a;五大主流安卓系统流畅度PK&#xff0c;谁的体验最好&#xff1f; 评价一款手机&#xff0c;你最先看的是什么&#xff1f; 是处理器平台&#xff1f;CPU核心频率&#xff1f;还是内存配置&#xff1f; 虽然这些硬件参数能够清晰地反映几款不同配置手机之间的性…