FreeCalypso > hg > vband-misc
view amrdiff/readone-amr.c @ 6:b55451463161
amrdiff: recognize DHF transform
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 03 Apr 2024 20:15:37 +0000 |
parents | 75ba83624a29 |
children |
line wrap: on
line source
/* * This program reads a single frame (the first one) from an AMR *.cod file, * enforces that this frame is MR122 speech, and emits the frame of 244 bits * as comma-separated ASCII. The intent is to extract the DHF in a form * convenient for inclusion in amrdiff source. */ #include <stdio.h> #include <stdint.h> #include <stdlib.h> #include <string.h> #include <strings.h> #include "amr_defs.h" main(argc, argv) char **argv; { char *filename; int bigend, rc; FILE *inf; uint8_t amr_bits[COD_FORMAT_NWORDS]; if (argc != 3) { usage: fprintf(stderr, "usage: %s amr-cod-file be|le\n", argv[0]); exit(1); } filename = argv[1]; if (!strcmp(argv[2], "be")) bigend = 1; else if (!strcmp(argv[2], "le")) bigend = 0; else goto usage; inf = fopen(filename, "r"); if (!inf) { perror(filename); exit(1); } rc = read_etsi_bits(inf, bigend, amr_bits, COD_FORMAT_NWORDS, filename); if (!rc) { fprintf(stderr, "error: %s is empty\n", filename); exit(1); } if (amr_bits[0] != TX_SPEECH_GOOD || amr_bits[245] != MR122) { fprintf(stderr, "error: frame type is wrong\n"); exit(1); } emit_frame244(amr_bits + 1); exit(0); }