Mediastreamer2 VoIP ఇంజిన్‌ను అన్వేషిస్తోంది. 4 వ భాగము

వ్యాసం యొక్క పదార్థం నా నుండి తీసుకోబడింది జెన్ ఛానల్.

సిగ్నల్ స్థాయి మీటర్‌ను సృష్టిస్తోంది

గతం లో వ్యాసం మీడియా స్ట్రీమర్‌ని ఉపయోగించి ప్రోగ్రామ్‌ల సరైన ముగింపును మేము స్పష్టం చేసాము.

ఈ వ్యాసంలో మేము సిగ్నల్ స్థాయి మీటర్ సర్క్యూట్‌ను సమీకరించి, ఫిల్టర్ నుండి కొలత ఫలితాన్ని ఎలా చదవాలో నేర్చుకుంటాము. కొలత ఖచ్చితత్వాన్ని అంచనా వేద్దాం.

మీడియా స్ట్రీమర్ అందించిన ఫిల్టర్‌ల సెట్‌లో ఫిల్టర్, MS_VOLUME ఉంటుంది, ఇది దాని గుండా వెళుతున్న సిగ్నల్ యొక్క RMS స్థాయిని కొలవగలదు, సిగ్నల్‌ను అటెన్యూట్ చేయగలదు మరియు చాలా ఉపయోగకరమైన మరియు ఊహించని విధులను నిర్వహించగలదు. మేము ఈ ఫిల్టర్‌కు పూర్తి కథనాన్ని తర్వాత కేటాయిస్తాము. అయితే ప్రస్తుతానికి దాన్ని మీటర్‌గా ఉపయోగిస్తాం.

మేము టోన్ జనరేటర్‌ను సిగ్నల్ మూలంగా ఉపయోగిస్తాము, దీని నుండి సిగ్నల్ సౌండ్ కార్డ్ కనెక్ట్ చేయబడిన అవుట్‌పుట్‌కు MS_VOLUME ఫిల్టర్‌కు పంపబడుతుంది.

ఈ ఉదాహరణలో, మేము జెనరేటర్ ఫిల్టర్‌ను కొద్దిగా భిన్నమైన మోడ్‌లో ఉపయోగిస్తాము - ఇది మాకు సింగిల్-టోన్ సిగ్నల్‌ను ఉత్పత్తి చేస్తుంది, అనగా. ఒకే ఒక సైనూసోయిడల్ డోలనం కలిగి ఉన్న సిగ్నల్.

ఫ్రీక్వెన్సీ మరియు వ్యాప్తితో పాటుగా, సిగ్నల్ ఉత్పత్తి చేయబడే సమయాన్ని మేము సెట్ చేయాలి; కొలత కోసం తగిన సంఖ్యలో నమూనాలు MS_VOLUME ఫిల్టర్ గుండా వెళ్లేలా ఇది సరిపోవాలి. జనరేటర్‌కు సెట్టింగ్‌లను బదిలీ చేయడానికి, 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;

జనరేటర్‌ను ప్రారంభించడానికి, మేము దాని MS_DTMF_GEN_PLAY_CUSTOM పద్ధతిని ఉపయోగిస్తాము.

సిగ్నల్ ప్రాసెసింగ్ యొక్క బ్లాక్ రేఖాచిత్రం:

Mediastreamer2 VoIP ఇంజిన్‌ను అన్వేషిస్తోంది. 4 వ భాగము

ఈ పథకాన్ని అమలు చేసే ప్రోగ్రామ్ కోడ్ క్రింద చూపబడింది.

/* Файл 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);
}

మేము మా ఉదాహరణను కంపైల్ చేస్తాము, మనం ఇంతకు ముందు చేసినట్లుగా, ఫైల్ పేరును మాత్రమే ఉపయోగిస్తాము mstest3. దీన్ని అమలు చేసి, ఫలితాన్ని పొందండి:

Амплитуде синуса 1.000000 вольт  соответствует среднеквадратическое значение 0.707733 вольт.

మీరు చూడగలిగినట్లుగా, కొలత ఫలితం సగానికి విభజించబడిన రెండు వర్గమూలానికి సమానమైన సైద్ధాంతిక విలువతో మూడవ దశాంశ స్థానానికి సమానంగా ఉంటుంది: sqr(2)/2=0,7071067811865475

నిజమైన విలువ నుండి ఫలితం యొక్క సాపేక్ష విచలనం 0.1%. మేము గరిష్ట సిగ్నల్ స్థాయిలో కొలత లోపాన్ని అంచనా వేసాము. దీని ప్రకారం, స్థాయి తగ్గుతుంది, లోపం పెరగాలి. తక్కువ సిగ్నల్ స్థాయిల కోసం దీన్ని మీరే అంచనా వేయమని నేను సూచిస్తున్నాను.

తదుపరి కథనంలో టోన్ డిటెక్టర్‌ని ఉపయోగించి ఇన్‌పుట్ వద్ద ఇచ్చిన ఫ్రీక్వెన్సీ యొక్క టోన్ సిగ్నల్ ఉనికిని గుర్తించే సర్క్యూట్‌ను మేము సమీకరించాము. ఫిల్టర్‌ల ద్వారా రూపొందించబడిన ఈవెంట్‌లను ఎలా ప్రాసెస్ చేయాలో కూడా మేము నేర్చుకుంటాము.

మూలం: www.habr.com

ఒక వ్యాఖ్యను జోడించండి