Используйте каналы функционального преобразователя, чтобы сгенерировать произвольную функцию формы волны на 1 кГц и данные записи одновременно, с помощью канала аналогового входа.
Узнайте устройства Digilent, соединенные к вашей системе с помощью daqlist.
daqlist("digilent") dq = daq("digilent")
ans =
1×4 table
DeviceID Description Model DeviceInfo
________ _____________________________________________ ____________________ _______________________
"AD1" "Digilent Inc. Analog Discovery 2 Kit Rev. C" "Analog Discovery 2" [1×1 daq.di.DeviceInfo]
dq =
DataAcquisition using Digilent Inc. hardware:
Running: 0
Rate: 10000
NumScansAvailable: 0
NumScansAcquired: 0
NumScansQueued: 0
NumScansOutputByHardware: 0
RateLimit: []
Show channels
Show properties and methods
Добавьте канал функционального преобразователя с ID устройства AD1 и ID канала 1. Установите тип формы волны на Arbitrary. Область значений напряжения выходного сигнала-5.0 к +5.0 вольтам.
ch_fgen = addoutput(dq, "AD1", "1", "Arbitrary"); ch_fgen.Name = "AD1_1_fgen"
ch_fgen =
Index Type Device Channel Measurement Type Range Name
_____ ______ ______ _______ ________________ ____________________ ____________
1 "fgen" "AD1" "1" "Arbitrary" "-5.0 to +5.0 Volts" "AD1_1_fgen"
Функциональный преобразователь производит периодические выходные параметры путем повторной генерации содержимого его буфера (4 096 точек). Форма волны создается, чтобы заполнить этот буфер без повторения.
buffersize = 4096; len = buffersize + 1; f0 = 1; f1 = 1 * f0; f2 = 2 * f0; f3 = 3 * f0; waveform = sin(linspace(0, 2*pi*f1, len)) + ... sin(linspace(0, 2*pi*f2, len)) + ... sin(linspace(0, 2*pi*f3, len)); waveform(end) = [];
frequency = 1000; ch_fgen.WaveformData = waveform; ch_fgen.Frequency = frequency;
Добавьте канал аналогового входа с ID устройства AD1 и ID канала 1. Установите тип измерения на Voltage.
ch_in = addinput(dq, "AD1", "1", "Voltage"); ch_in.Name = "AD1_1_in"
ch_in =
Index Type Device Channel Measurement Type Range Name
_____ ____ ______ _______ ________________ __________________ __________
1 "ai" "AD1" "1" "Voltage (Diff)" "-25 to +25 Volts" "AD1_1_in"
Получите данные в более высокой частоте развертки, чем самая высокая частота в сгенерированной форме волны (сверхдискретизация).
oversamplingratio = 50; Fn = 2 * frequency; Fs = oversamplingratio * Fn; dq.Rate = Fs;
data = read(dq, seconds(3));
k = 5; width = 750; height = 750; period = 1/frequency; numperiods = k * period; maxamplitude = 3*ch_fgen.Gain; wavedesired = repmat(waveform', k, 1); tsamples = linspace(0, numperiods, k * buffersize)';
L = 2 * oversamplingratio * buffersize; NFFT = 2^nextpow2(L); Y = fft(data.AD1_1_in, NFFT)/L; f0 = (Fs/2) * linspace(0, 1, NFFT/2 + 1);
plotScaleFactor = 12; plotRange = NFFT/2; % Plot is symmetric about NFFT plotRange = floor(plotRange / plotScaleFactor); Yplot = Y(1:plotRange); fplot = f0(1:plotRange); fig = figure; % Plot Desired Waveform subplot(311) plot(tsamples, wavedesired); xlabel('Time (seconds)'); ylabel('Voltage (Volts)'); title('Desired Waveform: sin(2\pi*1000t) + sin(2\pi*2000t) + sin(2\pi*3000t)'); xlim([0 numperiods]); ylim([-maxamplitude maxamplitude]); % Plot Acquired Waveform subplot(312) plot(data.Time, data.AD1_1_in); xlabel('Time (seconds)'); ylabel('Voltage (Volts)'); title('Acquired Waveform'); xlim([seconds(0) seconds(numperiods)]); ylim([-maxamplitude maxamplitude]); % Plot Single-Sided Amplitude Spectrum subplot(313) stem(fplot, 2*abs(Yplot)); title('Single-Sided Amplitude Spectrum of Waveform') xlabel('Frequency (Hz)') ylabel('|Y(f)|') axis tight % Make Graph Larger outpos = get(fig, 'OuterPosition'); set(fig, 'OuterPosition', [outpos(1)-125 outpos(2)-375 width height]);
