some more doxygen

This commit is contained in:
Mathieu Lacage
2008-03-21 15:33:01 -07:00
parent 18c92e855d
commit f17df2c2dc
2 changed files with 78 additions and 0 deletions

5
src/contrib/contrib.h Normal file
View File

@@ -0,0 +1,5 @@
/**
* \addtogroup contrib Contrib
*
* - A class to generate graphs with gnuplot: ns3::Gnuplot and ns3::GnuplotDataset
*/

View File

@@ -26,9 +26,15 @@
namespace ns3 {
/**
* \brief store a dataset to be used by ns3::Gnuplot
*/
class GnuplotDataset
{
public:
/**
* The plotting style to use for this dataset.
*/
enum Style {
LINES,
POINTS,
@@ -39,6 +45,9 @@ public:
FSTEPS,
HISTEPS,
};
/**
* Whether errorbars should be used for this dataset.
*/
enum ErrorBars {
NONE,
X,
@@ -46,12 +55,53 @@ public:
XY
};
/**
* Create an empty dataset without any title.
*/
GnuplotDataset ();
/**
* \param title the title to be associated to this dataset.
*
* Create an empty dataset. Usually, the dataset's title is
* displayed in the legend box.
*/
GnuplotDataset (std::string title);
/**
* \param style the style of plotting to use for this dataset.
*/
void SetStyle (enum Style style);
/**
* \param errorBars the style of errorbars to display.
*
* If you use any style other than none, you need
* to make sure you store the delta information in
* this dataset with the right GnuplotDataset::Add
* method.
*/
void SetErrorBars (enum ErrorBars errorBars);
/**
* \param x x coord to new data point
* \param y y coord to new data point
*
* Use this method with error bar style NONE.
*/
void Add (double x, double y);
/**
* \param x x coord to new data point
* \param y y coord to new data point
* \param errorDelta
*
* Use this method with error bar style X or Y.
*/
void Add (double x, double y, double errorDelta);
/**
* \param x x coord to new data point
* \param y y coord to new data point
* \param errorDeltaX x delta for the new data point
* \param errorDeltaY y delta for the new data point
*
* Use this method with error bar style XY.
*/
void Add (double x, double y, double errorDeltaX, double errorDeltaY);
private:
friend class Gnuplot;
@@ -68,16 +118,39 @@ private:
enum ErrorBars m_errorBars;
};
/**
* \brief a simple class to generate gnuplot-ready plotting commands
* from a set of datasets.
*
* This class really represents a single graph on which multiple datasets
* can be plotted.
*/
class Gnuplot
{
public:
/**
* \param pngFilename the name of the file where the png rendering of the
* graph will be generated if you feed the command stream output by
* Gnuplot::GenerateOutput to the gnuplot program.
*/
Gnuplot (std::string pngFilename);
~Gnuplot ();
/**
* \param xLegend the legend for the x horizontal axis
* \param yLegend the legend for the y vertical axis
*/
void SetLegend (std::string xLegend, std::string yLegend);
/**
* \param dataset add a dataset to the graph to be plotted.
*/
void AddDataset (const GnuplotDataset &dataset);
/**
* \param os the output stream on which the relevant gnuplot
* commands should be generated.
*/
void GenerateOutput (std::ostream &os);
private:
typedef std::vector<GnuplotDataset *> Datasets;