src/contrib/gnuplot.cc
author src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
Fri, 21 Mar 2008 04:51:36 +0100
changeset 2678 22aa62a108ed
parent 2519 55057c67d4f6
child 4061 359e0a1b5cf8
permissions -rw-r--r--
Composite and Jakes propagation loss models.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2007 INRIA
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
#include "gnuplot.h"
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    21
#include "ns3/assert.h"
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
#include <ostream>
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    23
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
namespace ns3 {
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
2519
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    26
GnuplotDataset::GnuplotDataset ()
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    27
  : m_title ("untitled"),
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    28
    m_style (LINES),
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    29
    m_errorBars (NONE)
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    30
{}
55057c67d4f6 add default constructor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2184
diff changeset
    31
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
GnuplotDataset::GnuplotDataset (std::string title)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    33
  : m_title (title),
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    34
    m_style (LINES),
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    35
    m_errorBars (NONE)
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
{}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    37
void 
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
GnuplotDataset::SetStyle (enum Style style)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
{
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
  m_style = style;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
void 
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    43
GnuplotDataset::SetErrorBars (enum ErrorBars errorBars)
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    44
{
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    45
  m_errorBars = errorBars;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    46
}
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    47
void 
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
GnuplotDataset::Add (double x, double y)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
{
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    50
  NS_ASSERT (m_errorBars == NONE);
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    51
  struct Data data;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    52
  data.x = x;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    53
  data.y = y;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    54
  data.dx = 0.0;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    55
  data.dy = 0.0;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    56
  m_dataset.push_back (data);
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    57
}
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    58
void 
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    59
GnuplotDataset::Add (double x, double y, double errorDelta)
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    60
{
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    61
  NS_ASSERT (m_errorBars == X || m_errorBars == Y);
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    62
  struct Data data;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    63
  data.x = x;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    64
  data.y = y;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    65
  data.dx = errorDelta;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    66
  data.dy = errorDelta;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
    67
  m_dataset.push_back (data);
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    68
}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    69
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
Gnuplot::Gnuplot (std::string pngFilename)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
  : m_pngFilename (pngFilename)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    72
{}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
Gnuplot::~Gnuplot ()
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
{
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
  for (Datasets::const_iterator i = m_datasets.begin (); i != m_datasets.end (); i++)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
    {
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
      delete *i;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
    }
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
  m_datasets.clear ();
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    81
}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
void 
2184
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    84
Gnuplot::SetLegend (std::string xLegend, std::string yLegend)
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    85
{
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    86
  m_xLegend = xLegend;
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    87
  m_yLegend = yLegend;
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    88
}
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    89
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
    90
void 
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    91
Gnuplot::AddDataset (const GnuplotDataset &dataset)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
{
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    93
  m_datasets.push_back (new GnuplotDataset (dataset));
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    94
}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    95
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    96
void 
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    97
Gnuplot::GenerateOutput (std::ostream &os)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    98
{
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
  os << "set terminal png" << std::endl;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   100
  os << "set output '" << m_pngFilename << "'" << std::endl;
2184
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
   101
  os << "set xlabel '" << m_xLegend << "'" << std::endl;
db9f25b01d5c add legend support to gnuplot output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2180
diff changeset
   102
  os << "set ylabel '" << m_yLegend << "'" << std::endl;
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   103
  os << "plot ";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   104
  for (Datasets::const_iterator i = m_datasets.begin (); i != m_datasets.end ();)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   105
    {
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   106
      os << "'-' title '" << (*i)->m_title << "'";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   107
      switch ((*i)->m_style) {
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   108
      case GnuplotDataset::LINES:
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   109
        os << " with lines";
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   110
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   111
      case GnuplotDataset::POINTS:
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   112
        switch ((*i)->m_errorBars)
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   113
          {
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   114
          case GnuplotDataset::NONE:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   115
            os << " with points";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   116
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   117
          case GnuplotDataset::X:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   118
            os << " with xerrorbars";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   119
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   120
          case GnuplotDataset::Y:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   121
            os << " with yerrorbars";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   122
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   123
          case GnuplotDataset::XY:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   124
            os << " with xyerrorbars";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   125
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   126
          }
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   127
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   128
      case GnuplotDataset::LINES_POINTS:
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   129
        switch ((*i)->m_errorBars)
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   130
          {
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   131
          case GnuplotDataset::NONE:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   132
            os << " with linespoints";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   133
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   134
          case GnuplotDataset::X:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   135
            os << " with xerrorlines";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   136
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   137
          case GnuplotDataset::Y:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   138
            os << " with yerrorlines";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   139
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   140
          case GnuplotDataset::XY:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   141
            os << " with xyerrorlines";
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   142
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   143
          }
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   144
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   145
      case GnuplotDataset::DOTS:
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   146
	os << " with dots";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   147
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   148
      case GnuplotDataset::IMPULSES:
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   149
	os << " with impulses";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   150
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   151
      case GnuplotDataset::STEPS:
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   152
	os << " with steps";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   153
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   154
      case GnuplotDataset::FSTEPS:
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   155
	os << " with fsteps";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   156
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   157
      case GnuplotDataset::HISTEPS:
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   158
	os << " with histeps";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   159
	break;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   160
      }
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   161
      i++;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   162
      if (i != m_datasets.end ())
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   163
	{
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   164
	  os << ", ";
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   165
	}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   166
    }
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   167
  os << std::endl;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   168
  for (Datasets::const_iterator i = m_datasets.begin (); i != m_datasets.end (); i++)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   169
    {
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   170
      for (GnuplotDataset::Dataset::const_iterator j = (*i)->m_dataset.begin ();
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   171
	   j != (*i)->m_dataset.end (); j++)
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   172
	{
2180
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   173
          switch ((*i)->m_errorBars) {
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   174
          case GnuplotDataset::NONE:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   175
            os << j->x << " " << j->y << std::endl;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   176
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   177
          case GnuplotDataset::X:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   178
            os << j->x << " " << j->y << " " << j->dx << std::endl;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   179
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   180
          case GnuplotDataset::Y:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   181
            os << j->x << " " << j->y << " " << j->dy << std::endl;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   182
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   183
          case GnuplotDataset::XY:
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   184
            os << j->x << " " << j->y << " " << j->dx << " " << j->dy << std::endl;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   185
            break;
8cbdda2a5c2d add support for gnuplot error bars
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1879
diff changeset
   186
          }
1879
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   187
	}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   188
      os << "e" << std::endl;
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   189
    }
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   190
}
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   191
876026968947 Gnuplot output class for contrib module
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   192
} // namespace ns3