⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dsb1.m

📁 contemporarycommunicatonsystem-using MATLAB经典书目源程序!
💻 M
字号:
% dsb1.m% Matlab demonstration script for DSB-AM modulation. The message signal% is +1 for 0 < t < t0/3, -2 for t0/3 < t < 2t0/3 and zero otherwise.echo ont0=.15;                             	% signal durationts=0.001;                            	% sampling intervalfc=250;                              	% carrier frequencysnr=20;                              	% SNR in dB (logarithmic)fs=1/ts;                             	% sampling frequencydf=0.3;                              	% desired freq. resolutiont=[0:ts:t0];                         	% time vectorsnr_lin=10^(snr/10);                 	% linear SNR% message signalm=[ones(1,t0/(3*ts)),-2*ones(1,t0/(3*ts)),zeros(1,t0/(3*ts)+1)];c=cos(2*pi*fc.*t);                   	% carrier signalu=m.*c;                              	% modulated signal[M,m,df1]=fftseq(m,ts,df);           	% Fourier transform M=M/fs;                              	% scaling                   [U,u,df1]=fftseq(u,ts,df);           	% Fourier transform U=U/fs;                              	% scaling[C,c,df1]=fftseq(c,ts,df);           	% Fourier transformf=[0:df1:df1*(length(m)-1)]-fs/2;    	% freq. vectorsignal_power=spower(u(1:length(t)));   	% power in modulated signalnoise_power=signal_power/snr_lin;    	% compute noise powernoise_std=sqrt(noise_power);         	% compute noise standard deviationnoise=noise_std*randn(1,length(u));  	% generate noiser=u+noise;                           	% add noise to the modulated signal[R,r,df1]=fftseq(r,ts,df);           	% spectrum of the signal+noise R=R/fs;                              	% scalingpause  % Press a key to show the modulated signal powersignal_powerpause  % Press any key to see a plot of the messageclfsubplot(2,2,1)plot(t,m(1:length(t)))xlabel('Time')title('The message signal')pause  % Press any key to see a plot of the carriersubplot(2,2,2)plot(t,c(1:length(t)))xlabel('Time')title('The carrier')pause  % Press any key to see a plot of the modulated signalsubplot(2,2,3)plot(t,u(1:length(t)))xlabel('Time')title('The modulated signal')pause   % Press any key to see a plots of the magnitude of the message and the	% modulated signal in the frequency domain.subplot(2,1,1)plot(f,abs(fftshift(M)))xlabel('Frequency')title('Spectrum of the message signal')subplot(2,1,2)plot(f,abs(fftshift(U)))title('Spectrum of the modulated signal')xlabel('Frequency')pause  % Press a key to see a noise samplesubplot(2,1,1)plot(t,noise(1:length(t)))title('noise sample') xlabel('Time')pause  % Press a key to see the modulated signal and noise subplot(2,1,2)plot(t,r(1:length(t)))title('Signal and noise')xlabel('Time')pause  % Press a key to see the modulated signal and noise in freq. domainsubplot(2,1,1)plot(f,abs(fftshift(U)))title('Signal spectrum')xlabel('Frequency')subplot(2,1,2)plot(f,abs(fftshift(R))) title('Signal and noise spectrum')xlabel('Frequency')

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -