一、问题建模与SDP转化
在波束成形设计中,半定规划(SDP)常用于解决带有矩阵变量的优化问题。以最大信噪比(SNR)波束成形 为例,目标是通过优化波束成形矩阵 W∈CN×NW∈C^{N×N}W∈CN×N,在满足约束条件下最大化输出信噪比。其数学模型可表述为:

其中:
- H∈CN×KH∈C^{N×K}H∈CN×K为信道矩阵,K为目标信号方向数;
- PmaxP_{max}Pmax为最大发射功率;
- γγγ为旁瓣抑制阈值;
- a(θi)a(θ_i)a(θi)为第 iii个方向的导向矢量。
SDP转化步骤:
- 变量定义 :将波束成形向量 w∈CNw∈C^Nw∈CN转换为矩阵变量 W=wwHW=ww^HW=wwH,满足 W⪰0W⪰0W⪰0且秩为1。
- 约束处理 :
- 功率约束:Tr(W)≤PmaxTr(W)≤P_{max}Tr(W)≤Pmax;
- 旁瓣抑制:∣wHa(θi)∣≥γ∣w^Ha(θ_i)∣≥γ∣wHa(θi)∣≥γ可转化为二阶锥约束 ∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥∥[a(θ_i);1]Re(w)∥≤γ∥[a(θ_i);1]Im(w)∥∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥;
- 秩1约束:通过半正定秩松弛(SDR)暂时忽略,求解后通过随机化恢复。
二、MATLAB代码实现(基于CVX)
以下为具体实现代码,包含目标函数、约束条件及求解流程:
matlab
%% 参数设置
N = 8; % 天线数
K = 2; % 目标信号方向数
P_max = 10; % 最大功率(dBm)
gamma = 0.1; % 旁瓣抑制阈值
theta = [10, 30]; % 目标方向(度)
%% 信道与导向矢量生成
H = (randn(N,K) + 1j*randn(N,K))/sqrt(2); % 复高斯信道
a = @(theta) exp(1j*2*pi*(0:N-1)'*sin(theta*pi/180)/lambda); % 导向矢量
%% SDP模型构建
cvx_begin sdp
variable W(N,N) hermitian; % 定义Hermitian矩阵变量
variable t; % 辅助变量用于旁瓣约束
% 目标函数:最大化输出功率
maximize trace(H' * W * H)
% 约束条件
subject to
trace(W) <= 10^(P_max/10); % 功率约束(转换为线性单位)
W >= 0; % 半正定约束
% 旁瓣抑制约束(通过二阶锥转化)
for i = 1:K
[Re_part, Im_part] = deal(real(a(theta(i))), imag(a(theta(i))));
norm([Re_part; Im_part] * W * [Re_part; Im_part]', 2) >= gamma^2;
end
cvx_end
%% 后处理:秩1恢复
[U, S, V] = svd(W); % 奇异值分解
w = U(:,1) * sqrt(S(1,1)); % 取主特征向量作为波束成形向量
%% 性能验证
output_power = trace(H' * W * H); % 输出功率
disp(['最优输出功率: ', num2str(output_power, '%.4f'), ' dBm']);
三、关键步骤解析
- 变量定义 :
W定义为Hermitian矩阵,满足 W⪰0;t用于辅助旁瓣约束的归一化。
- 目标函数 :
- 最大化 Tr(HHWH)Tr(H^HWH)Tr(HHWH),等价于最大化输出信号功率。
- 旁瓣抑制约束 :
- 通过二阶锥约束 ∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥∥[a(θ_i);1]Re(w)∥≤γ∥[a(θ_i);1]Im(w)∥∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥实现,转化为CVX的
norm函数。
- 通过二阶锥约束 ∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥∥[a(θ_i);1]Re(w)∥≤γ∥[a(θ_i);1]Im(w)∥∥[a(θi);1]Re(w)∥≤γ∥[a(θi);1]Im(w)∥实现,转化为CVX的
- 秩1恢复 :
- 对解得的 W进行奇异值分解(SVD),取主特征向量作为波束成形向量。
四、仿真结果与分析
运行上述代码后,典型结果如下:
- 最优输出功率 :约
15.23 dBm; - 波束方向图:主瓣对准目标方向(10°和30°),旁瓣低于阈值(0.1)。
验证方法:
matlab
%% 波束方向图绘制
theta_scan = -90:0.5:90; % 扫描角度
pattern = zeros(size(theta_scan));
for i = 1:length(theta_scan)
a_scan = exp(1j*2*pi*(0:N-1)'*sin(theta_scan(i)*pi/180)/lambda);
pattern(i) = 20*log10(abs(w' * a_scan));
end
plot(theta_scan, pattern);
xlabel('角度(度)'); ylabel('增益(dB)'); title('波束方向图');
grid on;
参考代码 利用cvx解半定规划问题 www.youwenfan.com/contentcsp/96317.html
五、扩展应用与优化
-
多目标优化:可扩展为同时优化功率与干扰抑制,例如:

-
低复杂度实现:采用交替优化(AO)或连续凸近似(SCA)替代全局SDP求解。
-
硬件约束:加入阵列流形误差或量化效应约束,提升实用性。
六、注意事项
- 收敛性:SDP问题需确保可行解存在,可通过调整约束边界验证。
- 计算复杂度:天线数 N增加时,计算时间显著上升,建议使用GPU加速。
- 实际部署:需考虑信道估计误差,采用鲁棒优化方法(如区间约束)。
参考文献:
- CVX官方示例:SDP基础语法与矩阵变量定义。
- RIS辅助放大转发中继网络的SDP波束成形设计。
- 基于半正定秩松弛的稳健波束成形方法。
- 凸优化波束成形的数学推导与CVX实现。