В этом примере показано, как получить и отобразить данные о звуковом давлении из микрофона PCB® IEPE массивов, Модели 130E20. Датчик записывает звуковое давление, сгенерированное камертоном в середину C частота (на 261,626 Гц).
Чтобы обнаружить устройство, которое поддерживает измерения микрофона, получите доступ к устройству в таблице, возвращенной daqlist
команда. В данном примере микрофон соединяется на канале 0 из устройства NI 9234 National Instruments® на шасси NI cDAQ-9178 CompactDAQ с ID cDAQ1Mod3
.
d = daqlist("ni")
d = 12×4 table DeviceID Description Model DeviceInfo ___________ __________________________________ _____________ ____________________ "cDAQ1Mod1" "National Instruments NI 9205" "NI 9205" [1×1 daq.DeviceInfo] "cDAQ1Mod2" "National Instruments NI 9263" "NI 9263" [1×1 daq.DeviceInfo] "cDAQ1Mod3" "National Instruments NI 9234" "NI 9234" [1×1 daq.DeviceInfo] "cDAQ1Mod4" "National Instruments NI 9201" "NI 9201" [1×1 daq.DeviceInfo] "cDAQ1Mod5" "National Instruments NI 9402" "NI 9402" [1×1 daq.DeviceInfo] "cDAQ1Mod6" "National Instruments NI 9213" "NI 9213" [1×1 daq.DeviceInfo] "cDAQ1Mod7" "National Instruments NI 9219" "NI 9219" [1×1 daq.DeviceInfo] "cDAQ1Mod8" "National Instruments NI 9265" "NI 9265" [1×1 daq.DeviceInfo] "Dev1" "National Instruments PCIe-6363" "PCIe-6363" [1×1 daq.DeviceInfo] "Dev2" "National Instruments NI ELVIS II" "NI ELVIS II" [1×1 daq.DeviceInfo] "Dev3" "National Instruments PCIe-6363" "PCIe-6363" [1×1 daq.DeviceInfo] "Dev4" "National Instruments PCIe-6363" "PCIe-6363" [1×1 daq.DeviceInfo]
deviceInfo = d{3, "DeviceInfo"}
deviceInfo = ni: National Instruments NI 9234 (Device ID: 'cDAQ1Mod3') Analog input supports: -5.0 to +5.0 Volts range Rates from 1000.0 to 51200.0 scans/sec 4 channels ('ai0','ai1','ai2','ai3') 'Voltage','Accelerometer','Microphone','IEPE' measurement types This module is in slot 3 of the 'cDAQ-9178' chassis with the name 'cDAQ1'.
Создайте DataAcquisition и добавьте канал с Microphone
тип измерения.
dq = daq("ni"); ch = addinput(dq, "cDAQ1Mod3", "ai0", "Microphone");
Установите канал микрофона Sensitivity
свойство к значению задано в таблице данных датчика. Для этого датчика, Sensitivity
значение составляет 0,037 вольт/Паскаль. Исследуйте свойства канала видеть изменения в конфигурации устройства.
ch.Sensitivity = 0.037; ch
ch = Index Type Device Channel Measurement Type Range Name _____ ____ ___________ _______ ___________________ ______________________ _______________ 1 "ai" "cDAQ1Mod3" "ai0" "Microphone (Diff)" "-200 to +200 Pascals" "cDAQ1Mod3_ai0"
Установите частоту развертки захвата на 51 200 сканов в секунду, затем используйте read
получать четыре секунды данных.
dq.Rate = 51200; tt = read(dq, seconds(4)); t = tt.Time; data = tt.cDAQ1Mod3_ai0;
Используйте audioplayer
воспроизвести полученный сигнал микрофона
p = audioplayer(data, dq.Rate); play(p);
Исследуйте данные во временном интервале
plot(t, data);
ylabel('Sound Pressure (pascals)');
Исследуйте данные в частотном диапазоне
Используйте fft
и следующие параметры, чтобы вычислить односторонний амплитудный спектр входящих данных:
Вычислите длину сигнала (количество отсчетов или записи в таблице)
Вычислите nfft
Вычислите амплитуду и частоту
len = height(tt); nfft = 2^nextpow2(len); y = fft(data,nfft)/len; f = dq.Rate/2*linspace(0,1,nfft/2+1); A = 2*abs(y(1:nfft/2+1));
Постройте односторонний амплитудный спектр
plot(f,A); xlim([0 1000]); xlabel('Frequency (Hz)'); ylabel('Amplitude');
График показывает скачок на уровне 261,626 Гц. Это совпадает с частотой камертона.