cannam@125: /* cannam@125: ** Copyright (C) 2008-2015 Erik de Castro Lopo cannam@125: ** cannam@125: ** This program is free software; you can redistribute it and/or modify cannam@125: ** it under the terms of the GNU General Public License as published by cannam@125: ** the Free Software Foundation; either version 2 of the License, or cannam@125: ** (at your option) any later version. cannam@125: ** cannam@125: ** This program is distributed in the hope that it will be useful, cannam@125: ** but WITHOUT ANY WARRANTY; without even the implied warranty of cannam@125: ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the cannam@125: ** GNU General Public License for more details. cannam@125: ** cannam@125: ** You should have received a copy of the GNU General Public License cannam@125: ** along with this program; if not, write to the Free Software cannam@125: ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. cannam@125: */ cannam@125: cannam@125: #include "sfconfig.h" cannam@125: cannam@125: #include cannam@125: #include cannam@125: #include cannam@125: #include cannam@125: cannam@125: #include cannam@125: cannam@125: #include "utils.h" cannam@125: cannam@125: #define SAMPLE_RATE 8000 cannam@125: cannam@125: typedef struct cannam@125: { int enc_fmt ; cannam@125: cannam@125: const char * enc_name ; cannam@125: const char * dec_name ; cannam@125: cannam@125: uint64_t enc_cksum ; cannam@125: uint64_t dec_cksum ; cannam@125: } CHECKSUM ; cannam@125: cannam@125: static CHECKSUM cannam@125: checksum_orig [] = cannam@125: { cannam@125: { SF_FORMAT_RAW | SF_FORMAT_ULAW, cannam@125: "checksum.ulaw", "cksum_ulaw.pcm16", cannam@125: 0xbd99d34ccbe2fLL, 0xda82168ed82e9LL cannam@125: }, cannam@125: { SF_FORMAT_RAW | SF_FORMAT_ALAW, cannam@125: "checksum.alaw", "cksum_alaw.pcm16", cannam@125: 0x0004afddc0fcf4bdLL, 0x2e7320230b88LL cannam@125: }, cannam@125: { SF_FORMAT_RAW | SF_FORMAT_GSM610, cannam@125: "checksum.gsm", "cksum_gsm.pcm16", cannam@125: 0xa06a3faaaf684LL, 0x2d7ff668efeb9LL cannam@125: }, cannam@125: { SF_FORMAT_RAW | SF_FORMAT_VOX_ADPCM, cannam@125: "checksum.vox", "cksum_vox.pcm16", cannam@125: 0x7c9d7afdb96a1LL, 0xe540df74a4b14LL cannam@125: }, cannam@125: } ; cannam@125: cannam@125: static void checksum_test (const CHECKSUM * cksum) ; cannam@125: cannam@125: static float orig [1 << 14] ; cannam@125: static short data [1 << 14] ; cannam@125: cannam@125: int cannam@125: main (void) cannam@125: { unsigned k ; cannam@125: cannam@125: gen_windowed_sine_float (orig, ARRAY_LEN (orig), 0.9) ; cannam@125: cannam@125: for (k = 0 ; k < ARRAY_LEN (checksum_orig) ; k++) cannam@125: checksum_test (&checksum_orig [k]) ; cannam@125: cannam@125: return 0 ; cannam@125: } /* main */ cannam@125: cannam@125: /*============================================================================== cannam@125: */ cannam@125: cannam@125: static void cannam@125: checksum_test (const CHECKSUM * cksum) cannam@125: { SNDFILE * file ; cannam@125: SF_INFO info ; cannam@125: cannam@125: print_test_name (__func__, cksum->enc_name) ; cannam@125: cannam@125: info.format = cksum->enc_fmt ; cannam@125: info.channels = 1 ; cannam@125: info.samplerate = SAMPLE_RATE ; cannam@125: cannam@125: file = test_open_file_or_die (cksum->enc_name, SFM_WRITE, &info, 0, __LINE__) ; cannam@125: test_write_float_or_die (file, 0, orig, ARRAY_LEN (orig), __LINE__) ; cannam@125: sf_close (file) ; cannam@125: cannam@125: check_file_hash_or_die (cksum->enc_name, cksum->enc_cksum, __LINE__) ; cannam@125: puts ("ok") ; cannam@125: cannam@125: /*------------------------------------------------------------------------*/ cannam@125: cannam@125: print_test_name (__func__, cksum->dec_name) ; cannam@125: cannam@125: info.format = cksum->enc_fmt ; cannam@125: info.channels = 1 ; cannam@125: info.samplerate = SAMPLE_RATE ; cannam@125: cannam@125: file = test_open_file_or_die (cksum->enc_name, SFM_READ, &info, 0, __LINE__) ; cannam@125: test_read_short_or_die (file, 0, data, ARRAY_LEN (data), __LINE__) ; cannam@125: sf_close (file) ; cannam@125: cannam@125: info.format = SF_ENDIAN_LITTLE | SF_FORMAT_RAW | SF_FORMAT_PCM_16 ; cannam@125: info.channels = 1 ; cannam@125: info.samplerate = SAMPLE_RATE ; cannam@125: cannam@125: file = test_open_file_or_die (cksum->dec_name, SFM_WRITE, &info, 0, __LINE__) ; cannam@125: test_write_short_or_die (file, 0, data, ARRAY_LEN (data), __LINE__) ; cannam@125: sf_close (file) ; cannam@125: cannam@125: check_file_hash_or_die (cksum->dec_name, cksum->dec_cksum, __LINE__) ; cannam@125: cannam@125: remove (cksum->enc_name) ; cannam@125: remove (cksum->dec_name) ; cannam@125: cannam@125: puts ("ok") ; cannam@125: } /* checksum_test */ cannam@125: