news 2026/5/28 18:53:03

积分旁瓣电平-matlab函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
积分旁瓣电平-matlab函数
%% ISL 计算 % 该示例用于采用我自己编写的ISL公式计算ISL clear all; close all; clear; N = 128; %信号长度 plotEnableHigh = 1; randPhaSig = exp(1j*2*pi*rand(N,1)); %生成随机相位编码信号 mlb = 0; %设置主瓣宽度为0,即只有自相关延迟为0的值 figure; plot(real(randPhaSig),'linewidth',1); axis tight; title(sprintf('长度为N=%d的随机相位编码信号',N)); [ISL_linear, ISL_dB, PSL_dB] = myISLPSL (randPhaSig, mlb, plotEnableHigh);

调用了计算积分旁瓣电平和峰值旁瓣电平的函数如下:

function [ISL_linear, ISL_dB, PSL_dB] = myISLPSL (x, mlb, plotEnable) %% 计算积分旁瓣电平 % 自己动手编写的波形的自相关的ISL积分旁瓣电平、PSL峰值旁瓣电平 % 输入: % x: 输入信号 % mlb: 主瓣宽度,主瓣一半的宽度 % 输出: % ISL_linear:ISL输出,以线性值 % ISL_dB: 以dB值输出 N = length(x); %输入信号的长度为N,那么自相关序列的长度为2N+1 acf = xcorr(x); %计算自相关函数 acf_norm = acf/max(abs(acf)); %对自相关函数进行归一化 acf_power = abs(acf_norm).^2; %能量值,这里取了平方 mainLobeCenter = N; %找到主瓣的中心位置 % 定义主瓣区域和旁瓣区域 mainLobeInd = mainLobeCenter-mlb : mainLobeCenter+mlb; %主瓣区域 sideLobeInd = [1: (mainLobeCenter - mlb - 1), (mainLobeCenter + mlb + 1):length(acf)]; %旁瓣区域 % 计算主瓣能量和旁瓣能量 mainLobePower = sum(acf_power(mainLobeInd)); %主瓣总能量 sideLobePower = sum(acf_power(sideLobeInd)); %旁瓣总能量 % 计算峰值旁瓣电平 sideLobePeak_linear = max(abs(acf_norm(sideLobeInd)))/1; %峰值旁瓣电平 PSL_dB = 20*log10(sideLobePeak_linear); %以dB为单位的PSL PSL_ind = find(abs(acf_norm) == sideLobePeak_linear) PSL_ind = PSL_ind(1); %仅保留第一个峰值 % 计算ISL(两种表示) ISL_linear = sideLobePower / mainLobePower; %积分旁瓣电平,这里以主瓣能量 ISL_dB = 10*log10(ISL_linear); %dB值表示的积分旁瓣电平 acd_ind = (-N+1):(N-1); %自相关函数的延迟取值范围 if plotEnable == 1 fprintf('=== ISL计算示例 ===\n'); fprintf('主瓣峰值能量: %.4f\n', mainLobePower); fprintf('旁瓣总能量: %.4f\n', sideLobePower); fprintf('ISL(线性): %.6f (无量纲比值)\n', ISL_linear); fprintf('ISL(dB): %.2f dB\n', ISL_dB); fprintf('\n注意:ISL_dB中的"dB"不是物理单位,而是对数标度表示\n'); sidelobePoints = length(sideLobeInd) averagePower = sum(abs(acf_norm(sideLobeInd)))/sidelobePoints; %平均能量 averLine = ones(1,2*N-1).*averagePower; figure; plot(acd_ind, 20*log10(abs(acf_norm) + eps), 'linewidth',1); %加上eps可以防止太小的值 %plot(acd_ind, (abs(acf_norm) + eps), 'linewidth',1); %加上eps可以防止太小的值 hold on; plot(acd_ind, 20*log10(averLine),'b--', 'linewidth',1); %加上eps可以防止太小的值 plot(acd_ind(PSL_ind), 20*log10(abs(acf_norm(PSL_ind))), 'ro'); axis tight; title(sprintf('自相关函数\n积分旁瓣电平ISL = %.2fdB, 峰值旁瓣电平PSL = %.2fdB',ISL_dB, PSL_dB)); legend('自相关值','平均值','PSL'); end


这里生成了128位的随机相位编码波形,经过自相关后再做归一化,可以看到主瓣峰值为0dB,积分旁瓣的整体的平均水平再-25dB左右,峰值旁瓣电平为-16.88dB,与LFM信号的-13.2dB相比还是略低一点的。但是它不如LFM的旁瓣那么平滑,而是有很多凸起。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 16:50:42

pythonstudy Day47

预训练模型 疏锦行 我们之前在训练中发现,准确率最开始随着epoch的增加而增加。随着循环的更新,参数在不断发生更新。 所以参数的初始值对训练结果有很大的影响: 如果最开始的初始值比较好,后续训练轮数就会少很多很有可能陷入…

作者头像 李华
网站建设 2026/5/24 11:24:11

什么时候@Async会失效?

有多种原因可造成Async失效: 1.Async依赖于Spring AOP,如果是内部调用的话则会绕过代理对象,直接调用原始方法。 2.Spring AOP默认只会对public方法生效,对于非public方法则不会被代理,所以此时Async是失效的。 3.如果…

作者头像 李华
网站建设 2026/5/9 20:27:03

Java是怎么实现跨平台的?

跨平台指的是在不同的硬件或者操作系统上,Java代码在不需要针对不同的平台做对应的修改的前提下,都可以正常运行。 要实现这样一种一次编写到处运行的特性,主要靠的是JVM,即Java虚拟机。 和其他编程语言在编译后直接生成特定于某一…

作者头像 李华
网站建设 2026/5/22 1:03:25

集体好奇心如何引爆乘数效应

集体好奇心如何引爆乘数效应关键词:集体好奇心、乘数效应、群体智慧、创新驱动、社交互动、知识共享、协同合作摘要:本文聚焦于集体好奇心如何引爆乘数效应这一核心问题。通过深入剖析集体好奇心的概念、形成机制,阐述其与乘数效应的内在联系…

作者头像 李华
网站建设 2026/5/28 17:49:06

幽冥大陆(八十七 ) 水果识别在线检测模型netron —东方仙盟练气期

ncnn:东方仙盟式的轻轻量高效深度学习推理框架 在深度学习的江湖中,ncnn 犹如一个隐世的东方仙盟,以其独特的 "内功心法" 和 "神兵利器",在终端设备的深度学习推理领域占据一席之地。作为腾讯开源的高性能神…

作者头像 李华