基于鲸鱼优化算法的5G信道估计(Matlab代码实现)

 💥💥💥💞💞💞欢迎来到本博客❤️❤️❤️💥💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

👨‍💻4 Matlab代码实现


💥1 概述

       2006年, Donoho等人[4提出压缩感知(Com-pressive Sensing , CS)概念框架,并用数学模型为理论提供支撑。压缩感知理论突破了奈奎斯特采样定理对信号维度的限制,避免稀疏信号在奈奎斯特采样时会产生的大量冗余信息,并缓解硬件设备和算法负担。

鲸鱼优化算法(Whale Optimization Algorithm,简称WOA)是一种启发式算法,受到鲸鱼在寻找猎物时的行为启发而提出的。它主要用于解决优化问题,包括信道估计问题。

5G信道估计是为了获取无线信道的状态信息,以便进行资源分配、功率控制等操作。在使用鲸鱼优化算法进行5G信道估计时,按照以下步骤进行:

1. 定义问题:明确信道估计的目标和约束条件。例如,可以将问题定义为最小化信道误差的均方根(Root Mean Square Error,RMSE)。
2. 初始化种群:随机生成一些鲸鱼个体作为初始种群。
3. 迭代更新:通过模拟鲸鱼的搜索行为进行迭代更新。具体来说,可以按照以下步骤进行:
   - 计算适应度:根据当前鲸鱼个体的位置,计算其对应的适应度值,即信道误差。
   - 更新最优个体:记录当前种群中适应度最好的个体作为当前的最优解。
   - 更新位置:根据当前个体的适应度值和最优个体的位置,更新每个鲸鱼个体的位置。
   - 更新搜索半径:根据当前迭代次数和最大迭代次数的比值,更新每个鲸鱼个体的搜索半径。
   - 达到停止条件:判断是否达到停止条件,如果是,则停止迭代;否则,返回到第一步进行下一轮迭代。
4. 输出结果:根据迭代结束后的最优个体,得到信道估计结果。

需要注意的是,鲸鱼优化算法的效果与具体的问题、算法参数设置以及迭代次数等因素有关,因此在实际应用中,可以根据具体情况进行调整和优化。此外,还可以结合其它算法和技术,如机器学习方法和统计方法,来进一步提高5G信道估计的性能。

📚2 运行结果

部分代码:

% Channel estimation using LS, WOA and MMSE 
% Number of OFDM Symbol = 1e1
% Channel model: TDLC-300

clc, clear; close all;
methods = {'LS ', 'WOA', 'MMSE'}            % Channel estimation methods

snrRange            = 0:5:30;               % Signal to noise ratio in dB
numSymbol           = 1e1;                  % Number of symbols
numFft              = 4096;                 % Size of DFT 
numCp               = numFft/4;             % Number of CP
subCarrierSpacing   = 30e3;                 % Subcarrier Spacing
numBitPerSym        = 4;                    % Number of bits per (modulated) symbol
numSymPerPilot      = 12;                   % Number of (modulated) symbol per pilots
numBitBerSecond     = 1e3;                  % Number of bits per second
signalEnergy        = 100;                  % Energy of signal

% Propagation Channel Model Configuration
% Create a TDL channel model object and specify its propagation characteristics.
numTapEst   = 400;                          % Number of est. channel taps
numTap      = 320;                          % Number of true channel taps

% TDLC300-100
tapDelay    = [0    65 70   190  195  200  245  325  520  1045  1510  2595];    % in ns
tapPower    = [-6.9 0  -7.7 -2.5 -2.4 -9.9 -8.0 -6.6 -7.1 -13.0 -14.2 -16.0];   % in dB 

% WOA Alg
maxIter     = 8;                            % maximum number of generations
numAgent    = 8;                            % Number of search agents

ub          = [50   100 400];               % [ub1,ub2,...,ubn] where ubn is the upper bound of variable n
lb          = [0    20  0];                 % [lb1,lb2,...,lbn] where lbn is the lower bound of variable n
dim         = 3;                            % Number of variables
positions   = rand(numAgent, dim).*(ub-lb) + lb;

visualization = 0;
saveOrNot = 0;                              % = 1 for save

sampRate    = numFft*subCarrierSpacing;     % Sample rate
numPilot    = ceil(numFft/numSymPerPilot);  % Number of pilots per OFDM symbol
pilotLoc    = zeros(numPilot, 1);           % Pilot's Location

pathLoss    = zeros(numTap, 1);         
tapSample   = round(tapDelay*1e-9*sampRate);  
pathLoss(tapSample+1) = 10.^(tapPower/10);  % Path loss of channel

M           = 2^numBitPerSym;               % M - QAM
A           = sqrt(3/2/(M-1)*signalEnergy); % QAM normalization factor
Nofdm       = numFft + numCp;               % Number of OFDM
numData     = numFft - numPilot;            % Number of data

MSEs_snr    = zeros(length(snrRange),length(methods));
ber_snr     = zeros(length(snrRange),length(methods));
fileIdx     = getFileId(saveOrNot);
tic 

for snrIdx = 1:length(snrRange)
    SNR = snrRange(snrIdx);
    er = zeros(1,length(methods));
    MSE = zeros(1,length(methods));
    for nsym=1:numSymbol

        msgint = randi([0 M-1],numFft-numPilot,1);      % Symbol generation
        data = qammod(msgint, M);


        % Add pilot
        p = randi([0, M-1], numPilot, 1);               % Pilot sequence generation
        pilot = qammod(p, M);
        ip = 0;
        X = zeros(numFft, 1);

        for k=1:numFft
            if rem(k,numSymPerPilot)== 1
                ip = ip+1;
                X(k)=pilot(floor(k/numSymPerPilot)+1);  % For pilot
                pilotLoc(ip) = k;                       % For pilot location
            else
                X(k) = data(k-ip);                      % For data
            end
        end

        % OFDM
        x = ifft(X,numFft);                             % IFFT
        xt = [x(numFft-numCp+1:numFft); x];             % add CP

        % PA
        tx = A*xt;
        signalPowerdB = 10*log10(cov(tx));

        % Channal gain
        h = (randn(numTap, 1)+1j*randn(numTap, 1))...
            .*sqrt(pathLoss/2);                        % Channel gain
        H = fft(h,numFft);                             % True channel frequency respond
        H_power_dB = 10*log10(abs(H.*conj(H)));        % True channel power in dB
        y_channel = conv(tx,h);                        % Channel path (convolution)

        % Add noise
        rx = awgn(y_channel, SNR, 'measured');
        % rx = y_channel + 1/(sqrt(2.0)*10^(SNR/20))*complex(randn(size(y_channel)),randn(size(y_channel)));

        % sto = sto_est(rx, numFft, numCp);
        % Receiver
        y = rx(numCp+1:Nofdm);                         % Remove CP
        Y = fft(y);                                    % FFT


        % Channel estimation
        for methodIdx = 1:length(methods)
            method = methods{methodIdx};
            if     method(1) == 'L'
                % LS estimation with linear interpolation
                H_est = LS_CE(Y,pilot,pilotLoc,numFft, 'linear');

            elseif method(1) == 'W'
                % WOA estimation
                [H_est, positions] = WOA_CE(Y,pilot,pilotLoc,numFft, numSymPerPilot, numBitPerSym, ...
                        positions,  numAgent, maxIter, lb, ub, dim);
          
            elseif method(1) == 'M'
                % MMSE estimation
                H_est = MMSE_CE(Y,pilot,pilotLoc,numFft,numSymPerPilot,h,SNR);
            end


            if method(end) == 'T'
                h_est = ifft(H_est);                   % Esti channel gain
                h_est = h_est(1:numTapEst);            % N-tap channel gain
                H_est = fft(h_est,numFft);             % DFT-based channel estimation
            end

            H_est_power_dB = ...
                10*log10(abs(H_est.*conj(H_est)));     % Esti channel power in dB


            Y_eq = Y./H_est;
            Data_extracted = zeros(numFft- numPilot, 1);
            ip = 0;

            for k=1:numFft
                if mod(k,numSymPerPilot)==1
                    ip=ip+1;
                else
                    Data_extracted(k-ip)=Y_eq(k);
                end
            end

            msg_detected = qamdemod(Data_extracted, M);
            bitDetected = de2bi(msg_detected, numBitPerSym);
            bitTrans    = de2bi(msgint, numBitPerSym);

            er(methodIdx) = er(methodIdx) + sum(sum(bitDetected~=bitTrans));

            MSE(methodIdx) = MSE(methodIdx) + (H-H_est/A)'*(H-H_est/A);

            %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
            if visualization
                figure(snrIdx)
                subplot(1, length(methods), methodIdx)
                hold on
                scatter(real(Data_extracted), imag(Data_extracted), 'b.')
                title(methods{methodIdx})
                pause(0)
            end

        end
    end

    MSEs = MSE/(numFft*numSymbol);
    MSEs_snr(snrIdx, :) = MSEs;
    ber_snr(snrIdx, :) = er/(numSymbol*numData*numBitPerSym);
    
  
    for methodIdx = 1:length(methods)
        str = sprintf('SNR = %2.0f dB: BER of %s \t= %6.5f\n', SNR, methods{methodIdx}, ber_snr(snrIdx, methodIdx));
        fprintf(str)
        if saveOrNot
            if methodIdx == 1

            fprintf(fileIdx, '\n-----------------------------------------\n');
            end

            fprintf(fileIdx, str);
        end
    end
end

if saveOrNot  
    fclose(fileIdx);
end

figure
subplot(121)
semilogy(snrRange, ber_snr)
legend(methods{:})
xlabel('SNR')
ylabel('BER')
grid on

subplot(122)
semilogy(snrRange, MSEs_snr)
legend(methods{:})
xlabel('SNR')
ylabel('MSE')
grid on
toc

% Local Functions
function [H_interpolated] = interpolate(H,pilot_loc,Nfft,method)
% Input: H = Channel estimate using pilot sequence
% pilot_loc = Location of pilot sequence
% Nfft = FFT size
% method = 鈥檒inear鈥�/鈥檚pline鈥�
% Output: H_interpolated = interpolated channel
if pilot_loc(1)>1
    slope = (H(2)-H_est(1))/(pilot_loc(2)-pilot_loc(1));
    H = [H(1)-slope*(pilot_loc(1)-1); H]; pilot_loc = [1; pilot_loc];
end

if pilot_loc(end) <Nfft
    slope = (H(end)-H(end-1))/(pilot_loc(end)-pilot_loc(end-1));
    H = [H; H(end)+slope*(Nfft-pilot_loc(end))];
    pilot_loc = [pilot_loc; Nfft];
end

if lower(method(1))=='l'
    H_interpolated = interp1(pilot_loc,H,[1:Nfft]', 'linear');
else
    H_interpolated = interp1(pilot_loc,H,[1:Nfft]', 'spline');
end
end

function H_LS = LS_CE(Y,Xp,pilot_loc,Nfft,int_opt)
% LS channel estimation function
% Inputs:
% Y = Frequency-domain received signal
% Xp = Pilot signal
% pilot_loc = Pilot location
% N = FFT size
% Nps = Pilot spacing
% int_opt = 鈥檒inear鈥� or 鈥檚pline鈥�
% output:
% H_LS = LS Channel estimate

LS_est = Y(pilot_loc)./Xp; % LS channel estimation
if lower(int_opt(1))=='l'
    method='linear';
else
    method='spline';
end
% Linear/Spline interpolation
H_LS = interpolate(LS_est,pilot_loc,Nfft,method);
end


function H_MMSE = MMSE_CE(Y,Xp,pilot_loc,Nfft,Nps,h,SNR)
% MMSE channel estimation function
% Inputs:
% Y = Frequency-domain received signal
% Xp = Pilot signal
% pilot_loc = Pilot location
% Nfft = FFT size
% Nps = Pilot spacing
% h = Channel impulse response
% SNR = Signal-to-Noise Ratio[dB]
% output:
% H_MMSE = MMSE channel estimate

% Calculate RMS delay spread
Ph = h.*conj(h);
Ptotal = h'*h;
t_sym = 1*(0:length(h)-1)';
t_mean = sum(t_sym.*Ph/Ptotal);
t_cov = sum(t_sym.^2.*Ph/Ptotal);
t_rms = sqrt(t_cov-t_mean^2);
f_max = 100;

H_MMSE = MMSE_ideal(Y,Xp,pilot_loc,Nfft,Nps,SNR, t_rms, f_max);
end


function [H_WOA, Positions] = WOA_CE(Y,Xp,pilot_loc,Nfft,Nps, Nbs, ...
                 Positions, NumAgent, Max_iter, lb, ub, dim)    

% fobj              = @CostFunction
% dim               = number of your variables
% Max_iteration     = maximum number of generations
% SearchAgents_no   = number of search agents
% lb                = [lb1,lb2,...,lbn] where lbn is the lower bound of variable n
% ub                = [ub1,ub2,...,ubn] where ubn is the upper bound of variable n


fobj = @ (x) MMSE_loss(Y, Xp, pilot_loc, Nfft, Nps, Nbs, x(1), x(2), x(3));

x = WhaleOptAlg(NumAgent,Max_iter,lb,ub,dim,fobj);
SNR   = x(1);
t_rms = x(2);
f_max = x(3);

H_WOA = MMSE_ideal(Y,Xp,pilot_loc,Nfft,Nps,SNR, t_rms, f_max);

end

function fileId = getFileId(enable)
if enable == 0
    fileId = 0;
    return 
end

ctime       = clock;
cmonth     = ctime(2); smonth  = num2str(cmonth);
cday       = ctime(3); sday    = num2str(cday);
chour      = ctime(4); shour   = num2str(chour);
cminute    = ctime(5); sminute = num2str(cminute);

fileName = ['CE', smonth, sday, shour, sminute, '.txt'];

fileId = fopen(fileName, 'w');
end

🎉3 参考文献

👨‍💻4 Matlab代码实现

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Unity 工具之 NuGetForUnity 包管理器,方便在 Unity 中的进行包管理的简单使用

Unity 工具之 NuGetForUnity 包管理器&#xff0c;方便在 Unity 中的进行包管理的简单使用 目录 Unity 工具之 NuGetForUnity 包管理器&#xff0c;方便在 Unity 中的进行包管理的简单使用 一、简单介绍 二、NuGetForUnity 的下载导入 Unity 三、NuGetForUnity 在 Unity 的…

Jetbrains idea 代码关闭 注释自动渲染 导致换行不生效

方法1 关闭注释自动渲染 取消勾选 方法2 结尾使用 <br> 强制换行

vector使用

文章目录 vector的介绍vector的使用vector的初始化vector iterator迭代器的使用vector 空间增长问题vector的增删改查 迭代器失效总结 vector的介绍 文档介绍 vector是表示可变大小数组的序列容器。就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。也就是意味着…

【雕爷学编程】MicroPython动手做(02)——尝试搭建K210开发板的IDE环境3

4、下载MaixPy IDE&#xff0c;MaixPy 使用Micropython 脚本语法&#xff0c;所以不像 C语言 一样需要编译&#xff0c;要使用MaixPy IDE , 开发板固件必须是V0.3.1 版本以上&#xff08;这里使用V0.5.0&#xff09;, 否则MaixPy IDE上会连接不上&#xff0c; 使用前尽量检查固…

宝塔设置云服务器mysql端口转发,实现本地电脑访问云mysql

环境&#xff1a;centos系统使用宝塔面板 实现功能&#xff1a;宝塔设置云服务器mysql端口转发&#xff0c;实现本地电脑访问mysql 1.安装mysql、PHP-7.4.33、phpMyAdmin 5.0 软件商店》搜索 mysql安装即可 软件商店》搜索 PHP安装7.4.33即可&#xff08;只需要勾选快速安装&…

iOS开发-实现快速登录弹窗与微信微博QQ三方登录切换控件

iOS开发-实现快速登录弹窗与微信微博QQ三方登录切换控件。 之前开发中实现快速登录弹窗与微信微博等了切换控件。 一、效果图 二、实现代码 实现背景渐变UIBlurEffect self.blurEffect [UIBlurEffect effectWithStyle:UIBlurEffectStyleLight]; self.effectView [[UIVisu…

linux上适用的反汇编调试软件(对标od)

ubuntu下类似于od软件 经过搜索&#xff0c;在Ubuntu上选用edb-debugger进行动态调试&#xff0c; 下载链接: https://github.com/eteran/edb-debugger 但是依赖反汇编引擎: https://github.com/capstone-engine/capstone 安装 先安装capstone 先下载release的版本&#xf…

基于量子同态加密的安全多方凸包协议

摘要安全多方计算几何(SMCG)是安全多方计算的一个分支。该协议是为SMCG中安全的多方凸包计算而设计的。首先&#xff0c;提出了一种基于量子同态加密的安全双方值比较协议。由于量子同态加密的性质&#xff0c;该协议可以很好地保护量子电路执行过程中数据的安全性和各方之间的…

组合模式-树形结构的处理

A公司需要筛选出年龄35岁及以上(如果是领导&#xff0c;年龄为45岁及以上)的人。其组织架构图如下。 图 A公司部分组织架构图 图 传统解决方案 public class Development {private String name;public Development(String name) {this.name name;}List<Employee> emplo…

需求分析案例:消息配置中心

本文介绍了一个很常见的消息推送需求&#xff0c;在系统需要短信、微信、邮件之类的消息推送时&#xff0c;边界如何划分和如何设计技术方案。 1、需求 一个系统&#xff0c;一般会区分多个业务模块&#xff0c;并拆分成不同的业务系统&#xff0c;例如一个商城的架构如下&am…

flutter(01) windows桌面版 编译环境安装指南

1 flutter环境安装 flutter官网参考&#xff1a;Install | Flutter 先下载flutter SDK>&#xff1a;flutter sdk下载--官网&#xff0c;之后解压到C:\Users\XXX\data&#xff08;这里以该路径为例&#xff0c;但可以为其他自定义路径&#xff09;目录下&#xff0c;在这里…

栈和队列模拟实现(C++)

文章目录 0.码云完整代码1.deque的认识1.1介绍1.2图析1.3性能比较 2.stack的学习2.1模拟实现2.2测试函数 3.queue的学习3.1模拟实现3.2测试函数 4.优先级队列的学习4.0仿函数的引入4.1介绍4.2例题4.3模拟实现 5.测试函数 0.码云完整代码 点击 栈 队列 优先级队列 跳转码云获取…

鸿鹄协助管理华为云与炎凰Ichiban

炎凰对华为云的需求 在炎凰日常的开发中&#xff0c;对于服务器上的需求&#xff0c;我们基本都是采用云服务。目前我们主要选择的是华为云&#xff0c;华为云的云主机比较稳定&#xff0c;提供的云主机配置也比较多样&#xff0c;非常适合对于不同场景硬件配置的需求&#xff…

石子合并(区间dp模板)

题目描述&#xff1a; dp分析&#xff1a; 解题代码&#xff1a; #include<iostream> using namespace std;const int N1e36;int f[N][N]; int a[N]; int s[N];int main(){int n;cin>>n;for(int i1;i<n;i){scanf("%d",&s[i]);s[i]s[i-1];//前缀和…

2.1数据结构——线性表

一、定义 线性表是具有相同数据类型的n&#xff08;n>0&#xff09;个数据元素的有限序列&#xff0c;&#xff08;n表示表长&#xff0c;n0为空表&#xff09; 用L表示&#xff1a; 位序&#xff1a;线性表中的“第i个” a1是表头元素&#xff1b;an是表尾元素 除第一个…

《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(8)-Fiddler如何设置捕获会话

1.简介 前边几篇宏哥介绍了Fiddler界面内容以及作用。今天宏哥就讲解和分享如何设置Fiddler后&#xff0c;我们就可以捕获会话&#xff0c;进行抓包了。 2.捕获会话的设备 常见的捕获会话的设备分为PC&#xff08;电脑&#xff09;端和手机&#xff08;Android和IOS苹果&…

【SpringⅢ】Spring 的生命周期

目录 &#x1f96a;1 Bean 的作用域 &#x1f969;1.1 singleton&#xff1a;单例模式 &#x1f359;1.2 prototype&#xff1a;原型模式 &#x1f371;1.3 Bean 的其他作用域 &#x1f35c;2 Spring 生命周期(执行流程) &#x1f958;2.1 启动容器 &#x1f372; 2.2 读…

Elasticsearch:使用 ELSER 释放语义搜索的力量:Elastic Learned Sparse EncoderR

问题陈述 在信息过载的时代&#xff0c;根据上下文含义和用户意图而不是精确的关键字匹配来查找相关搜索结果已成为一项重大挑战。 传统的搜索引擎通常无法理解用户查询的语义上下文&#xff0c;从而导致相关性较低的结果。 解决方案&#xff1a;ELSER Elastic 通过其检索模型…

vue elementui table去掉滚动条与实现表格自动滚动且无滚动条

当table内容列过多时&#xff0c;可通过height属性设置table高度以固定table高度、固定表头&#xff0c;使table内容可以滚动。 现在需求是右侧滚动条不好看&#xff0c;需要去除滚动条&#xff0c;并隐藏滚动条所占列的位置。让他可以滚动但是不出现滚动条,不然即时隐藏了滚动…

Mybatis学习笔记

Mybatis 文章目录 Mybatis搭建环境创建Maven工程将数据库中的表转换为对应的实体类配置文件核心配置文件mybatis-config.xml创建Mapper接口映射文件xxxMapper.xmllog4j日志功能 Mybatis操纵数据库示例及要点说明获取参数的两种方式${}#{} 各种类型的参数处理单个字面量参数多个…