X-Git-Url: http://git.kpe.io/?p=wdq2wav.git;a=blobdiff_plain;f=wdq2wav.h;h=fceee293df2b9819095020e7dad1be57d33971c5;hp=5dd00ceb8123fe0bc2a7222515bc75ed01d4af3f;hb=HEAD;hpb=7ca37015588adb2dee7054808e5bc6849dc4ff41 diff --git a/wdq2wav.h b/wdq2wav.h index 5dd00ce..fceee29 100644 --- a/wdq2wav.h +++ b/wdq2wav.h @@ -8,7 +8,7 @@ ** ** Copyright (c) 2003 Kevin Rosenberg ** -** $Id: wdq2wav.h,v 1.15 2003/02/25 18:18:26 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 @@ -32,16 +32,17 @@ #include #include #include +#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 @@ -71,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; @@ -80,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; @@ -96,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; @@ -127,7 +137,7 @@ class WavFile bool WriteFile (); bool Play(); - + private: bool fill_header(); }; @@ -136,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)); }