由带宽和相位裕量自动设计PI值 matlab代码

该博客分享了一段MATLAB代码,用于根据给定的带宽和相位裕量自动设计PI控制器。通过输入期望的带宽和相位裕量,代码计算出相应的KP和KI值,并绘制了Bode图。虽然没有详细的注释,但博主邀请有兴趣的人在评论区进行讨论和交流。
摘要由CSDN通过智能技术生成

设定 带宽和 相位裕量 自动设计PI值

输入被控对象传递函数、带宽、相位裕量

输出kp ki 和 bode图

还没有详细写注释感兴趣可以评论下

clear;clc;close all;
format long
%输入
my_w=2000;%输入预期带宽度
my_phasemargin=60;%输入预期的相位裕量
%sysOL=tf(num,den); %输入系统开环传递函数

%%Kpwm
E=30;
Vtri=1;
Kpwm=E/Vtri;
num=[Kpwm];
den=[1];
sysPWM=tf(num,den)

%%LCR
hold on;
L=1e-3;
C=20e-6;
R=10;
num=[1];
den=[L*C L/R 1];
sysLCR=tf(num,den)
%%PI
hold on;
% syms Kp Ki;
Kp= 0.071942446944953;    %计算完成后把结果填到这里即可看到bode
Ki=-5.197455364855435e+02;
num=[Kp Ki];
den=[1 0];
sysPI=tf(num,den)
%margin(sysPI)


%%OL&CL
sysOL=series(sysLCR,sysPI)
sysOL=series(sysOL,sysPWM)
bode(sysPI)
margin(sysOL)
legend('sysPI','sysOL');

### 回答1: GMSK波形是高斯最小频移键控的波形,它被广泛应用于电信技术和数字通信领域。其主要特点是幅恒定,频偏大小无限制,具有连续相位属性,在频谱中呈现出类似于高斯带通滤波器的特性。GMSK波形可以通过高斯卷积方法和相位正交键控方法进行构造。在数字通信中,GMSK波形特别适合扩频通信和调制解调。 Matlab代码实现GMSK波形主要包括以下几个步骤: 1. 设置GMSK波形参数,例如载波频率、抽样频率、符号率等参数。 2. 生成包络函数,使用高斯卷积方法计包络函数,并将其归一化。 3. 生成相位函数,使用相位正交键控方法计相位函数,并用包络函数进行调制。 4. 生成GMSK波形,将包络函数和相位函数相乘并进行调制,最终得到GMSK波形信号。 以下是一个简单的Matlab代码实现GMSK波形的示例: % 设置GMSK波形参数 fc = 600; % 载波频率 fs = 8000; % 抽样频率 Tb = 1/100; % 符号率 Ts = 1/fs; % 抽样周期 N = 10000; % 采样点数 % 生成包络函数 t = [0:Ts:(N-1)*Ts]; b = gausspuls(t,Tb); % 生成相位函数 phi = zeros(1,N); for n = 2:N phi(n) = phi(n-1) - pi*Tb*mod(b(n-1)+b(n),2)/Ts; end % 生成GMSK波形 s = b.*cos(2*pi*fc*t+phi); % 绘制波形 figure(1); subplot(211); plot(t,b); title('包络函数'); subplot(212); plot(t,s); title('GMSK波形'); xlabel('时间(秒)'); ylabel('幅度'); 通过以上代码,可以生成一个具有高斯包络和连续相位的GMSK波形,并进行可视化展示。 ### 回答2: GMSK是一种调制方式,是连续相位调制(CPM)的一种形式。GMSK波形是一个具有含有限带宽的高斯滤波特性的信号,主要用于数字通信系统中的语音和数据传输。 GMSK波形的特点是:调制复杂度低,误码率低,带宽效率高,对频谱利用率不错。 为了实现GMSK波形的生成,我们可以使用Matlab编程实现。Matlab是一个功能强大的数学软件,可以用它进行信号处理、波形分析、频谱分析等等。 我们可以在Matlab中使用firpm函数设计一个低通高斯滤波器,用于对于数据进行预处理。然后使用practical_gmsk_modulation函数实现GMSK调制。最后,使用Matlab中的plot函数将GMSK波形进行可视化。 以下是可能的Matlab代码实现: %设计低通高斯滤波器 fs=9600; N=20; fc=2000; [b,a]=firpm(N,[0 fc],[ 1 1],'lowpass'); freqz(b,a,512); %创建输入数据信息 s = randi([0,1],1,100); %高斯平滑过滤 so = upsample(s,2); si = filter(b,a,so); sd = diff([0 si] ); %GMSK调制 mod_obj = gmskmod('InputType','Bit','SamplesPerSymbol',2,'RolloffFactor',0.35); gmsk_signal = mod_obj(sd '); %绘制GMSK波形 figure; plot(real(gmsk_signal )); grid on; title('GMSK调制后的波形'); xlabel('样本数'); ylabel('幅'); 以上就是一个可能的Matlab代码实现,可以通过修改参数和数据进行调整,以满足各种需求。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值