FreeCalypso > hg > vband-misc
view ringing/genring.c @ 26:1794bf0fbcf7
pcmu2efr: emit full PCMU input
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 12 May 2024 04:48:36 +0000 |
parents | b875c8edd54f |
children |
line wrap: on
line source
/* * This program computes the waveform for the North American precise tone plan * ringing signal, specifically the 2 s long ON phase, and writes it into a * "robe" PCM16 file. */ #include <math.h> #include <stdio.h> #include <stdint.h> #include <stdlib.h> #define FREQ_LOW (M_PI * 440.0 / 4000.0) #define FREQ_HIGH (M_PI * 480.0 / 4000.0) #define AMPL_PEAK 2552.329f /* -19 dBm0 */ #define TOTAL_SAMPLES 16000 main(argc, argv) char **argv; { FILE *outf; float angle_low, angle_high; unsigned nsamp; int sample; unsigned sample_out; if (argc != 2) { fprintf(stderr, "usage: %s outfile\n", argv[0]); exit(1); } outf = fopen(argv[1], "w"); if (!outf) { perror(argv[1]); exit(1); } angle_low = 0; angle_high = 0; for (nsamp = 0; nsamp < TOTAL_SAMPLES; nsamp++) { sample = (sinf(angle_low) + sinf(angle_high)) * AMPL_PEAK; sample_out = sample & 0xFFFF; putc(sample_out >> 8, outf); putc(sample_out & 0xFF, outf); angle_low += FREQ_LOW; angle_high += FREQ_HIGH; } exit(0); }