X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=wdq2wav.h;h=fceee293df2b9819095020e7dad1be57d33971c5;hb=refs%2Ftags%2Fv1.0.0;hp=6d37b206fd478d3c3498e92d076c7e6de81b77c4;hpb=c96e924d9aaa24d68c93f3e6a4d85bed88a08df1;p=wdq2wav.git diff --git a/wdq2wav.h b/wdq2wav.h index 6d37b20..fceee29 100644 --- a/wdq2wav.h +++ b/wdq2wav.h @@ -8,7 +8,7 @@ ** ** Copyright (c) 2003 Kevin Rosenberg ** -** $Id: wdq2wav.h,v 1.16 2003/02/28 04:21:15 kevin Exp $ +** $Id$ ** ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU General Public License (version 2) as @@ -35,14 +35,14 @@ #include #include #include -#ifdef WIN32 +#ifdef _WIN32 #include #include #else #include #endif -#ifdef LINUX +#ifdef __linux__ #include #if __BYTE_ORDER == __BIG_ENDIAN #define WORDS_BIG_ENDIAN 1 @@ -72,6 +72,9 @@ public: bool m_valid; std::string m_error; int m_fd; + bool m_bLegacy_format; + bool m_bHires; + int m_nMaxChannels; int m_nChannels; unsigned long int m_nSamples; double m_sample_rate; @@ -81,9 +84,13 @@ public: unsigned int m_nData_bytes; unsigned int m_time_acq_start; unsigned int m_time_acq_stop; + double m_time_between_channel_samples; + + bool any_packed_channels(); + bool is_channel_packed(int iChannel); }; -class WindaqChannel +class WindaqChannel { public: WindaqFile& r_wdq; @@ -97,16 +104,18 @@ public: signed short int m_max_raw_data; double m_max_scaled_data; double m_min_scaled_data; + double m_raw_mean; WindaqChannel (WindaqFile& wdq, const int channel); ~WindaqChannel (); + double raw2measured(signed short int raw) const { return (raw * m_slope) + m_intercept; } private: bool read_channel_data(); }; -class WavFile +class WavFile { public: bool m_valid; @@ -128,7 +137,7 @@ class WavFile bool WriteFile (); bool Play(); - + private: bool fill_header(); }; @@ -137,5 +146,5 @@ template inline T nearest (double x) { return (x > 0 ? - static_cast(x+0.5) : static_cast(x-0.5)); + static_cast(x+0.5) : static_cast(x-0.5)); }