สำรวจเครื่องมือ Mediastreamer2 VoIP ส่วนที่ 4

เนื้อหาของบทความนำมาจากของฉัน ช่องเซน.

การสร้างเครื่องวัดระดับสัญญาณ

ในที่สุด статье เราได้ชี้แจงการยกเลิกโปรแกรมที่ใช้สตรีมมีเดียอย่างถูกต้องแล้ว

ในบทความนี้ เราจะประกอบวงจรมิเตอร์วัดระดับสัญญาณและเรียนรู้วิธีอ่านผลการวัดจากตัวกรอง มาประเมินความแม่นยำในการวัดกัน

ชุดตัวกรองที่ Media Streamer มอบให้ประกอบด้วยตัวกรอง 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% เราประเมินข้อผิดพลาดในการวัดที่ระดับสัญญาณสูงสุด ดังนั้นเมื่อระดับลดลง ข้อผิดพลาดก็ควรเพิ่มขึ้น ฉันขอแนะนำให้คุณประเมินระดับสัญญาณต่ำด้วยตนเอง

ในบทความถัดไป เราจะรวบรวมวงจรที่ตรวจจับการมีอยู่ของสัญญาณเสียงของความถี่ที่กำหนดที่อินพุตโดยใช้เครื่องตรวจจับโทนเสียง นอกจากนี้เรายังจะได้เรียนรู้วิธีการประมวลผลเหตุการณ์ที่สร้างโดยตัวกรอง

ที่มา: will.com

เพิ่มความคิดเห็น