1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Copyright (c) 2017 Paul B Mahol 3cabdff1aSopenharmony_ci * 4cabdff1aSopenharmony_ci * This file is part of FFmpeg. 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 10cabdff1aSopenharmony_ci * 11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14cabdff1aSopenharmony_ci * Lesser General Public License for more details. 15cabdff1aSopenharmony_ci * 16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 19cabdff1aSopenharmony_ci */ 20cabdff1aSopenharmony_ci 21cabdff1aSopenharmony_ci#include <sys/stat.h> 22cabdff1aSopenharmony_ci#include <sys/types.h> 23cabdff1aSopenharmony_ci#include <unistd.h> 24cabdff1aSopenharmony_ci#include <stdio.h> 25cabdff1aSopenharmony_ci#include <mysofa.h> 26cabdff1aSopenharmony_ci 27cabdff1aSopenharmony_ciint main(int argc, char **argv) 28cabdff1aSopenharmony_ci{ 29cabdff1aSopenharmony_ci struct MYSOFA_HRTF *hrtf; 30cabdff1aSopenharmony_ci int sample_rate; 31cabdff1aSopenharmony_ci int err, i, j; 32cabdff1aSopenharmony_ci 33cabdff1aSopenharmony_ci if (argc < 3) { 34cabdff1aSopenharmony_ci printf("usage: %s input_SOFA_file output_directory\n", argv[0]); 35cabdff1aSopenharmony_ci return 1; 36cabdff1aSopenharmony_ci } 37cabdff1aSopenharmony_ci 38cabdff1aSopenharmony_ci hrtf = mysofa_load(argv[1], &err); 39cabdff1aSopenharmony_ci if (!hrtf || err) { 40cabdff1aSopenharmony_ci printf("invalid input SOFA file: %s\n", argv[1]); 41cabdff1aSopenharmony_ci return 1; 42cabdff1aSopenharmony_ci } 43cabdff1aSopenharmony_ci 44cabdff1aSopenharmony_ci if (hrtf->DataSamplingRate.elements != 1) 45cabdff1aSopenharmony_ci goto fail; 46cabdff1aSopenharmony_ci sample_rate = hrtf->DataSamplingRate.values[0]; 47cabdff1aSopenharmony_ci 48cabdff1aSopenharmony_ci err = mkdir(argv[2], 0744); 49cabdff1aSopenharmony_ci if (err) 50cabdff1aSopenharmony_ci goto fail; 51cabdff1aSopenharmony_ci 52cabdff1aSopenharmony_ci err = chdir(argv[2]); 53cabdff1aSopenharmony_ci if (err) 54cabdff1aSopenharmony_ci goto fail; 55cabdff1aSopenharmony_ci 56cabdff1aSopenharmony_ci for (i = 0; i < hrtf->M; i++) { 57cabdff1aSopenharmony_ci FILE *file; 58cabdff1aSopenharmony_ci int bps = 32; 59cabdff1aSopenharmony_ci int blkalign = 8; 60cabdff1aSopenharmony_ci int bytespersec = blkalign * sample_rate; 61cabdff1aSopenharmony_ci char filename[1024]; 62cabdff1aSopenharmony_ci int azi = hrtf->SourcePosition.values[i * 3]; 63cabdff1aSopenharmony_ci int ele = hrtf->SourcePosition.values[i * 3 + 1]; 64cabdff1aSopenharmony_ci int dis = hrtf->SourcePosition.values[i * 3 + 2]; 65cabdff1aSopenharmony_ci int size = 8 * hrtf->N; 66cabdff1aSopenharmony_ci int offset = i * 2 * hrtf->N; 67cabdff1aSopenharmony_ci 68cabdff1aSopenharmony_ci snprintf(filename, sizeof(filename), "azi_%d_ele_%d_dis_%d.wav", azi, ele, dis); 69cabdff1aSopenharmony_ci file = fopen(filename, "w+"); 70cabdff1aSopenharmony_ci fwrite("RIFF", 4, 1, file); 71cabdff1aSopenharmony_ci fwrite("\xFF\xFF\xFF\xFF", 4, 1, file); 72cabdff1aSopenharmony_ci fwrite("WAVE", 4, 1, file); 73cabdff1aSopenharmony_ci fwrite("fmt ", 4, 1, file); 74cabdff1aSopenharmony_ci fwrite("\x10\x00\00\00", 4, 1, file); 75cabdff1aSopenharmony_ci fwrite("\x03\x00", 2, 1, file); 76cabdff1aSopenharmony_ci fwrite("\x02\x00", 2, 1, file); 77cabdff1aSopenharmony_ci fwrite(&sample_rate, 4, 1, file); 78cabdff1aSopenharmony_ci fwrite(&bytespersec, 4, 1, file); 79cabdff1aSopenharmony_ci fwrite(&blkalign, 2, 1, file); 80cabdff1aSopenharmony_ci fwrite(&bps, 2, 1, file); 81cabdff1aSopenharmony_ci fwrite("data", 4, 1, file); 82cabdff1aSopenharmony_ci fwrite(&size, 4, 1, file); 83cabdff1aSopenharmony_ci 84cabdff1aSopenharmony_ci for (j = 0; j < hrtf->N; j++) { 85cabdff1aSopenharmony_ci float l, r; 86cabdff1aSopenharmony_ci 87cabdff1aSopenharmony_ci l = hrtf->DataIR.values[offset + j]; 88cabdff1aSopenharmony_ci r = hrtf->DataIR.values[offset + j + hrtf->N]; 89cabdff1aSopenharmony_ci fwrite(&l, 4, 1, file); 90cabdff1aSopenharmony_ci fwrite(&r, 4, 1, file); 91cabdff1aSopenharmony_ci } 92cabdff1aSopenharmony_ci fclose(file); 93cabdff1aSopenharmony_ci } 94cabdff1aSopenharmony_ci 95cabdff1aSopenharmony_cifail: 96cabdff1aSopenharmony_ci mysofa_free(hrtf); 97cabdff1aSopenharmony_ci 98cabdff1aSopenharmony_ci return 0; 99cabdff1aSopenharmony_ci} 100