Il-materjal tal-artiklu huwa meħud minn tiegħi
Ħolqien ta' miter tal-livell tas-sinjal
Fl-aħħar
F'dan l-artikolu se niġbru ċirkwit tal-miter tal-livell tas-sinjal u nitgħallmu kif naqraw ir-riżultat tal-kejl mill-filtru. Ejja nevalwaw l-eżattezza tal-kejl.
Is-sett ta 'filtri pprovduti mill-media streamer jinkludi filtru, MS_VOLUME, li huwa kapaċi jkejjel il-livell RMS tas-sinjal li jgħaddi minnu, jattenwa s-sinjal u jwettaq ħafna funzjonijiet utli u mhux mistennija. Aħna ser niddedikaw artiklu sħiħ għal dan il-filtru aktar tard. Imma għalissa se nużawha bħala metru.
Aħna se nużaw ġeneratur tat-ton bħala sors tas-sinjal, li s-sinjal minnu jintbagħat lill-filtru MS_VOLUME, li l-output tiegħu hija konnessa l-karta tal-ħoss.
F'dan l-eżempju, se nużaw il-filtru tal-ġeneratur f'mod kemmxejn differenti - se jiġġenera sinjal b'ton wieħed għalina, i.e. sinjal li fih oxxillazzjoni sinusojdali waħda biss.
Minbarra l-frekwenza u l-amplitudni, ikollna bżonn nissettjaw il-ħin li matulu se jiġi ġġenerat is-sinjal; għandu jkun biżżejjed sabiex numru suffiċjenti ta 'kampjuni jgħaddu mill-filtru MS_VOLUME għall-kejl. Biex tittrasferixxi s-settings lill-ġeneratur, tintuża l-istruttura MSDtmfGenCustomTone:
struct _MSDtmfGenCustomTone{
char tone_name[8]; /* Текстовое название сигнала из 8 букв.*/
int duration; /* Длительность сигнала в миллисекундах.*/
int frequencies[2]; /* Пара частот из которых должен состоять выходной сигнал. */
float amplitude; /* Амплитуда тонов, 1.0 соответствует уровню 0 дБ от милливатта на нагрузке 600 Ом.*/
int interval; /* Пауза в миллисекундах перед началом повторного проигрывания сигнала.*/
int repeat_count; /* Количество повторов.*/
};
typedef struct _MSDtmfGenCustomTone MSDtmfGenCustomTone;
Biex tibda l-ġeneratur, se nużaw il-metodu MS_DTMF_GEN_PLAY_CUSTOM tiegħu.
Dijagramma blokk tal-ipproċessar tas-sinjali:
Il-kodiċi tal-programm li jimplimenta din l-iskema jidher hawn taħt.
/* Файл mstest3.c */
#include <mediastreamer2/msfilter.h>
#include <mediastreamer2/msticker.h>
#include <mediastreamer2/dtmfgen.h>
#include <mediastreamer2/mssndcard.h>
#include <mediastreamer2/msvolume.h>
int main()
{
ms_init();
/* Создаем экземпляры фильтров. */
MSFilter *voidsource=ms_filter_new(MS_VOID_SOURCE_ID);
MSFilter *dtmfgen=ms_filter_new(MS_DTMF_GEN_ID);
MSFilter *volume=ms_filter_new(MS_VOLUME_ID);
MSSndCard *card_playback=ms_snd_card_manager_get_default_card(ms_snd_card_manager_get());
MSFilter *snd_card_write=ms_snd_card_create_writer(card_playback);
/* Создаем тикер. */
MSTicker *ticker=ms_ticker_new();
/* Соединяем фильтры в цепочку. */
ms_filter_link(voidsource, 0, dtmfgen, 0);
ms_filter_link(dtmfgen, 0, volume, 0);
ms_filter_link(volume, 0, snd_card_write, 0);
/* Подключаем источник тактов. */
ms_ticker_attach(ticker,voidsource);
MSDtmfGenCustomTone dtmf_cfg;
/* Устанавливаем имя нашего сигнала, помня о том, что в массиве мы должны
оставить место для нуля, который обозначает конец строки. */
strncpy(dtmf_cfg.tone_name, "busy", sizeof(dtmf_cfg.tone_name));
dtmf_cfg.duration=1000;
dtmf_cfg.frequencies[0]=440; /* Будем генерировать один тон, частоту второго тона установим в 0.*/
dtmf_cfg.frequencies[1]=0;
dtmf_cfg.amplitude=1.0; /* Такой амплитуде синуса должен соответствовать результат измерения 0.707.*/
dtmf_cfg.interval=0.;
dtmf_cfg.repeat_count=0.;
/* Включаем звуковой генератор. */
ms_filter_call_method(dtmfgen, MS_DTMF_GEN_PLAY_CUSTOM, (void*)&dtmf_cfg);
/* Даем, время половину секунды, чтобы измеритель накопил данные. */
ms_usleep(500000);
/* Читаем результат измерения. */
float level=0;
ms_filter_call_method(volume, MS_VOLUME_GET_LINEAR,&level);
printf("Амплитуде синуса %f вольт соответствует среднеквадратическое значение %f вольт.n", dtmf_cfg.amplitude, level);
}
Aħna niġbru l-eżempju tagħna, bħalma għamilna qabel, billi nużaw biss l-isem tal-fajl mstest3. Ejja nħaddmu u nikseb ir-riżultat:
Амплитуде синуса 1.000000 вольт соответствует среднеквадратическое значение 0.707733 вольт.
Kif tistgħu taraw, ir-riżultat tal-kejl ikkoinċida mat-tielet post deċimali mal-valur teoretiku ugwali għall-għerq kwadru ta 'tnejn diviż bin-nofs: sqr(2)/2=0,7071067811865475
Id-devjazzjoni relattiva tar-riżultat mill-valur veru kienet 0.1%. Aħna vvalutajna l-iżball tal-kejl fil-livell massimu tas-sinjal. Għaldaqstant, hekk kif il-livell jonqos, l-iżball għandu jiżdied. Nissuġġerixxi li tevalwa lilek innifsek għal livelli ta 'sinjal baxx.
Fl-artiklu li jmiss se niġbru ċirkwit li jiskopri l-preżenza ta 'sinjal tat-ton ta' frekwenza partikolari fl-input bl-użu ta 'ditekter tat-ton. Se nitgħallmu wkoll kif nipproċessaw avvenimenti ġġenerati minn filtri.
Sors: www.habr.com