基于Matlab计算经典CFAR阈值

news2024/10/6 20:31:10

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法  神经网络预测 雷达通信  无线传感器

信号处理 图像处理 路径规划 元胞自动机 无人机  电力系统

⛄ 内容介绍

基于Matlab计算经典CFAR阈值

⛄ 完整代码

function T = calcCFARthreshold(nTest, nRef, thePFA)

% calculates classical radar CFAR threshold for 0-mean AWGN

% classical Neyman-Pearson detection threshold for radar detection

% under additive Gaussian white noise criterion and specifid false alarm

% probability.

% the threshold T is calculated such that under the noise-only condition

% 计算0均值AWGN的经典雷达CFAR阈值

% 雷达检测的经典Neyman-Pearson检测阈值

% 在加性高斯白噪声准则和特定的虚警概率下

% 仅在噪声条件下计算阈值T

% prob(Ptest > T * Pref) <= pfa                        Eq(1)公式1

%

% where Ptest is the sum of normed-squares of the nTest cells

%       Pref  is the sum of normed-squares of the nRef cells

%       pfa is the required maximum type-I (aka false alarm prob) error

%其中:Ptest是nTest单元的标准平方和,Pref是nRef单元的标准平方和,pfa是所需的最大类型-I(又名虚警概率)误差

%

% inputs: nTest  - the number of noise-only test cells

%         nRef   - the number of noise-only reference cells

%         thePfA - maximum probability such that 

%                  prob(Ptest/Pref > T) <= pfa         Eq(2)

%                  This is equivalent to Eq(1) 

%inputs:nTest  - 仅噪声测试单元的数量

%        nRef  - 仅噪声参考单元的数量

%        thePfA  - 这样的最大概率prob(Ptest / Pref> T)<= pfa Eq(2)相当于方程(1)

% demo:  calcCFARthreshold;  % no inputs

%demo: 计算0均值AWGN的经典雷达CFAR阈值;%无输入

% the classical CFAR processor compares the total power in nTest cells

% to the power in nRef cells. The threshold T is selected so that the 

% ratio of Eq(2) is satisfied. it is assumed that the both sets' cells

% contain only thermal (AWGN) noise. If this ratio exceeds T, it assumed a 

% radar target exists. The probability that only noise exceeds T is given 

% by the threshold T (usually on the order of 10^-4 to 10^-7). 

%经典CFAR处理器将nTest单元中的总功率与nRef单元中的功率进行比较。

%选择阈值T使得满足Eq(2)(公式2)的比率。

%假设两组'单元仅包含热(AWGN)噪声。

%如果该比率超过T,则假定存在雷达目标。

%仅噪声超过T的概率由阈值T给出(通常在10 ^ -4到10 ^ -7的数量级)。

% michaelB brost. as usual, fully sharable under GPLv3

% michaelB brost. 像往常一样,在GPLv3下完全可以共享

% demo

if(nargin == 0),%nargin是用来判断输入变量个数的函数:如果输入变量的数目为0

    nTest = 10; %仅噪声测试单元个数

    nRef  = 25; %仅噪声参考单元的数量

    thePFA = 1e-4;%方程2:“prob(Ptest/Pref > T) <= pfa”的最大概率,方程2等效与方程1“prob(Ptest > T * Pref) <= pfa”

    T = calcCFARthreshold(nTest, nRef, thePFA);

    doTest(nTest, nRef, thePFA, T);

    clear('T');

    return;

end

% requires the statistics toolbox需要统计工具箱

T = finv(1 - thePFA, nTest, nRef) * nTest / nRef;

return

function doTest(nTest, nRef, thePfa, T)

% simple test of threshold calc阈值计算的简单测试

nPt   = min(1e5, ceil(50/thePfa));

nIter = 15;

nHit  = zeros(nIter, 1);

wHnd = waitbar(0, '');

for k1=1:nIter

    % test set noise power测试设置噪声功率

    testPower = sum(randn(nPt, nTest).^2, 2);

    % reference set noise power参考设定噪声功率

    refPower = sum(randn(nPt, nRef).^2, 2);

    

    % test

    index = find(testPower >= (T .* refPower)); 

    % >(大于),>=(大于等于),<(小于),<=(小于等于), ==(等于),~=(不等于)

    % count up contacts 计数

    nHit(k1) = length(index);

    

    waitbar(k1/nIter, wHnd, sprintf('PFA simulation iteration %d of %d', k1, nIter));

   

end

close(wHnd);

pHit = nHit / nPt;

figure;

stem(pHit);

ylabel('P_F_A');

xlabel('runs');

pfaAvg = mean(pHit);

pfaStd = sqrt(var(pHit));

title(sprintf(...

    'calculated average pfa: %5.3e, 1-sigma: %5.3e (design: %5.2e)\n', ...

    pfaAvg, pfaStd, thePfa));

hold on;

lHnd = line([1, nIter], [thePfa, thePfa]);

set(lHnd, 'color', 'k');

lHnd = line([1, nIter], [pfaAvg, pfaAvg]);

set(lHnd, 'color', 'b');

lHnd = line([1, nIter], [thePfa, thePfa] - pfaStd);

set(lHnd, 'color', 'r');

lHnd = line([1, nIter], [thePfa, thePfa] + pfaStd);

set(lHnd, 'color', 'r');

legend('simulated PFA', 'specified PFA', 'mean PFA', '1 \sigma limits', ...

'location', 'south');

set(gca, 'xlim', [0, nIter+1]); 

⛄ 运行结果

⛄ 参考文献

⛄ Matlab代码关注

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

❤️ 关注我领取海量matlab电子书和数学建模资料

 

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

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

相关文章

基于开源 PolarDB-X 打造中正智能身份认证业务数据基座

一、公司及业务介绍 中正智能是全球领先的生物识别和身份认证公司之一。我们曾负责公安部指纹算法国家标准的起草、编写&#xff0c;具备从算法、终端、平台、设计、生产、交付全域自研的能力&#xff0c;拥有多项自主知识产权的产品&#xff0c;并积极与高校合作开展基础研发。…

【Rust 指南】并发编程|无畏并发的原因

文章目录前言1、线程1.1、通过 spawn 创建新线程1.2、join 方法2、move 强制所有权迁移3、使用消息传递跨线程传递数据3.1、Send 方法3.2 、Sync 方法前言 安全高效的处理并发是 Rust 诞生的目的之一&#xff0c;主要解决的是服务器高负载承受能力。 并发&#xff08;concurren…

石家庄正定县恢复种植 国稻种芯·中国水稻节:河北绘就画卷

石家庄正定县恢复种植 国稻种芯中国水稻节&#xff1a;河北绘就画卷 新华社记者 杨世尧 摄 河北日报 通讯员张 晓峰 摄影报道 新闻中国采编网 中国新闻采编网 谋定研究中国智库网 中国农民丰收节国际贸易促进会 国稻种芯中国水稻节 中国三农智库网-功能性农业农业大健康大会…

MongoDB备份与恢复

MongoDB备份与恢复 文章目录MongoDB备份与恢复1.备份恢复工具2.备份工具区别3.mongoexport导出工具命令4.导出MongoDB的表4.1.创建备份的目录4.2.登录数据库4.3.查询表和表中数据4.4.导出数据为json格式4.5.导出数据为csv格式5.mongoimport导入工具5.1.恢复json格式数据5.2.登录…

Python基础-3-列表

一&#xff1a;简述 列表是由一系列按特定顺序排列的元素组成&#xff0c;可以创建包含字母表中所有字母&#xff0c;数字或家庭成员姓名的列表&#xff1b;也可以将任何东西加入列表&#xff0c;其中的元素之间可以没有任何关系。列表中通常包含了多个元素&#xff0c;因此给…

HTTPS中间人攻击实验

HTTPS中间人攻击实验 一.实验基础 1、HTTPS概述 HTTPS (全称: Hyper Text Transfer Protocol over SecureSocketLayer)&#xff0c; 是以安全为目标的HTTP通道&#xff0c;在HTTP的基础上通过传输加密和身份认证保证了传输过程的安全性。 默认端口&#xff1a;443 SSLspli…

【无人机】基于拓展卡尔曼滤波时序四旋翼无人机状态跟踪附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

SpringBoot+Vue项目实现疫情期间社区出入管理系统

文末获取源码 开发语言&#xff1a;Java 使用框架&#xff1a;spring boot 前端技术&#xff1a;JavaScript、Vue.js 、css3 开发工具&#xff1a;IDEA/MyEclipse/Eclipse、Visual Studio Code 数据库&#xff1a;MySQL 5.7/8.0 数据库管理工具&#xff1a;phpstudy/Navicat JD…

web前端期末大作业——基于Bootstrap响应式汽车经销商4S店官网21页

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

【prometheus上报和使用】

prometheus上报和使用prometheus环境搭建进行上报CountrateirateincreaseGaugehistogram分位线summaryprometheus Prometheus是由SoundCloud开发的开源监控系统&#xff0c;由GO语言编写而成&#xff0c;采用Pull的方式来获取监控信息&#xff0c;并且提供了多维度的数据模型和…

Linux-sed

sed sed是一种几乎包括所有UNIX平台&#xff08;包括Linux&#xff09;的轻量级流编辑器。sed主要用来将数据进行选取、替换、删除、新增的命令 sed [选项] ‘[动作]’ 文件名 选项&#xff1a; -n&#xff1a;一般sed命令会把所有数据都输出到屏幕&#xff0c;如果加入此选项…

vue.js毕业设计,基于vue.js前后端分离订座预约系统设计与实现(H5移动项目)

功能介绍 【后台功能】 广告管理&#xff1a;设置小程序首页轮播图广告和链接 留言列表&#xff1a;所有用户留言信息列表&#xff0c;支持删除 会员列表&#xff1a;查看所有注册会员信息&#xff0c;支持删除 录入资讯&#xff1a;录入资讯标题、内容等信息 管理资讯&#x…

HTTP Only下的XSS攻击

今天继续给大家介绍渗透测试相关知识&#xff0c;本文主要内容是HTTP Only下的XSS攻击。 免责声明&#xff1a; 本文所介绍的内容仅做学习交流使用&#xff0c;严禁利用文中技术进行非法行为&#xff0c;否则造成一切严重后果自负&#xff01; 再次强调&#xff1a;严禁对未授权…

程序猿成长之路之密码学篇-密码学简介

在阅读本文前需要了解的术语&#xff1a; 授权人/非授权人&#xff1a;授权人指获取了查看数据权限的用户&#xff0c;非授权人则是指未获取到权限的用户。明文/密文&#xff1a;明文指没有加密的数据内容&#xff0c;密文是指加密后的数据内容CIA(密码学中不是美国中情局的意思…

npm 如何更新项目最新依赖包

NPM 是什么&#xff1f; Node 软件包管理器(NPM)提供了各种功能来帮助你安装和维护项目的依赖关系。 由于错误修复、新功能和其他更新&#xff0c;依赖关系可能会随着时间的推移而变得过时。你的项目依赖越多&#xff0c;就越难跟上这些更新。 老旧的软件包会对安全构成威胁&am…

USB-数据传输

一、USB编码-反向不归零编码(NRZI)位填充 规则&#xff1a;数据为0&#xff0c;电平反转&#xff0c;数据为1&#xff0c;电平不翻转;当连续出现6个相同的1穿插一个0&#xff0c;目的是为了防止连续出现多个1导致的同步漂移。 二、USB传输帧 帧是USB传输的时间单位&#xff0…

深入浅出PyTorc——进阶训练技巧

1. 自定义损失函数 1.1 以函数方式定义 手动写出损失的公式并用函数进行存储&#xff0c;方便调用。 def my_loss(output, target):loss torch.mean((output - target)**2)return loss 1.2 以类方式定义 1.2.1 损失函数的继承关系 &#xff08;1&#xff09;Loss函数部分继…

POI及EasyExcel

1.谈谈 POI 和 easyExcel 应用场景 1.将用户信息导出为excel表格&#xff08;导出数据....&#xff09;2.将Excel表中的信息录入到网站数据库&#xff08;习题上传....&#xff09; 开发中经常会设计到excel的处理&#xff0c;如导出Excel&#xff0c;导入Excel到数据库中&…

详解Spring面试IoC和AOP

Spring IOC 和 AOP 文章目录Spring IOC 和 AOP前言什么是 IoC&#xff1f;**为什么叫控制反转**不用IoC&#xff1a;所有对象开发者自己创建使用IoC&#xff1a;对象不用卡法这创建&#xff0c;而是交给Spring框架完成基于XML和基于注解基于XML&#xff1a;基于注解&#xff1a…

TeeChart Pro for .NET 2022.10.24 Crack

.NNET 的 TeeChart 图表控件提供了一个很好的通用组件套件&#xff0c;可以满足无数的图表需求&#xff0c;也针对重要的垂直领域&#xff0c;例如金融、科学和统计领域。 数据可视化 数十种完全可定制和交互式的图表类型、地图和仪表指示器&#xff0c;以及完整的功能集&#…