Используйте каналы функционального преобразователя, чтобы сгенерировать синусоидальную форму волны на 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
. Установите тип формы волны на Sine
.
ch_fgen = addoutput(dq, "AD1", "1", "Sine");
Установите усиление канала на 5 (устанавливает амплитуду синусоиды к 5 В). Присвойте усиление переменной.
ch_fgen.Name = "AD1_1_fgen"
gain = 5;
ch_fgen.Gain = gain;
ch_fgen = Index Type Device Channel Measurement Type Range Name _____ ______ ______ _______ ________________ ____________________ ____________ 1 "fgen" "AD1" "1" "Sine" "-5.0 to +5.0 Volts" "AD1_1_fgen"
Установите частоту сигнала на 1 кГц
ch_fgen.Frequency = 1000;
Добавьте канал аналогового входа с 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"
Получите данные в более высокой частоте развертки, чем самая высокая частота в сгенерированной форме волны.
dq.Rate = 100 * ch_fgen.Frequency;
[data, startTime] = read(dq, seconds(1));
period = 1/ch_fgen.Frequency; plot(data.Time, data.AD1_1_in); xlabel('Time in seconds'); ylabel('Voltage in volts'); title(['Period = ', num2str(period), ' seconds']) xlim([seconds(0) seconds(5*period)]); ylim([-gain gain]);