/* ==================================================================== * Copyright (c) 1999-2001 Carnegie Mellon University. All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * This work was supported in part by funding from the Defense Advanced * Research Projects Agency and the National Science Foundation of the * United States of America, and the CMU Sphinx Speech Consortium. * * THIS SOFTWARE IS PROVIDED BY CARNEGIE MELLON UNIVERSITY ``AS IS'' AND * ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY * NOR ITS EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * ==================================================================== * */ /* 30 May 1989 David R. Fulmer (drf) updated to do byte order conversions when necessary. */ #include #include #if (! WIN32) #include #include #include #else #include #endif #include "byteorder.h" int f2read (char *file, float **data1_ref, float **data2_ref, int *length_ref) { int fd; int length; int size; int offset; char *data1, *data2; if ((fd = open (file, O_RDONLY, 0644)) < 0) { fprintf (stderr, "f2read: %s: can't open\n", file); return -1; } if (read (fd, (char *) &length, 4) != 4) { fprintf (stderr, "f2read: %s: can't read length (empty file?)\n", file); return (-1); } SWAPL(&length); size = length * sizeof (float); if (!(data1 = malloc ((unsigned) size))) { fprintf (stderr, "f2read: %s: can't alloc data1\n", file); close (fd); return -1; } if (read (fd, data1, size) != size) { fprintf (stderr, "f2read: %s: can't read data1\n", file); close (fd); free (data1); return -1; } if (!(data2 = malloc ((unsigned) size))) { fprintf (stderr, "f2read: %s: can't alloc data2\n", file); close (fd); free (data1); return -1; } if (read (fd, data2, size) != size) { fprintf (stderr, "f2read: %s: can't read data2\n", file); close (fd); free (data1); free (data2); return -1; } close (fd); *data1_ref = (float *) data1; *data2_ref = (float *) data2; for(offset = 0; offset < length; offset++) { SWAPF(*data1_ref + offset); SWAPF(*data2_ref + offset); } *length_ref = length; return length; }