X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=include%2Fplotfile.h;h=da40ed358f6cef38d9fd2ebb9dd93856da22ded5;hp=35c7f9ff9a15a95555205d9e88fa4da8e3586bc3;hb=9b2bb510160bdb56f04847f5b55ab61dd8a47976;hpb=75a3edd6e6a5c16aea583771dfd1924c7aee9103 diff --git a/include/plotfile.h b/include/plotfile.h index 35c7f9f..da40ed3 100644 --- a/include/plotfile.h +++ b/include/plotfile.h @@ -9,7 +9,7 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: plotfile.h,v 1.1 2000/12/19 21:37:10 kevin Exp $ +** $Id: plotfile.h,v 1.4 2000/12/23 18:12:35 kevin Exp $ ** ** 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 @@ -41,37 +41,30 @@ #include #include #include "ctsupport.h" -#include "plotfile.h" +#include "plotfile.h" + // Plotfile structure: // 1. Lines that begin with # are comments // 2. ASCII file format // 3. Header lines begin with and end with -// 4. Valid headers -//
(signifies beginning of headers) -// (multiple instances may be present) -// -// -// <xlabel> -// <ylabel> -// <filetype>plotfile</filetype> (required) -// <ncolumns> (required) -// <nrecords> (required) -// </header> (required, signifies end of headers) +// 4. Valid headers +// <plotfile ncolumns nrecords> (signifies beginning of plotfile) +// <description> (beginning of description lines) +// <ezset> (signifies beginning of ezset commands) +// <columns> Beginning of data columns // 5. Data is ASCII file format, one record per line // Number of columns is variable and is set by ncolumns header -// 6. Data begins with <plotdata> and ends with </plotdata> + class PlotFile { private: std::string m_strFilename; - std::string m_strTitle; - std::string m_strXLabel; - std::string m_strYLabel; std::string m_strDate; - std::vector<std::string> m_vecStrDescriptions; + std::vector<std::string> m_vecStrDescriptions; + std::vector<std::string> m_vecStrEzsetCommands; std::vector<double> m_vecCurves; int m_iNumColumns; int m_iNumRecords; @@ -91,34 +84,21 @@ public: PlotFile (void); ~PlotFile (); - void setTitle (const std::string& title) - { m_strTitle = title; } - - void setXLabel (const std::string& label) - { m_strXLabel = label; } - - void setYLabel (const std::string& label) - { m_strYLabel = label; } - void setCurveSize (int iNCurves, int iNRecords); - void addDescription (const char* const pszDesc) - { m_vecStrDescriptions.push_back (pszDesc); } - + void addDescription (const char* const pszDesc) + { m_vecStrDescriptions.push_back (pszDesc); } + + void addEzsetCommand (const char* const pszCmd) + { m_vecStrEzsetCommands.push_back (pszCmd); } + bool addColumn (int iCol, const double* const pdColumn); bool addColumn (int iCol, const float* const pdColumn); - const std::string& getTitle () const - { return m_strTitle; } - - const std::string& getXLabel () const - { return m_strXLabel; } - - const std::string& getYLabel () const - { return m_strXLabel; } - - const std::string& getData () const + void getColumn (int iCol, double *pdColumnData) const; + + const std::string& getDate () const { return m_strDate; } int getNumColumns () const @@ -126,6 +106,10 @@ public: int getNumRecords () const { return m_iNumRecords; } + + bool getMinMax (int startingCol, double& min, double& max) const; + + bool statistics (int startingCol, double& min, double& max, double& mean, double& mode, double& median, double &stddev) const; unsigned int getNumDescriptions (void) const { return m_vecStrDescriptions.size(); } @@ -133,6 +117,12 @@ public: const std::string& getDescription (int iDescIndex) const { return m_vecStrDescriptions[iDescIndex]; } + unsigned int getNumEzsetCommands (void) const + { return m_vecStrEzsetCommands.size(); } + + const std::string& getEzsetCommand (int iIndex) const + { return m_vecStrEzsetCommands[iIndex]; } + bool fileRead (const char* const filename); bool fileWrite (const char* const filename);