Matlab menyedian fasilitas pengambilan data audio langsung dari hardware soundcard (internal/external) menggunakan system audio toolbox atau data acquisition toolbox. Namun toolbox tersebut hanya mendukung beberapa jenis soundcard saja.
Jika hardware tidak didukung dan pengambilan data audio realtime bisa dikesampingkan, maka pengambilan data audio melalui mic/line in masih bisa dilakukan dengan fungsi standar yang disediakan matlab.
Dalam proyek ini digunakan fungsi-fungsi utama berikut:
- audiodevinfo, bertugas mengambil informasi perangkat/hardware audio input seperti mic dan line in. Daftar perangkat masukan suara ini ditampilkan dalam pop-up menu sehingga pengguna bisa memilih perangkat yang akan digunakan sebagai masukan audio.
- audiorecorder, merupakan fungsi perekam audio standar matlab yang akan mulai merekam saat diberi perintah start() dan akan berhenti saat diberi perintah stop(). Data suara yang terekam bisa diambil dengan perintah getaudiodata();
- Timer, berfungsi mengatur jeda pengambilan data suara.
Metode ini akan memiliki jeda tergantung pengaturan waktu di timer, agar terlihat lebih realtime, perioda timer dibuat lebih kecil dan dalam mode tetap/fixedSpacing. Selain itu waktu proses lanjutan seperti analisa ampltudo/phase, FFT, Filter dan lain-lain dibuat seefektif mungkin sehingga jeda (kehilangan data audio) bisa diperkecil.
berikut koding fungsi merekam data suara matlab yang digunakan:
function varargout = audioSoundcard(varargin) gui_Singleton = 1; gui_State = struct('gui_Name', mfilename, ... 'gui_Singleton', gui_Singleton, ... 'gui_OpeningFcn', @audioSoundcard_OpeningFcn, ... 'gui_OutputFcn', @audioSoundcard_OutputFcn, ... 'gui_LayoutFcn', [] , ... 'gui_Callback', []); if nargin && ischar(varargin{1}) gui_State.gui_Callback = str2func(varargin{1}); end if nargout [varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:}); else gui_mainfcn(gui_State, varargin{:}); end % --- Executes just before audioSoundcard is made visible. function audioSoundcard_OpeningFcn(hObject, eventdata, handles, varargin) % Choose default command line output for AudioSpectrumAnalyzer handles.output = hObject; % Update handles structure guidata(hObject, handles); % uiwait(handles.figure1); global guiHandle; global recorder; global audioData; global panjangDataRekaman; global frequencySampling; global bitsPerSample; global audioChannel; panjangDataRekaman = 8191; frequencySampling = 22050; bitsPerSample = 16; audioChannel = 1; ylim(handles.axes1, [-0.5, 0.5]); xlim(handles.axes1, [0, panjangDataRekaman]); title(handles.axes1, 'Real time'); xlabel(handles.axes1, 'sampling (bit)') ylabel(handles.axes1, 'Amplitude') hold(handles.axes1,'on'); guiHandle = guidata(hObject); set(handles.checkboxAktif,'value', 0); info = audiodevinfo; nDevices = audiodevinfo(1); str = {}; set(handles.popupmenuDevice,'string',str); for i = 1:nDevices str = [str, char(info.input(i).Name)]; end set(handles.popupmenuDevice,'string',str); set(handles.checkboxAktif,'value',0); deviceID = get(handles.popupmenuDevice,'value') - 1; recorder = audiorecorder(frequencySampling, bitsPerSample, audioChannel, deviceID); audioData = double.empty(); % --- Outputs from this function are returned to the command line. function varargout = audioSoundcard_OutputFcn(hObject, eventdata, handles) varargout{1} = handles.output; % --- Executes on button press in checkboxAktif. function checkboxAktif_Callback(hObject, eventdata, handles) global timerRekam T = timerfind; if isempty(T) disp('timer empty') timerRekam = timerRekaman(); end if get(handles.checkboxAktif,'value') start(timerRekam) else stop(timerRekam) end % --- Executes on selection change in popupmenuDevice. function popupmenuDevice_Callback(hObject, eventdata, handles) global recorder global frequencySampling global bitsPerSample; global audioChannel; deviceID = get(handles.popupmenuDevice,'value') - 1; recorder = audiorecorder(frequencySampling, bitsPerSample, audioChannel, deviceID); % --- Executes during object creation, after setting all properties. function popupmenuDevice_CreateFcn(hObject, eventdata, handles) if ispc && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor')) set(hObject,'BackgroundColor','white'); end % --- Executes during object deletion, before destroying properties. function figure1_DeleteFcn(hObject, eventdata, handles) T = timerfind; if ~isempty(T) stop(T) delete(T) end function t = timerRekaman() t = timer; t.StartDelay = 0; t.TimerFcn = @rekamSuara; t.StopFcn = @selesaiRekamSuara; t.Period = 0.5; t.ExecutionMode = 'fixedSpacing'; function rekamSuara(mTimer,~) global recorder global audioData; global plotData; global panjangDataRekaman; if recorder.isrecording stop(recorder); delete(plotData); audioData = [audioData; getaudiodata(recorder)]; if length(audioData) > panjangDataRekaman audioData = audioData(length(audioData)-panjangDataRekaman:length(audioData)); end tampilGrafik; end disp('AmbilSuara...') recorder.record; function selesaiRekamSuara(mTimer,~) disp('Selesai.') function tampilGrafik() global guiHandle; global audioData; global plotData; global panjangDataRekaman; if ~isempty(audioData) plotData = plot(audioData, 'b', 'Parent', guiHandle.axes1); end
Contah capture audio matlab menggunakan fungsi standar pembacaan soundcard:
file pendukung pengambilan data suara dengan matlab: