mirror of
https://github.com/dkogan/feedgnuplot.git
synced 2025-09-19 03:38:08 +08:00
Compare commits
98 Commits
debian/1.1
...
debian/1.2
Author | SHA1 | Date | |
---|---|---|---|
![]() |
9ab429e618 | ||
![]() |
14a39b6fd2 | ||
![]() |
d705699459 | ||
![]() |
8867cf54f0 | ||
![]() |
1a15457b81 | ||
![]() |
6397548515 | ||
![]() |
ba4cc66fe8 | ||
![]() |
52b9024320 | ||
![]() |
6809545a16 | ||
![]() |
a66e45adb5 | ||
![]() |
116eb8fbc0 | ||
![]() |
8557cd4870 | ||
![]() |
88fbd90a28 | ||
![]() |
d9906d8e88 | ||
![]() |
186b7a3ae0 | ||
![]() |
62eb5f17bb | ||
![]() |
a164c4ff29 | ||
![]() |
8c39242986 | ||
![]() |
2934a76fdd | ||
![]() |
30d5b10fd6 | ||
![]() |
f2d4b7d78b | ||
![]() |
00d2f0d6a6 | ||
![]() |
0ccffde918 | ||
![]() |
805060ba92 | ||
![]() |
614bbfe848 | ||
![]() |
265062904f | ||
![]() |
55ba185ec5 | ||
![]() |
0780c10b18 | ||
![]() |
6ba7fc053c | ||
![]() |
061cb0c0af | ||
![]() |
21c38efc2d | ||
![]() |
08b827d81b | ||
![]() |
7833e63c32 | ||
![]() |
b91eb7f746 | ||
![]() |
d9e5067f20 | ||
![]() |
9148a3e5e9 | ||
![]() |
44a81e153d | ||
![]() |
3d53e25c22 | ||
![]() |
458367883a | ||
![]() |
ba1715446b | ||
![]() |
d4997cbba7 | ||
![]() |
c875120dbd | ||
![]() |
1f350add09 | ||
![]() |
5dcffaa62d | ||
![]() |
d36082ab32 | ||
![]() |
5cf323a97c | ||
![]() |
2d7bf52a45 | ||
![]() |
229c08582d | ||
![]() |
5b20a2389a | ||
![]() |
04876fa72e | ||
![]() |
892e8266c8 | ||
![]() |
cb59f1b3bc | ||
![]() |
e61e831ef2 | ||
![]() |
469461cf00 | ||
![]() |
54f3751270 | ||
![]() |
01de359dcd | ||
![]() |
0c18ccc7db | ||
![]() |
a285735961 | ||
![]() |
d28ef06cff | ||
![]() |
0ddc0bd0bd | ||
![]() |
83379b0280 | ||
![]() |
aa690c92e4 | ||
![]() |
e5973e4fd6 | ||
![]() |
2b2a40f1fe | ||
![]() |
dd034797ec | ||
![]() |
c89ddef9ba | ||
![]() |
f4859ae475 | ||
![]() |
69c635103a | ||
![]() |
8952973ba2 | ||
![]() |
e14b57b6ad | ||
![]() |
df2c78a85e | ||
![]() |
472520fdd8 | ||
![]() |
54f7f17558 | ||
![]() |
a8dc63c472 | ||
![]() |
10a4d35e97 | ||
![]() |
70946c92c2 | ||
![]() |
a8f5b99c23 | ||
![]() |
5cb7e3616a | ||
![]() |
b9ce0ea175 | ||
![]() |
d6381c747b | ||
![]() |
a054645a71 | ||
![]() |
0ce0f8a3f0 | ||
![]() |
3171f272fc | ||
![]() |
1cced9a621 | ||
![]() |
3132b76caa | ||
![]() |
b90e783f69 | ||
![]() |
9b0bc07ae4 | ||
![]() |
7bcb3920a1 | ||
![]() |
0ec6cb3d6d | ||
![]() |
9edb99d4cd | ||
![]() |
a1fac377a8 | ||
![]() |
80a5fac5f2 | ||
![]() |
f6fc00f3f2 | ||
![]() |
02d3f2bc92 | ||
![]() |
f682fa0816 | ||
![]() |
1e63a87a3d | ||
![]() |
47846ea562 | ||
![]() |
36d1db13a3 |
78
Changes
Normal file
78
Changes
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
feedgnuplot (1.23)
|
||||||
|
|
||||||
|
* --extracmds no longer accepts comma-separated lists
|
||||||
|
This was needed because a command can have a comma
|
||||||
|
* --curvestyle no longer adds on top of --curvestyleall
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sat, 29 Sep 2012 16:29:38 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.22)
|
||||||
|
|
||||||
|
* removed --size option
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Mon, 03 Sep 2012 08:33:26 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.21)
|
||||||
|
|
||||||
|
* removed the POD from the script to its own file
|
||||||
|
* fixed regression to allow no given extracmds, histogram or y2
|
||||||
|
options
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 02 Sep 2012 23:52:21 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.20)
|
||||||
|
|
||||||
|
* no longer hardcoding 'x11' as the default terminal
|
||||||
|
* added histogram support
|
||||||
|
* generic terminals can now be requested
|
||||||
|
* --extracmds, --histogram, --y2 can now take comma-separated lists
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Fri, 31 Aug 2012 01:35:50 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.19)
|
||||||
|
|
||||||
|
* added --geometry option to specify plot dimensions
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sat, 11 Feb 2012 21:04:42 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.18)
|
||||||
|
|
||||||
|
* data-ids can now include characters such as -. Any non-whitespace
|
||||||
|
works
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Tue, 27 Dec 2011 16:47:36 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.17)
|
||||||
|
|
||||||
|
[ Dima Kogan ]
|
||||||
|
* POD: removed -Winteractive, since this was apparently a mawk-ism
|
||||||
|
* added zsh and bash completions
|
||||||
|
|
||||||
|
[ Hermann Schwarting ]
|
||||||
|
* add build dependency libtest-script-run-perl
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 20 Nov 2011 19:17:22 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.16)
|
||||||
|
|
||||||
|
* Some POD fixes
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Fri, 11 Nov 2011 00:10:18 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.15)
|
||||||
|
|
||||||
|
* Renamed main script from feedGnuplot to feedgnuplot
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 16 Oct 2011 11:58:15 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.14)
|
||||||
|
|
||||||
|
* added 'clear' command, documented commands
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 22 May 2011 15:25:28 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.13)
|
||||||
|
|
||||||
|
* Better streaming plot control
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Tue, 26 Apr 2011 14:24:09 -0700
|
3
INSTALL
3
INSTALL
@@ -1,8 +1,9 @@
|
|||||||
If running on a Debian-based OS (this includes Ubuntu), it is highly recommended
|
If running on a Debian-based OS (this includes Ubuntu), it is highly recommended
|
||||||
to install this program as a package by doing
|
to install this program as a package by doing
|
||||||
|
|
||||||
|
ln -fs package_definitions/debian debian
|
||||||
dpkg-buildpackage -us -uc -b
|
dpkg-buildpackage -us -uc -b
|
||||||
sudo dpkg -i feedgnuplot*.deb
|
sudo dpkg -i ../feedgnuplot*.deb
|
||||||
|
|
||||||
This builds a debian package and installs it.
|
This builds a debian package and installs it.
|
||||||
|
|
||||||
|
8
LICENSE
Normal file
8
LICENSE
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
This library is distributed under the terms of the GNU GPL:
|
||||||
|
|
||||||
|
http://www.gnu.org/licenses/gpl.html
|
||||||
|
|
||||||
|
|
||||||
|
or the Artistic license:
|
||||||
|
|
||||||
|
http://dev.perl.org/licenses/artistic.html
|
3
MANIFEST
3
MANIFEST
@@ -1,5 +1,8 @@
|
|||||||
Makefile.PL
|
Makefile.PL
|
||||||
MANIFEST
|
MANIFEST
|
||||||
bin/feedgnuplot
|
bin/feedgnuplot
|
||||||
|
bin/feedgnuplot.pod
|
||||||
t/00-load.t
|
t/00-load.t
|
||||||
t/manifest.t
|
t/manifest.t
|
||||||
|
Changes
|
||||||
|
LICENSE
|
||||||
|
36
Makefile.PL
36
Makefile.PL
@@ -4,14 +4,14 @@ use ExtUtils::MakeMaker;
|
|||||||
|
|
||||||
sub parseversion
|
sub parseversion
|
||||||
{
|
{
|
||||||
# grab the version number from the debian changelog file. I look for lines line
|
# grab the version number from the changelog. I look for lines line
|
||||||
#
|
#
|
||||||
# libpackage-perl (0.02) unstable; urgency=low
|
# libpackage-perl (0.02)
|
||||||
#
|
#
|
||||||
# I parse out the 0.02 part
|
# I parse out the 0.02 part
|
||||||
open DCH, 'debian/changelog' or die "Couldn't open debian/changelog";
|
open DCH, 'Changes' or die "Couldn't open 'Changes'";
|
||||||
my ($version) = <DCH> =~ /^\S+ \s* \( ([0-9\.]+) \)/x
|
my ($version) = <DCH> =~ /^\S+ \s* \( ([0-9\.]+) \)/x
|
||||||
or die "Couldn't parse version from debian/changelog";
|
or die "Couldn't parse version from 'Changes'";
|
||||||
close DCH;
|
close DCH;
|
||||||
|
|
||||||
return $version;
|
return $version;
|
||||||
@@ -23,37 +23,33 @@ sub MY::libscan
|
|||||||
|
|
||||||
my ($self, $file) = @_;
|
my ($self, $file) = @_;
|
||||||
|
|
||||||
# Don't install the README.pod or any non-feedgnuplot .pl file
|
# Don't install any symlinks (i.e. README.pod)
|
||||||
return undef if $file !~ /feedgnuplot.pl/ && $file =~ /\.pl$|^README.pod/;
|
return undef if -l $file;
|
||||||
|
|
||||||
return $self->SUPER::libscan ($file);
|
return $self->SUPER::libscan ($file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# I want my manpage to go into the man section '1', NOT '1p'. Here I add a
|
||||||
|
# snippet to the end of the generated Makefile to force this
|
||||||
|
sub MY::postamble
|
||||||
|
{
|
||||||
|
return "MAN1EXT := 1\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
WriteMakefile
|
WriteMakefile
|
||||||
(
|
(
|
||||||
NAME => 'feedgnuplot',
|
NAME => 'feedgnuplot',
|
||||||
AUTHOR => q{Dima Kogan <dima@secretsauce.net>},
|
AUTHOR => q{Dima Kogan <dima@secretsauce.net>},
|
||||||
VERSION => parseversion(),
|
VERSION => parseversion(),
|
||||||
ABSTRACT_FROM => 'bin/feedgnuplot',
|
ABSTRACT_FROM => 'bin/feedgnuplot.pod',
|
||||||
($ExtUtils::MakeMaker::VERSION >= 6.3002
|
($ExtUtils::MakeMaker::VERSION >= 6.3002
|
||||||
? ('LICENSE' => 'perl')
|
? ('LICENSE' => 'perl')
|
||||||
: ()),
|
: ()),
|
||||||
PL_FILES => {},
|
PL_FILES => {},
|
||||||
EXE_FILES => [ 'bin/feedgnuplot' ],
|
EXE_FILES => [ 'bin/feedgnuplot' ],
|
||||||
|
MAN1PODS => { 'bin/feedgnuplot.pod' => 'blib/man1/feedgnuplot.1' },
|
||||||
PREREQ_PM => { 'Test::Script::Run' => 0},
|
PREREQ_PM => { 'Test::Script::Run' => 0},
|
||||||
dist => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
|
dist => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
|
||||||
clean => { FILES => 'feedgnuplot-*' },
|
clean => { FILES => 'feedgnuplot-*' },
|
||||||
);
|
);
|
||||||
|
|
||||||
# reroute the main POD into a separate README.pod if requested. This is here
|
|
||||||
# purely to generate a README.pod for the github front page
|
|
||||||
if(exists $ARGV[0] && $ARGV[0] eq 'README.pod')
|
|
||||||
{
|
|
||||||
open SCRIPT, 'bin/feedgnuplot' or die "Couldn't open main script";
|
|
||||||
open README, '>README.pod' or die "Couldn't open README.pod";
|
|
||||||
while (<SCRIPT>)
|
|
||||||
{
|
|
||||||
if (/^=/../^=cut/)
|
|
||||||
{ print README; }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
366
README.pod
366
README.pod
@@ -1,366 +0,0 @@
|
|||||||
=head1 NAME
|
|
||||||
|
|
||||||
feedgnuplot - Pipe-oriented frontend to Gnuplot
|
|
||||||
|
|
||||||
=head1 SYNOPSIS
|
|
||||||
|
|
||||||
Simple plotting of stored data:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}'
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' |
|
|
||||||
feedgnuplot --lines --points --legend 0 "data 0" --title "Test plot" --y2 1
|
|
||||||
|
|
||||||
Simple real-time plotting example: plot how much data is received on the wlan0
|
|
||||||
network interface in bytes/second (uses bash, awk and Linux):
|
|
||||||
|
|
||||||
$ while true; do sleep 1; cat /proc/net/dev; done |
|
|
||||||
gawk '/wlan0/ {if(b) {print $2-b; fflush()} b=$2}' |
|
|
||||||
feedgnuplot --lines --stream --xlen 10 --ylabel 'Bytes/sec' --xlabel seconds
|
|
||||||
|
|
||||||
=head1 DESCRIPTION
|
|
||||||
|
|
||||||
This is a flexible, command-line-oriented frontend to Gnuplot. It creates
|
|
||||||
plots from data coming in on STDIN or given in a filename passed on the
|
|
||||||
commandline. Various data representations are supported, as is hardcopy
|
|
||||||
output and streaming display of live data. A simple example:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot
|
|
||||||
|
|
||||||
You should see a plot with two curves. The C<awk> command generates some data to
|
|
||||||
plot and the C<feedgnuplot> reads it in from STDIN and generates the plot. The
|
|
||||||
C<awk> invocation is just an example; more interesting things would be plotted
|
|
||||||
in normal usage. No commandline-options are required for the most basic
|
|
||||||
plotting. Input parsing is flexible; every line need not have the same number of
|
|
||||||
points. New curves will be created as needed.
|
|
||||||
|
|
||||||
The most commonly used functionality of gnuplot is supported directly by the
|
|
||||||
script. Anything not directly supported can still be done with the
|
|
||||||
C<--extracmds> and C<--curvestyle> options. Arbitrary gnuplot commands can be
|
|
||||||
passed in with C<--extracmds>. For example, to turn off the grid, pass in
|
|
||||||
C<--extracmds 'unset grid'>. As many of these options as needed can be passed
|
|
||||||
in. To add arbitrary curve styles, use C<--curvestyle curveID extrastyle>. Pass
|
|
||||||
these more than once to affect more than one curve. To apply an extra style to
|
|
||||||
I<all> the curves, pass in C<--curvestyleall extrastyle>.
|
|
||||||
|
|
||||||
=head2 Data formats
|
|
||||||
|
|
||||||
By default, each value present in the incoming data represents a distinct data
|
|
||||||
point, as demonstrated in the original example above (we had 10 numbers in the
|
|
||||||
input and 10 points in the plot). If requested, the script supports more
|
|
||||||
sophisticated interpretation of input data
|
|
||||||
|
|
||||||
=head3 Domain selection
|
|
||||||
|
|
||||||
If C<--domain> is passed in, the first value on each line of input is
|
|
||||||
interpreted as the I<X>-value for the rest of the data on that line. Without
|
|
||||||
C<--domain> the I<X>-value is the line number, and the first value on a line is
|
|
||||||
a plain data point like the others. Default is C<--nodomain>. Thus the original
|
|
||||||
example above produces 2 curves, with B<1,2,3,4,5> as the I<X>-values. If we run
|
|
||||||
the same command with --domain:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --domain
|
|
||||||
|
|
||||||
we get only 1 curve, with B<2,4,6,8,10> as the I<X>-values. As many points as
|
|
||||||
desired can appear on a single line, but all points on a line are associated
|
|
||||||
with the I<X>-value at the start of that line.
|
|
||||||
|
|
||||||
=head3 Curve indexing
|
|
||||||
|
|
||||||
By default, each column represents a separate curve. This is fine unless sparse
|
|
||||||
data is to be plotted. With the C<--dataid> option, each point is represented by
|
|
||||||
2 values: a string identifying the curve, and the value itself. If we add
|
|
||||||
C<--dataid> to the original example:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --dataid --autolegend
|
|
||||||
|
|
||||||
we get 5 different curves with one point in each. The first column, as produced
|
|
||||||
by C<awk>, is B<2,4,6,8,10>. These are interpreted as the IDs of the curves to
|
|
||||||
be plotted. The C<--autolegend> option adds a legend using the given IDs to
|
|
||||||
label the curves. The IDs need not be numbers; generic strings are accepted. As
|
|
||||||
many points as desired can appear on a single line. C<--domain> can be used in
|
|
||||||
conjunction with C<--dataid>.
|
|
||||||
|
|
||||||
=head3 Multi-value style support
|
|
||||||
|
|
||||||
Depending on how gnuplot is plotting the data, more than one value may be needed
|
|
||||||
to represent a single point. For example, the script has support to plot all the
|
|
||||||
data with C<--circles>. This requires a radius to be specified for each point in
|
|
||||||
addition to the position of the point. Thus, when plotting with C<--circles>, 2
|
|
||||||
numbers are read for each data point instead of 1. A similar situation exists
|
|
||||||
with C<--colormap> where each point contains the position I<and> the
|
|
||||||
color. There are other gnuplot styles that require more data (such as error
|
|
||||||
bars), but none of these are directly supported by the script. They can still be
|
|
||||||
used, though, by specifying the specific style with C<--curvestyle>, and
|
|
||||||
specifying how many extra values are needed for each point with
|
|
||||||
C<--extraValuesPerPoint extra>. C<--extraValuesPerPoint> is ONLY needed for the
|
|
||||||
styles not explicitly supported; supported styles set that variable
|
|
||||||
automatically.
|
|
||||||
|
|
||||||
=head3 3D data
|
|
||||||
|
|
||||||
To plot 3D data, pass in C<--3d>. C<--domain> MUST be given when plotting 3D
|
|
||||||
data to avoid domain ambiguity. If 3D data is being plotted, there are by
|
|
||||||
definition 2 domain values instead of one (I<Z> as a function of I<X> and I<Y>
|
|
||||||
instead of I<Y> as a function of I<X>). Thus the first 2 values on each line are
|
|
||||||
interpreted as the domain instead of just 1. The rest of the processing happens
|
|
||||||
the same way as before.
|
|
||||||
|
|
||||||
=head3 Special data commands
|
|
||||||
|
|
||||||
Other than the raw data, 2 special commands are interpreted if they appear in
|
|
||||||
the input. These are C<replot> and C<clear>. If a line of data begins with
|
|
||||||
C<replot> and we're plotting in realtime with C<--stream>, the plot will be
|
|
||||||
refreshed immediately. If a line of data begins with C<clear>, the plot is
|
|
||||||
cleared, to be re-filled with any data following the C<clear>.
|
|
||||||
|
|
||||||
=head2 Real-time streaming data
|
|
||||||
|
|
||||||
To plot real-time data, pass in the C<--stream [refreshperiod]> option. Data
|
|
||||||
will then be plotted as it is received. The plot will be updated every
|
|
||||||
C<refreshperiod> seconds. If the period isn't specified, a 1Hz refresh rate is
|
|
||||||
used. To refresh at specific intervals indicated by the data, set the
|
|
||||||
refreshperiod to 0 or to 'trigger'. The plot will then I<only> be refreshed when
|
|
||||||
a data line 'replot' is received. This 'replot' command works in both triggered
|
|
||||||
and timed modes, but in triggered mode, it's the only way to replot.
|
|
||||||
|
|
||||||
To plot only the most recent data (instead of I<all> the data), C<--xlen
|
|
||||||
windowsize> can be given. This will create an constantly-updating, scrolling
|
|
||||||
view of the recent past. C<windowsize> should be replaced by the desired length
|
|
||||||
of the domain window to plot, in domain units (passed-in values if C<--domain>
|
|
||||||
or line numbers otherwise).
|
|
||||||
|
|
||||||
=head2 Hardcopy output
|
|
||||||
|
|
||||||
The script is able to produce hardcopy output with C<--hardcopy outputfile>. The
|
|
||||||
output type is inferred from the filename with B<.ps>, B<.eps>, B<.pdf> and
|
|
||||||
B<.png> currently supported.
|
|
||||||
|
|
||||||
=head2 Self-plotting data files
|
|
||||||
|
|
||||||
This script can be used to enable self-plotting data files. There are 2 ways of
|
|
||||||
doing this: with a shebang (#!) or with inline perl data.
|
|
||||||
|
|
||||||
=head3 Self-plotting data with a #!
|
|
||||||
|
|
||||||
A self-plotting, executable data file C<data> is formatted as
|
|
||||||
|
|
||||||
$ cat data
|
|
||||||
#!/usr/bin/feedgnuplot --lines --points
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
12 36
|
|
||||||
14 49
|
|
||||||
16 64
|
|
||||||
18 81
|
|
||||||
20 100
|
|
||||||
22 121
|
|
||||||
24 144
|
|
||||||
26 169
|
|
||||||
28 196
|
|
||||||
30 225
|
|
||||||
|
|
||||||
This is the shebang (#!) line followed by the data, formatted as before. The
|
|
||||||
data file can be plotted simply with
|
|
||||||
|
|
||||||
$ ./data
|
|
||||||
|
|
||||||
The caveats here are that on Linux the whole #! line is limited to 127 charaters
|
|
||||||
and that the full path to feedgnuplot must be given. The 127 character limit is
|
|
||||||
a serious limitation, but this can likely be resolved with a kernel patch. I
|
|
||||||
have only tried on Linux 2.6.
|
|
||||||
|
|
||||||
=head3 Self-plotting data with perl inline data
|
|
||||||
|
|
||||||
Perl supports storing data and code in the same file. This can also be used to
|
|
||||||
create self-plotting files:
|
|
||||||
|
|
||||||
$ cat plotdata.pl
|
|
||||||
#!/usr/bin/perl
|
|
||||||
use strict;
|
|
||||||
use warnings;
|
|
||||||
|
|
||||||
open PLOT, "| feedgnuplot --lines --points" or die "Couldn't open plotting pipe";
|
|
||||||
while( <DATA> )
|
|
||||||
{
|
|
||||||
my @xy = split;
|
|
||||||
print PLOT "@xy\n";
|
|
||||||
}
|
|
||||||
__DATA__
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
12 36
|
|
||||||
14 49
|
|
||||||
16 64
|
|
||||||
18 81
|
|
||||||
20 100
|
|
||||||
22 121
|
|
||||||
24 144
|
|
||||||
26 169
|
|
||||||
28 196
|
|
||||||
30 225
|
|
||||||
|
|
||||||
This is especially useful if the logged data is not in a format directly
|
|
||||||
supported by feedgnuplot. Raw data can be stored after the __DATA__ directive,
|
|
||||||
with a small perl script to manipulate the data into a useable format and send
|
|
||||||
it to the plotter.
|
|
||||||
|
|
||||||
=head1 ARGUMENTS
|
|
||||||
|
|
||||||
--[no]domain If enabled, the first element of each line is the
|
|
||||||
domain variable. If not, the point index is used
|
|
||||||
|
|
||||||
--[no]dataid If enabled, each data point is preceded by the ID
|
|
||||||
of the data set that point corresponds to. This ID is
|
|
||||||
interpreted as a string, NOT as just a number. If not
|
|
||||||
enabled, the order of the point is used.
|
|
||||||
|
|
||||||
As an example, if line 3 of the input is "0 9 1 20"
|
|
||||||
'--nodomain --nodataid' would parse the 4 numbers as points in 4
|
|
||||||
different curves at x=3
|
|
||||||
|
|
||||||
'--domain --nodataid' would parse the 4 numbers as points in 3 different
|
|
||||||
curves at x=0. Here, 0 is the x-variable and 9,1,20 are the data values
|
|
||||||
|
|
||||||
'--nodomain --dataid' would parse the 4 numbers as points in 2 different
|
|
||||||
curves at x=3. Here 0 and 1 are the data IDs and 9 and 20 are the
|
|
||||||
data values
|
|
||||||
|
|
||||||
'--domain --dataid' would parse the 4 numbers as a single point at
|
|
||||||
x=0. Here 9 is the data ID and 1 is the data value. 20 is an extra
|
|
||||||
value, so it is ignored. If another value followed 20, we'd get another
|
|
||||||
point in curve ID 20
|
|
||||||
|
|
||||||
--[no]3d Do [not] plot in 3D. This only makes sense with --domain.
|
|
||||||
Each domain here is an (x,y) tuple
|
|
||||||
|
|
||||||
--colormap Show a colormapped xy plot. Requires extra data for the color.
|
|
||||||
zmin/zmax can be used to set the extents of the colors.
|
|
||||||
Automatically increments extraValuesPerPoint
|
|
||||||
|
|
||||||
--stream [period] Plot the data as it comes in, in realtime. If period is given,
|
|
||||||
replot every period seconds. If no period is given, replot at
|
|
||||||
1Hz. If the period is given as 0 or 'trigger', replot ONLY when
|
|
||||||
the incoming data dictates this . See the "Real-time streaming
|
|
||||||
data" section of the man page.
|
|
||||||
|
|
||||||
--[no]lines Do [not] draw lines to connect consecutive points
|
|
||||||
--[no]points Do [not] draw points
|
|
||||||
--circles Plot with circles. This requires a radius be specified for
|
|
||||||
each point. Automatically increments extraValuesPerPoint
|
|
||||||
|
|
||||||
--xlabel xxx Set x-axis label
|
|
||||||
--ylabel xxx Set y-axis label
|
|
||||||
--y2label xxx Set y2-axis label. Does not apply to 3d plots
|
|
||||||
--zlabel xxx Set y-axis label. Only applies to 3d plots
|
|
||||||
|
|
||||||
--title xxx Set the title of the plot
|
|
||||||
|
|
||||||
--legend curveID legend
|
|
||||||
Set the label for a curve plot. Use this option multiple times
|
|
||||||
for multiple curves. With --dataid, curveID is the ID. Otherwise,
|
|
||||||
it's the index of the curve, starting at 0
|
|
||||||
|
|
||||||
--autolegend Use the curve IDs for the legend. Titles given with --legend
|
|
||||||
override these
|
|
||||||
|
|
||||||
--xlen xxx When using --stream, sets the size of the x-window to plot.
|
|
||||||
Omit this or set it to 0 to plot ALL the data. Does not
|
|
||||||
make sense with 3d plots. Implies --monotonic
|
|
||||||
|
|
||||||
--xmin xxx Set the range for the x axis. These are ignored in a
|
|
||||||
streaming plot
|
|
||||||
--xmax xxx Set the range for the x axis. These are ignored in a
|
|
||||||
streaming plot
|
|
||||||
--ymin xxx Set the range for the y axis.
|
|
||||||
--ymax xxx Set the range for the y axis.
|
|
||||||
--y2min xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
|
||||||
--y2max xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
|
||||||
--zmin xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
|
||||||
--zmax xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
|
||||||
|
|
||||||
--y2 xxx Plot the data specified by this curve ID on the y2 axis.
|
|
||||||
Without --dataid, the ID is just an ordered 0-based index.
|
|
||||||
Does not apply to 3d plots.
|
|
||||||
|
|
||||||
--curvestyle curveID style
|
|
||||||
Additional styles per curve. With --dataid, curveID is the
|
|
||||||
ID. Otherwise, it's the index of the curve, starting at 0. Use
|
|
||||||
this option multiple times for multiple curves
|
|
||||||
|
|
||||||
--curvestyleall xxx Additional styles for ALL curves.
|
|
||||||
|
|
||||||
--extracmds xxx Additional commands. These could contain extra global styles
|
|
||||||
for instance
|
|
||||||
|
|
||||||
--size xxx Gnuplot size option
|
|
||||||
|
|
||||||
--square Plot data with aspect ratio 1. For 3D plots, this controls the
|
|
||||||
aspect ratio for all 3 axes
|
|
||||||
|
|
||||||
--square_xy For 3D plots, set square aspect ratio for ONLY the x,y axes
|
|
||||||
|
|
||||||
--hardcopy xxx If not streaming, output to a file specified here. Format
|
|
||||||
inferred from filename
|
|
||||||
|
|
||||||
--maxcurves xxx The maximum allowed number of curves. This is 100 by default,
|
|
||||||
but can be reset with this option. This exists purely to
|
|
||||||
prevent perl from allocating all of the system's memory when
|
|
||||||
reading bogus data
|
|
||||||
|
|
||||||
--monotonic If --domain is given, checks to make sure that the x-
|
|
||||||
coordinate in the input data is monotonically increasing.
|
|
||||||
If a given x-variable is in the past, all data currently
|
|
||||||
cached for this curve is purged. Without --monotonic, all
|
|
||||||
data is kept. Does not make sense with 3d plots.
|
|
||||||
No --monotonic by default.
|
|
||||||
|
|
||||||
--extraValuesPerPoint xxx
|
|
||||||
How many extra values are given for each data point. Normally this
|
|
||||||
is 0, and does not need to be specified, but sometimes we want
|
|
||||||
extra data, like for colors or point sizes or error bars, etc.
|
|
||||||
feedgnuplot options that require this (colormap, circles)
|
|
||||||
automatically set it. This option is ONLY needed if unknown styles are
|
|
||||||
used, with --curvestyleall for instance
|
|
||||||
|
|
||||||
--dump Instead of printing to gnuplot, print to STDOUT. For
|
|
||||||
debugging.
|
|
||||||
|
|
||||||
--geometry If using X11, specifies the size, position of the plot window
|
|
||||||
|
|
||||||
=head1 ACKNOWLEDGEMENT
|
|
||||||
|
|
||||||
This program is originally based on the driveGnuPlots.pl script from
|
|
||||||
Thanassis Tsiodras. It is available from his site at
|
|
||||||
L<http://users.softlab.ece.ntua.gr/~ttsiod/gnuplotStreaming.html>
|
|
||||||
|
|
||||||
=head1 REPOSITORY
|
|
||||||
|
|
||||||
L<https://github.com/dkogan/feedgnuplot>
|
|
||||||
|
|
||||||
=head1 AUTHOR
|
|
||||||
|
|
||||||
Dima Kogan, C<< <dima@secretsauce.net> >>
|
|
||||||
|
|
||||||
=head1 LICENSE AND COPYRIGHT
|
|
||||||
|
|
||||||
Copyright 2011 Dima Kogan.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of either: the GNU General Public License as published
|
|
||||||
by the Free Software Foundation; or the Artistic License.
|
|
||||||
|
|
||||||
See http://dev.perl.org/licenses/ for more information.
|
|
||||||
|
|
||||||
=cut
|
|
1
README.pod
Symbolic link
1
README.pod
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
bin/feedgnuplot.pod
|
484
bin/feedgnuplot
484
bin/feedgnuplot
@@ -89,19 +89,25 @@ sub interpretCommandline
|
|||||||
# do not stream in the data by default
|
# do not stream in the data by default
|
||||||
# point plotting by default.
|
# point plotting by default.
|
||||||
# no monotonicity checks by default
|
# no monotonicity checks by default
|
||||||
|
# normal histograms by default
|
||||||
$options{ maxcurves } = 100;
|
$options{ maxcurves } = 100;
|
||||||
|
$options{ histstyle} = 'freq';
|
||||||
|
|
||||||
# Previously I was using 'legend=s%' and 'curvestyle=s%' for curve addressing. This had cleaner
|
# Previously I was using 'legend=s%' and 'curvestyle=s%' for curve addressing. This had cleaner
|
||||||
# syntax, but disregarded the order of the given options. This resulted in arbitrarily ordered
|
# syntax, but disregarded the order of the given options. This resulted in arbitrarily ordered
|
||||||
# curves.
|
# curves. I thus make parse these into lists, and then also make hashes, for later use
|
||||||
# needed for these to be parsed into a ref to a list
|
|
||||||
$options{legend} = [];
|
# needed for these to be parsed into an array-ref
|
||||||
$options{curvestyle} = [];
|
$options{legend} = [];
|
||||||
|
$options{curvestyle} = [];
|
||||||
|
$options{histogram} = [];
|
||||||
GetOptions($options, 'stream:s', 'domain!', 'dataid!', '3d!', 'colormap!', 'lines!', 'points!',
|
GetOptions($options, 'stream:s', 'domain!', 'dataid!', '3d!', 'colormap!', 'lines!', 'points!',
|
||||||
'circles', 'legend=s{2}', 'autolegend!', 'xlabel=s', 'ylabel=s', 'y2label=s', 'zlabel=s',
|
'circles', 'legend=s{2}', 'autolegend!', 'xlabel=s', 'ylabel=s', 'y2label=s', 'zlabel=s',
|
||||||
'title=s', 'xlen=f', 'ymin=f', 'ymax=f', 'xmin=f', 'xmax=f', 'y2min=f', 'y2max=f',
|
'title=s', 'xlen=f', 'ymin=f', 'ymax=f', 'xmin=f', 'xmax=f', 'y2min=f', 'y2max=f',
|
||||||
'zmin=f', 'zmax=f', 'y2=s@', 'curvestyle=s{2}', 'curvestyleall=s', 'extracmds=s@',
|
'zmin=f', 'zmax=f', 'y2=s@', 'curvestyle=s{2}', 'curvestyleall=s', 'extracmds=s@',
|
||||||
'size=s', 'square!', 'square_xy!', 'hardcopy=s', 'maxcurves=i', 'monotonic!',
|
'square!', 'square_xy!', 'hardcopy=s', 'maxcurves=i', 'monotonic!',
|
||||||
|
'histogram=s@', 'binwidth=f', 'histstyle=s',
|
||||||
|
'terminal=s',
|
||||||
'extraValuesPerPoint=i', 'help', 'dump',
|
'extraValuesPerPoint=i', 'help', 'dump',
|
||||||
'geometry=s') or pod2usage(1);
|
'geometry=s') or pod2usage(1);
|
||||||
|
|
||||||
@@ -112,6 +118,28 @@ sub interpretCommandline
|
|||||||
# no global style if one isn't given
|
# no global style if one isn't given
|
||||||
$options->{curvestyleall} = '' unless defined $options->{curvestyleall};
|
$options->{curvestyleall} = '' unless defined $options->{curvestyleall};
|
||||||
|
|
||||||
|
# expand options that are given as comma-separated lists
|
||||||
|
for my $listkey (qw(histogram y2))
|
||||||
|
{
|
||||||
|
@{$options{$listkey}} = map split('\s*,\s*', $_), @{$options{$listkey}}
|
||||||
|
if defined $options{$listkey};
|
||||||
|
}
|
||||||
|
|
||||||
|
# --legend and --curvestyle options are conceptually hashes, but are parsed as
|
||||||
|
# arrays in order to preserve the ordering. I parse both of these into hashes
|
||||||
|
# because those are useful to have later. After this I can access individual
|
||||||
|
# legends with $options{legend_hash}{curveid}
|
||||||
|
for my $listkey (qw(legend curvestyle))
|
||||||
|
{
|
||||||
|
$options{"${listkey}_hash"} = {};
|
||||||
|
|
||||||
|
my $n = scalar @{$options{$listkey}}/2;
|
||||||
|
foreach my $idx (0..$n-1)
|
||||||
|
{
|
||||||
|
$options{"${listkey}_hash"}{$options{$listkey}[$idx*2]} = $options{$listkey}[$idx*2 + 1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# parse stream option. Allowed only numbers >= 0 or 'trigger'
|
# parse stream option. Allowed only numbers >= 0 or 'trigger'
|
||||||
if(defined $options->{stream})
|
if(defined $options->{stream})
|
||||||
{
|
{
|
||||||
@@ -177,6 +205,12 @@ sub interpretCommandline
|
|||||||
print STDERR "--3d does not make sense with --monotonic\n";
|
print STDERR "--3d does not make sense with --monotonic\n";
|
||||||
exit -1;
|
exit -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( defined $options->{binwidth} || @{$options->{histogram}} )
|
||||||
|
{
|
||||||
|
print STDERR "--3d does not make sense with histograms\n";
|
||||||
|
exit -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -204,6 +238,12 @@ sub interpretCommandline
|
|||||||
|
|
||||||
# --xlen implies an order to the data, so I force monotonicity
|
# --xlen implies an order to the data, so I force monotonicity
|
||||||
$options{monotonic} = 1 if defined $options{xlen};
|
$options{monotonic} = 1 if defined $options{xlen};
|
||||||
|
|
||||||
|
if( $options{histstyle} !~ /freq|cum|uniq|cnorm/ )
|
||||||
|
{
|
||||||
|
print STDERR "unknown histstyle. Allowed are 'freq...', 'cum...', 'uniq...', 'cnorm...'\n";
|
||||||
|
exit -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub getGnuplotVersion
|
sub getGnuplotVersion
|
||||||
@@ -264,22 +304,25 @@ sub mainThread
|
|||||||
if( $options{hardcopy})
|
if( $options{hardcopy})
|
||||||
{
|
{
|
||||||
$outputfile = $options{hardcopy};
|
$outputfile = $options{hardcopy};
|
||||||
($outputfileType) = $outputfile =~ /\.(eps|ps|pdf|png)$/;
|
$outputfile =~ /\.(eps|ps|pdf|png|svg)$/i;
|
||||||
if(!$outputfileType) { die("Only .eps, .ps, .pdf and .png supported\n"); }
|
$outputfileType = $1 ? lc $1 : '';
|
||||||
|
|
||||||
my %terminalOpts =
|
my %terminalOpts =
|
||||||
( eps => 'postscript solid color enhanced eps',
|
( eps => 'postscript solid color enhanced eps',
|
||||||
ps => 'postscript solid color landscape 10',
|
ps => 'postscript solid color landscape 10',
|
||||||
pdf => 'pdfcairo solid color font ",10" size 11in,8.5in',
|
pdf => 'pdfcairo solid color font ",10" size 11in,8.5in',
|
||||||
png => 'png size 1280,1024' );
|
png => 'png size 1280,1024',
|
||||||
|
svg => 'svg');
|
||||||
|
|
||||||
print PIPE "set terminal $terminalOpts{$outputfileType}\n";
|
$options{terminal} ||= $terminalOpts{$outputfileType}
|
||||||
print PIPE "set output \"$outputfile\"\n";
|
if $terminalOpts{$outputfileType};
|
||||||
}
|
|
||||||
else
|
die "Asked to plot to file '$outputfile', but I don't know which terminal to use, and no --terminal given"
|
||||||
{
|
unless $options{terminal};
|
||||||
print PIPE "set terminal x11\n";
|
|
||||||
}
|
}
|
||||||
|
print PIPE "set terminal $options{terminal}\n" if $options{terminal};
|
||||||
|
print PIPE "set output \"$outputfile\"\n" if $outputfile;
|
||||||
|
|
||||||
|
|
||||||
# If a bound isn't given I want to set it to the empty string, so I can communicate it simply to
|
# If a bound isn't given I want to set it to the empty string, so I can communicate it simply to
|
||||||
# gnuplot
|
# gnuplot
|
||||||
@@ -328,15 +371,13 @@ sub mainThread
|
|||||||
# set a square aspect ratio. Gnuplot does this differently for 2D and 3D plots
|
# set a square aspect ratio. Gnuplot does this differently for 2D and 3D plots
|
||||||
if(! $options{'3d'})
|
if(! $options{'3d'})
|
||||||
{
|
{
|
||||||
$options{size} = '' unless defined $options{size};
|
print(PIPE "set size ratio -1\n");
|
||||||
$options{size} .= ' ratio -1';
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
print(PIPE "set view equal xyz\n");
|
print(PIPE "set view equal xyz\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
print(PIPE "set size $options{size}\n") if defined $options{size};
|
|
||||||
|
|
||||||
if($options{square_xy})
|
if($options{square_xy})
|
||||||
{
|
{
|
||||||
@@ -351,7 +392,10 @@ sub mainThread
|
|||||||
# For the specified values, set the legend entries to 'title "blah blah"'
|
# For the specified values, set the legend entries to 'title "blah blah"'
|
||||||
if(@{$options{legend}})
|
if(@{$options{legend}})
|
||||||
{
|
{
|
||||||
# @{$options{legend}} is a list where consecutive pairs are (curveID, legend)
|
# @{$options{legend}} is a list where consecutive pairs are (curveID,
|
||||||
|
# legend). I use $options{legend} here instead of $options{legend_hash}
|
||||||
|
# because I create a new curve when I see a new one, and the hash is
|
||||||
|
# unordered, thus messing up the ordering
|
||||||
my $n = scalar @{$options{legend}}/2;
|
my $n = scalar @{$options{legend}}/2;
|
||||||
foreach my $idx (0..$n-1)
|
foreach my $idx (0..$n-1)
|
||||||
{
|
{
|
||||||
@@ -363,7 +407,10 @@ sub mainThread
|
|||||||
# add the extra curve options
|
# add the extra curve options
|
||||||
if(@{$options{curvestyle}})
|
if(@{$options{curvestyle}})
|
||||||
{
|
{
|
||||||
# @{$options{curvestyle}} is a list where consecutive pairs are (curveID, style)
|
# @{$options{curvestyle}} is a list where consecutive pairs are (curveID,
|
||||||
|
# style). I use $options{curvestyle} here instead of
|
||||||
|
# $options{curvestyle_hash} because I create a new curve when I see a new
|
||||||
|
# one, and the hash is unordered, thus messing up the ordering
|
||||||
my $n = scalar @{$options{curvestyle}}/2;
|
my $n = scalar @{$options{curvestyle}}/2;
|
||||||
foreach my $idx (0..$n-1)
|
foreach my $idx (0..$n-1)
|
||||||
{
|
{
|
||||||
@@ -387,6 +434,16 @@ sub mainThread
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# set up histograms
|
||||||
|
$options{binwidth} ||= 1; # if no binwidth given, set it to 1
|
||||||
|
print PIPE
|
||||||
|
"set boxwidth $options{binwidth}\n" .
|
||||||
|
"histbin(x) = $options{binwidth} * floor(0.5 + x/$options{binwidth})\n";
|
||||||
|
foreach (@{$options{histogram}})
|
||||||
|
{
|
||||||
|
setCurveAsHistogram( $_ );
|
||||||
|
}
|
||||||
|
|
||||||
# regexp for a possibly floating point, possibly scientific notation number
|
# regexp for a possibly floating point, possibly scientific notation number
|
||||||
my $numRE = '-?\d*\.?\d+(?:[Ee][-+]?\d+)?';
|
my $numRE = '-?\d*\.?\d+(?:[Ee][-+]?\d+)?';
|
||||||
|
|
||||||
@@ -563,8 +620,14 @@ sub updateCurveOptions
|
|||||||
{ $title = $id; }
|
{ $title = $id; }
|
||||||
|
|
||||||
my $titleoption = defined $title ? "title \"$title\"" : "notitle";
|
my $titleoption = defined $title ? "title \"$title\"" : "notitle";
|
||||||
my $extraoption = defined $options{curvestyleall} ? $options{curvestyleall} : '';
|
|
||||||
$curveoptions->{options} = "$titleoption $curveoptions->{extraoptions} $extraoption";
|
my $curvestyleall = '';
|
||||||
|
$curvestyleall = $options{curvestyleall}
|
||||||
|
if defined $options{curvestyleall} && !defined $options{curvestyle_hash}{$id};
|
||||||
|
|
||||||
|
my $histoptions = $curveoptions->{histoptions} || '';
|
||||||
|
|
||||||
|
$curveoptions->{options} = "$histoptions $titleoption $curveoptions->{extraoptions} $curvestyleall";
|
||||||
}
|
}
|
||||||
|
|
||||||
sub getCurve
|
sub getCurve
|
||||||
@@ -609,6 +672,16 @@ sub setCurveLabel
|
|||||||
updateCurveOptions($curve->[0], $id);
|
updateCurveOptions($curve->[0], $id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub setCurveAsHistogram
|
||||||
|
{
|
||||||
|
my ($id, $str) = @_;
|
||||||
|
|
||||||
|
my $curve = getCurve($id);
|
||||||
|
$curve->[0]{histoptions} = 'using (histbin($2)):(1.0) smooth ' . $options{histstyle};
|
||||||
|
|
||||||
|
updateCurveOptions($curve->[0], $id);
|
||||||
|
}
|
||||||
|
|
||||||
# remove all the curve data
|
# remove all the curve data
|
||||||
sub clearCurves
|
sub clearCurves
|
||||||
{
|
{
|
||||||
@@ -622,372 +695,3 @@ sub pushPoint
|
|||||||
my ($curve, $xy) = @_;
|
my ($curve, $xy) = @_;
|
||||||
push @$curve, $xy;
|
push @$curve, $xy;
|
||||||
}
|
}
|
||||||
|
|
||||||
__END__
|
|
||||||
|
|
||||||
=head1 NAME
|
|
||||||
|
|
||||||
feedgnuplot - Pipe-oriented frontend to Gnuplot
|
|
||||||
|
|
||||||
=head1 SYNOPSIS
|
|
||||||
|
|
||||||
Simple plotting of stored data:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}'
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' |
|
|
||||||
feedgnuplot --lines --points --legend 0 "data 0" --title "Test plot" --y2 1
|
|
||||||
|
|
||||||
Simple real-time plotting example: plot how much data is received on the wlan0
|
|
||||||
network interface in bytes/second (uses bash, awk and Linux):
|
|
||||||
|
|
||||||
$ while true; do sleep 1; cat /proc/net/dev; done |
|
|
||||||
gawk '/wlan0/ {if(b) {print $2-b; fflush()} b=$2}' |
|
|
||||||
feedgnuplot --lines --stream --xlen 10 --ylabel 'Bytes/sec' --xlabel seconds
|
|
||||||
|
|
||||||
=head1 DESCRIPTION
|
|
||||||
|
|
||||||
This is a flexible, command-line-oriented frontend to Gnuplot. It creates
|
|
||||||
plots from data coming in on STDIN or given in a filename passed on the
|
|
||||||
commandline. Various data representations are supported, as is hardcopy
|
|
||||||
output and streaming display of live data. A simple example:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot
|
|
||||||
|
|
||||||
You should see a plot with two curves. The C<awk> command generates some data to
|
|
||||||
plot and the C<feedgnuplot> reads it in from STDIN and generates the plot. The
|
|
||||||
C<awk> invocation is just an example; more interesting things would be plotted
|
|
||||||
in normal usage. No commandline-options are required for the most basic
|
|
||||||
plotting. Input parsing is flexible; every line need not have the same number of
|
|
||||||
points. New curves will be created as needed.
|
|
||||||
|
|
||||||
The most commonly used functionality of gnuplot is supported directly by the
|
|
||||||
script. Anything not directly supported can still be done with the
|
|
||||||
C<--extracmds> and C<--curvestyle> options. Arbitrary gnuplot commands can be
|
|
||||||
passed in with C<--extracmds>. For example, to turn off the grid, pass in
|
|
||||||
C<--extracmds 'unset grid'>. As many of these options as needed can be passed
|
|
||||||
in. To add arbitrary curve styles, use C<--curvestyle curveID extrastyle>. Pass
|
|
||||||
these more than once to affect more than one curve. To apply an extra style to
|
|
||||||
I<all> the curves, pass in C<--curvestyleall extrastyle>.
|
|
||||||
|
|
||||||
=head2 Data formats
|
|
||||||
|
|
||||||
By default, each value present in the incoming data represents a distinct data
|
|
||||||
point, as demonstrated in the original example above (we had 10 numbers in the
|
|
||||||
input and 10 points in the plot). If requested, the script supports more
|
|
||||||
sophisticated interpretation of input data
|
|
||||||
|
|
||||||
=head3 Domain selection
|
|
||||||
|
|
||||||
If C<--domain> is passed in, the first value on each line of input is
|
|
||||||
interpreted as the I<X>-value for the rest of the data on that line. Without
|
|
||||||
C<--domain> the I<X>-value is the line number, and the first value on a line is
|
|
||||||
a plain data point like the others. Default is C<--nodomain>. Thus the original
|
|
||||||
example above produces 2 curves, with B<1,2,3,4,5> as the I<X>-values. If we run
|
|
||||||
the same command with --domain:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --domain
|
|
||||||
|
|
||||||
we get only 1 curve, with B<2,4,6,8,10> as the I<X>-values. As many points as
|
|
||||||
desired can appear on a single line, but all points on a line are associated
|
|
||||||
with the I<X>-value at the start of that line.
|
|
||||||
|
|
||||||
=head3 Curve indexing
|
|
||||||
|
|
||||||
By default, each column represents a separate curve. This is fine unless sparse
|
|
||||||
data is to be plotted. With the C<--dataid> option, each point is represented by
|
|
||||||
2 values: a string identifying the curve, and the value itself. If we add
|
|
||||||
C<--dataid> to the original example:
|
|
||||||
|
|
||||||
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --dataid --autolegend
|
|
||||||
|
|
||||||
we get 5 different curves with one point in each. The first column, as produced
|
|
||||||
by C<awk>, is B<2,4,6,8,10>. These are interpreted as the IDs of the curves to
|
|
||||||
be plotted. The C<--autolegend> option adds a legend using the given IDs to
|
|
||||||
label the curves. The IDs need not be numbers; generic strings are accepted. As
|
|
||||||
many points as desired can appear on a single line. C<--domain> can be used in
|
|
||||||
conjunction with C<--dataid>.
|
|
||||||
|
|
||||||
=head3 Multi-value style support
|
|
||||||
|
|
||||||
Depending on how gnuplot is plotting the data, more than one value may be needed
|
|
||||||
to represent a single point. For example, the script has support to plot all the
|
|
||||||
data with C<--circles>. This requires a radius to be specified for each point in
|
|
||||||
addition to the position of the point. Thus, when plotting with C<--circles>, 2
|
|
||||||
numbers are read for each data point instead of 1. A similar situation exists
|
|
||||||
with C<--colormap> where each point contains the position I<and> the
|
|
||||||
color. There are other gnuplot styles that require more data (such as error
|
|
||||||
bars), but none of these are directly supported by the script. They can still be
|
|
||||||
used, though, by specifying the specific style with C<--curvestyle>, and
|
|
||||||
specifying how many extra values are needed for each point with
|
|
||||||
C<--extraValuesPerPoint extra>. C<--extraValuesPerPoint> is ONLY needed for the
|
|
||||||
styles not explicitly supported; supported styles set that variable
|
|
||||||
automatically.
|
|
||||||
|
|
||||||
=head3 3D data
|
|
||||||
|
|
||||||
To plot 3D data, pass in C<--3d>. C<--domain> MUST be given when plotting 3D
|
|
||||||
data to avoid domain ambiguity. If 3D data is being plotted, there are by
|
|
||||||
definition 2 domain values instead of one (I<Z> as a function of I<X> and I<Y>
|
|
||||||
instead of I<Y> as a function of I<X>). Thus the first 2 values on each line are
|
|
||||||
interpreted as the domain instead of just 1. The rest of the processing happens
|
|
||||||
the same way as before.
|
|
||||||
|
|
||||||
=head3 Special data commands
|
|
||||||
|
|
||||||
Other than the raw data, 2 special commands are interpreted if they appear in
|
|
||||||
the input. These are C<replot> and C<clear>. If a line of data begins with
|
|
||||||
C<replot> and we're plotting in realtime with C<--stream>, the plot will be
|
|
||||||
refreshed immediately. If a line of data begins with C<clear>, the plot is
|
|
||||||
cleared, to be re-filled with any data following the C<clear>.
|
|
||||||
|
|
||||||
=head2 Real-time streaming data
|
|
||||||
|
|
||||||
To plot real-time data, pass in the C<--stream [refreshperiod]> option. Data
|
|
||||||
will then be plotted as it is received. The plot will be updated every
|
|
||||||
C<refreshperiod> seconds. If the period isn't specified, a 1Hz refresh rate is
|
|
||||||
used. To refresh at specific intervals indicated by the data, set the
|
|
||||||
refreshperiod to 0 or to 'trigger'. The plot will then I<only> be refreshed when
|
|
||||||
a data line 'replot' is received. This 'replot' command works in both triggered
|
|
||||||
and timed modes, but in triggered mode, it's the only way to replot.
|
|
||||||
|
|
||||||
To plot only the most recent data (instead of I<all> the data), C<--xlen
|
|
||||||
windowsize> can be given. This will create an constantly-updating, scrolling
|
|
||||||
view of the recent past. C<windowsize> should be replaced by the desired length
|
|
||||||
of the domain window to plot, in domain units (passed-in values if C<--domain>
|
|
||||||
or line numbers otherwise).
|
|
||||||
|
|
||||||
=head2 Hardcopy output
|
|
||||||
|
|
||||||
The script is able to produce hardcopy output with C<--hardcopy outputfile>. The
|
|
||||||
output type is inferred from the filename with B<.ps>, B<.eps>, B<.pdf> and
|
|
||||||
B<.png> currently supported.
|
|
||||||
|
|
||||||
=head2 Self-plotting data files
|
|
||||||
|
|
||||||
This script can be used to enable self-plotting data files. There are 2 ways of
|
|
||||||
doing this: with a shebang (#!) or with inline perl data.
|
|
||||||
|
|
||||||
=head3 Self-plotting data with a #!
|
|
||||||
|
|
||||||
A self-plotting, executable data file C<data> is formatted as
|
|
||||||
|
|
||||||
$ cat data
|
|
||||||
#!/usr/bin/feedgnuplot --lines --points
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
12 36
|
|
||||||
14 49
|
|
||||||
16 64
|
|
||||||
18 81
|
|
||||||
20 100
|
|
||||||
22 121
|
|
||||||
24 144
|
|
||||||
26 169
|
|
||||||
28 196
|
|
||||||
30 225
|
|
||||||
|
|
||||||
This is the shebang (#!) line followed by the data, formatted as before. The
|
|
||||||
data file can be plotted simply with
|
|
||||||
|
|
||||||
$ ./data
|
|
||||||
|
|
||||||
The caveats here are that on Linux the whole #! line is limited to 127 charaters
|
|
||||||
and that the full path to feedgnuplot must be given. The 127 character limit is
|
|
||||||
a serious limitation, but this can likely be resolved with a kernel patch. I
|
|
||||||
have only tried on Linux 2.6.
|
|
||||||
|
|
||||||
=head3 Self-plotting data with perl inline data
|
|
||||||
|
|
||||||
Perl supports storing data and code in the same file. This can also be used to
|
|
||||||
create self-plotting files:
|
|
||||||
|
|
||||||
$ cat plotdata.pl
|
|
||||||
#!/usr/bin/perl
|
|
||||||
use strict;
|
|
||||||
use warnings;
|
|
||||||
|
|
||||||
open PLOT, "| feedgnuplot --lines --points" or die "Couldn't open plotting pipe";
|
|
||||||
while( <DATA> )
|
|
||||||
{
|
|
||||||
my @xy = split;
|
|
||||||
print PLOT "@xy\n";
|
|
||||||
}
|
|
||||||
__DATA__
|
|
||||||
2 1
|
|
||||||
4 4
|
|
||||||
6 9
|
|
||||||
8 16
|
|
||||||
10 25
|
|
||||||
12 36
|
|
||||||
14 49
|
|
||||||
16 64
|
|
||||||
18 81
|
|
||||||
20 100
|
|
||||||
22 121
|
|
||||||
24 144
|
|
||||||
26 169
|
|
||||||
28 196
|
|
||||||
30 225
|
|
||||||
|
|
||||||
This is especially useful if the logged data is not in a format directly
|
|
||||||
supported by feedgnuplot. Raw data can be stored after the __DATA__ directive,
|
|
||||||
with a small perl script to manipulate the data into a useable format and send
|
|
||||||
it to the plotter.
|
|
||||||
|
|
||||||
=head1 ARGUMENTS
|
|
||||||
|
|
||||||
--[no]domain If enabled, the first element of each line is the
|
|
||||||
domain variable. If not, the point index is used
|
|
||||||
|
|
||||||
--[no]dataid If enabled, each data point is preceded by the ID
|
|
||||||
of the data set that point corresponds to. This ID is
|
|
||||||
interpreted as a string, NOT as just a number. If not
|
|
||||||
enabled, the order of the point is used.
|
|
||||||
|
|
||||||
As an example, if line 3 of the input is "0 9 1 20"
|
|
||||||
'--nodomain --nodataid' would parse the 4 numbers as points in 4
|
|
||||||
different curves at x=3
|
|
||||||
|
|
||||||
'--domain --nodataid' would parse the 4 numbers as points in 3 different
|
|
||||||
curves at x=0. Here, 0 is the x-variable and 9,1,20 are the data values
|
|
||||||
|
|
||||||
'--nodomain --dataid' would parse the 4 numbers as points in 2 different
|
|
||||||
curves at x=3. Here 0 and 1 are the data IDs and 9 and 20 are the
|
|
||||||
data values
|
|
||||||
|
|
||||||
'--domain --dataid' would parse the 4 numbers as a single point at
|
|
||||||
x=0. Here 9 is the data ID and 1 is the data value. 20 is an extra
|
|
||||||
value, so it is ignored. If another value followed 20, we'd get another
|
|
||||||
point in curve ID 20
|
|
||||||
|
|
||||||
--[no]3d Do [not] plot in 3D. This only makes sense with --domain.
|
|
||||||
Each domain here is an (x,y) tuple
|
|
||||||
|
|
||||||
--colormap Show a colormapped xy plot. Requires extra data for the color.
|
|
||||||
zmin/zmax can be used to set the extents of the colors.
|
|
||||||
Automatically increments extraValuesPerPoint
|
|
||||||
|
|
||||||
--stream [period] Plot the data as it comes in, in realtime. If period is given,
|
|
||||||
replot every period seconds. If no period is given, replot at
|
|
||||||
1Hz. If the period is given as 0 or 'trigger', replot ONLY when
|
|
||||||
the incoming data dictates this . See the "Real-time streaming
|
|
||||||
data" section of the man page.
|
|
||||||
|
|
||||||
--[no]lines Do [not] draw lines to connect consecutive points
|
|
||||||
--[no]points Do [not] draw points
|
|
||||||
--circles Plot with circles. This requires a radius be specified for
|
|
||||||
each point. Automatically increments extraValuesPerPoint
|
|
||||||
|
|
||||||
--xlabel xxx Set x-axis label
|
|
||||||
--ylabel xxx Set y-axis label
|
|
||||||
--y2label xxx Set y2-axis label. Does not apply to 3d plots
|
|
||||||
--zlabel xxx Set y-axis label. Only applies to 3d plots
|
|
||||||
|
|
||||||
--title xxx Set the title of the plot
|
|
||||||
|
|
||||||
--legend curveID legend
|
|
||||||
Set the label for a curve plot. Use this option multiple times
|
|
||||||
for multiple curves. With --dataid, curveID is the ID. Otherwise,
|
|
||||||
it's the index of the curve, starting at 0
|
|
||||||
|
|
||||||
--autolegend Use the curve IDs for the legend. Titles given with --legend
|
|
||||||
override these
|
|
||||||
|
|
||||||
--xlen xxx When using --stream, sets the size of the x-window to plot.
|
|
||||||
Omit this or set it to 0 to plot ALL the data. Does not
|
|
||||||
make sense with 3d plots. Implies --monotonic
|
|
||||||
|
|
||||||
--xmin xxx Set the range for the x axis. These are ignored in a
|
|
||||||
streaming plot
|
|
||||||
--xmax xxx Set the range for the x axis. These are ignored in a
|
|
||||||
streaming plot
|
|
||||||
--ymin xxx Set the range for the y axis.
|
|
||||||
--ymax xxx Set the range for the y axis.
|
|
||||||
--y2min xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
|
||||||
--y2max xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
|
||||||
--zmin xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
|
||||||
--zmax xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
|
||||||
|
|
||||||
--y2 xxx Plot the data specified by this curve ID on the y2 axis.
|
|
||||||
Without --dataid, the ID is just an ordered 0-based index.
|
|
||||||
Does not apply to 3d plots.
|
|
||||||
|
|
||||||
--curvestyle curveID style
|
|
||||||
Additional styles per curve. With --dataid, curveID is the
|
|
||||||
ID. Otherwise, it's the index of the curve, starting at 0. Use
|
|
||||||
this option multiple times for multiple curves
|
|
||||||
|
|
||||||
--curvestyleall xxx Additional styles for ALL curves.
|
|
||||||
|
|
||||||
--extracmds xxx Additional commands. These could contain extra global styles
|
|
||||||
for instance
|
|
||||||
|
|
||||||
--size xxx Gnuplot size option
|
|
||||||
|
|
||||||
--square Plot data with aspect ratio 1. For 3D plots, this controls the
|
|
||||||
aspect ratio for all 3 axes
|
|
||||||
|
|
||||||
--square_xy For 3D plots, set square aspect ratio for ONLY the x,y axes
|
|
||||||
|
|
||||||
--hardcopy xxx If not streaming, output to a file specified here. Format
|
|
||||||
inferred from filename
|
|
||||||
|
|
||||||
--maxcurves xxx The maximum allowed number of curves. This is 100 by default,
|
|
||||||
but can be reset with this option. This exists purely to
|
|
||||||
prevent perl from allocating all of the system's memory when
|
|
||||||
reading bogus data
|
|
||||||
|
|
||||||
--monotonic If --domain is given, checks to make sure that the x-
|
|
||||||
coordinate in the input data is monotonically increasing.
|
|
||||||
If a given x-variable is in the past, all data currently
|
|
||||||
cached for this curve is purged. Without --monotonic, all
|
|
||||||
data is kept. Does not make sense with 3d plots.
|
|
||||||
No --monotonic by default.
|
|
||||||
|
|
||||||
--extraValuesPerPoint xxx
|
|
||||||
How many extra values are given for each data point. Normally this
|
|
||||||
is 0, and does not need to be specified, but sometimes we want
|
|
||||||
extra data, like for colors or point sizes or error bars, etc.
|
|
||||||
feedgnuplot options that require this (colormap, circles)
|
|
||||||
automatically set it. This option is ONLY needed if unknown styles are
|
|
||||||
used, with --curvestyleall for instance
|
|
||||||
|
|
||||||
--dump Instead of printing to gnuplot, print to STDOUT. For
|
|
||||||
debugging.
|
|
||||||
|
|
||||||
--geometry If using X11, specifies the size, position of the plot window
|
|
||||||
|
|
||||||
=head1 ACKNOWLEDGEMENT
|
|
||||||
|
|
||||||
This program is originally based on the driveGnuPlots.pl script from
|
|
||||||
Thanassis Tsiodras. It is available from his site at
|
|
||||||
L<http://users.softlab.ece.ntua.gr/~ttsiod/gnuplotStreaming.html>
|
|
||||||
|
|
||||||
=head1 REPOSITORY
|
|
||||||
|
|
||||||
L<https://github.com/dkogan/feedgnuplot>
|
|
||||||
|
|
||||||
=head1 AUTHOR
|
|
||||||
|
|
||||||
Dima Kogan, C<< <dima@secretsauce.net> >>
|
|
||||||
|
|
||||||
=head1 LICENSE AND COPYRIGHT
|
|
||||||
|
|
||||||
Copyright 2011 Dima Kogan.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of either: the GNU General Public License as published
|
|
||||||
by the Free Software Foundation; or the Artistic License.
|
|
||||||
|
|
||||||
See http://dev.perl.org/licenses/ for more information.
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
396
bin/feedgnuplot.pod
Normal file
396
bin/feedgnuplot.pod
Normal file
@@ -0,0 +1,396 @@
|
|||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
feedgnuplot - Pipe-oriented frontend to Gnuplot
|
||||||
|
|
||||||
|
=head1 SYNOPSIS
|
||||||
|
|
||||||
|
Simple plotting of stored data:
|
||||||
|
|
||||||
|
$ seq 5 | awk '{print 2*$1, $1*$1}'
|
||||||
|
2 1
|
||||||
|
4 4
|
||||||
|
6 9
|
||||||
|
8 16
|
||||||
|
10 25
|
||||||
|
|
||||||
|
$ seq 5 | awk '{print 2*$1, $1*$1}' |
|
||||||
|
feedgnuplot --lines --points --legend 0 "data 0" --title "Test plot" --y2 1
|
||||||
|
|
||||||
|
Simple real-time plotting example: plot how much data is received on the wlan0
|
||||||
|
network interface in bytes/second (uses bash, awk and Linux):
|
||||||
|
|
||||||
|
$ while true; do sleep 1; cat /proc/net/dev; done |
|
||||||
|
gawk '/wlan0/ {if(b) {print $2-b; fflush()} b=$2}' |
|
||||||
|
feedgnuplot --lines --stream --xlen 10 --ylabel 'Bytes/sec' --xlabel seconds
|
||||||
|
|
||||||
|
=head1 DESCRIPTION
|
||||||
|
|
||||||
|
This is a flexible, command-line-oriented frontend to Gnuplot. It creates
|
||||||
|
plots from data coming in on STDIN or given in a filename passed on the
|
||||||
|
commandline. Various data representations are supported, as is hardcopy
|
||||||
|
output and streaming display of live data. A simple example:
|
||||||
|
|
||||||
|
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot
|
||||||
|
|
||||||
|
You should see a plot with two curves. The C<awk> command generates some data to
|
||||||
|
plot and the C<feedgnuplot> reads it in from STDIN and generates the plot. The
|
||||||
|
C<awk> invocation is just an example; more interesting things would be plotted
|
||||||
|
in normal usage. No commandline-options are required for the most basic
|
||||||
|
plotting. Input parsing is flexible; every line need not have the same number of
|
||||||
|
points. New curves will be created as needed.
|
||||||
|
|
||||||
|
The most commonly used functionality of gnuplot is supported directly by the
|
||||||
|
script. Anything not directly supported can still be done with the
|
||||||
|
C<--extracmds> and C<--curvestyle> options. Arbitrary gnuplot commands can be
|
||||||
|
passed in with C<--extracmds>. For example, to turn off the grid, pass in
|
||||||
|
C<--extracmds 'unset grid'>. As many of these options as needed can be passed
|
||||||
|
in. To add arbitrary curve styles, use C<--curvestyle curveID extrastyle>. Pass
|
||||||
|
these more than once to affect more than one curve. To apply an extra style to
|
||||||
|
I<all> the curves that lack an explicit C<--curvestyle>, pass in
|
||||||
|
C<--curvestyleall extrastyle>.
|
||||||
|
|
||||||
|
=head2 Data formats
|
||||||
|
|
||||||
|
By default, each value present in the incoming data represents a distinct data
|
||||||
|
point, as demonstrated in the original example above (we had 10 numbers in the
|
||||||
|
input and 10 points in the plot). If requested, the script supports more
|
||||||
|
sophisticated interpretation of input data
|
||||||
|
|
||||||
|
=head3 Domain selection
|
||||||
|
|
||||||
|
If C<--domain> is passed in, the first value on each line of input is
|
||||||
|
interpreted as the I<X>-value for the rest of the data on that line. Without
|
||||||
|
C<--domain> the I<X>-value is the line number, and the first value on a line is
|
||||||
|
a plain data point like the others. Default is C<--nodomain>. Thus the original
|
||||||
|
example above produces 2 curves, with B<1,2,3,4,5> as the I<X>-values. If we run
|
||||||
|
the same command with --domain:
|
||||||
|
|
||||||
|
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --domain
|
||||||
|
|
||||||
|
we get only 1 curve, with B<2,4,6,8,10> as the I<X>-values. As many points as
|
||||||
|
desired can appear on a single line, but all points on a line are associated
|
||||||
|
with the I<X>-value at the start of that line.
|
||||||
|
|
||||||
|
=head3 Curve indexing
|
||||||
|
|
||||||
|
By default, each column represents a separate curve. This is fine unless sparse
|
||||||
|
data is to be plotted. With the C<--dataid> option, each point is represented by
|
||||||
|
2 values: a string identifying the curve, and the value itself. If we add
|
||||||
|
C<--dataid> to the original example:
|
||||||
|
|
||||||
|
$ seq 5 | awk '{print 2*$1, $1*$1}' | feedgnuplot --dataid --autolegend
|
||||||
|
|
||||||
|
we get 5 different curves with one point in each. The first column, as produced
|
||||||
|
by C<awk>, is B<2,4,6,8,10>. These are interpreted as the IDs of the curves to
|
||||||
|
be plotted. The C<--autolegend> option adds a legend using the given IDs to
|
||||||
|
label the curves. The IDs need not be numbers; generic strings are accepted. As
|
||||||
|
many points as desired can appear on a single line. C<--domain> can be used in
|
||||||
|
conjunction with C<--dataid>.
|
||||||
|
|
||||||
|
=head3 Multi-value style support
|
||||||
|
|
||||||
|
Depending on how gnuplot is plotting the data, more than one value may be needed
|
||||||
|
to represent a single point. For example, the script has support to plot all the
|
||||||
|
data with C<--circles>. This requires a radius to be specified for each point in
|
||||||
|
addition to the position of the point. Thus, when plotting with C<--circles>, 2
|
||||||
|
numbers are read for each data point instead of 1. A similar situation exists
|
||||||
|
with C<--colormap> where each point contains the position I<and> the
|
||||||
|
color. There are other gnuplot styles that require more data (such as error
|
||||||
|
bars), but none of these are directly supported by the script. They can still be
|
||||||
|
used, though, by specifying the specific style with C<--curvestyle>, and
|
||||||
|
specifying how many extra values are needed for each point with
|
||||||
|
C<--extraValuesPerPoint extra>. C<--extraValuesPerPoint> is ONLY needed for the
|
||||||
|
styles not explicitly supported; supported styles set that variable
|
||||||
|
automatically.
|
||||||
|
|
||||||
|
=head3 3D data
|
||||||
|
|
||||||
|
To plot 3D data, pass in C<--3d>. C<--domain> MUST be given when plotting 3D
|
||||||
|
data to avoid domain ambiguity. If 3D data is being plotted, there are by
|
||||||
|
definition 2 domain values instead of one (I<Z> as a function of I<X> and I<Y>
|
||||||
|
instead of I<Y> as a function of I<X>). Thus the first 2 values on each line are
|
||||||
|
interpreted as the domain instead of just 1. The rest of the processing happens
|
||||||
|
the same way as before.
|
||||||
|
|
||||||
|
=head3 Special data commands
|
||||||
|
|
||||||
|
Other than the raw data, 2 special commands are interpreted if they appear in
|
||||||
|
the input. These are C<replot> and C<clear>. If a line of data begins with
|
||||||
|
C<replot> and we're plotting in realtime with C<--stream>, the plot will be
|
||||||
|
refreshed immediately. If a line of data begins with C<clear>, the plot is
|
||||||
|
cleared, to be re-filled with any data following the C<clear>.
|
||||||
|
|
||||||
|
=head2 Real-time streaming data
|
||||||
|
|
||||||
|
To plot real-time data, pass in the C<--stream [refreshperiod]> option. Data
|
||||||
|
will then be plotted as it is received. The plot will be updated every
|
||||||
|
C<refreshperiod> seconds. If the period isn't specified, a 1Hz refresh rate is
|
||||||
|
used. To refresh at specific intervals indicated by the data, set the
|
||||||
|
refreshperiod to 0 or to 'trigger'. The plot will then I<only> be refreshed when
|
||||||
|
a data line 'replot' is received. This 'replot' command works in both triggered
|
||||||
|
and timed modes, but in triggered mode, it's the only way to replot.
|
||||||
|
|
||||||
|
To plot only the most recent data (instead of I<all> the data), C<--xlen
|
||||||
|
windowsize> can be given. This will create an constantly-updating, scrolling
|
||||||
|
view of the recent past. C<windowsize> should be replaced by the desired length
|
||||||
|
of the domain window to plot, in domain units (passed-in values if C<--domain>
|
||||||
|
or line numbers otherwise).
|
||||||
|
|
||||||
|
=head2 Hardcopy output
|
||||||
|
|
||||||
|
The script is able to produce hardcopy output with C<--hardcopy outputfile>. The
|
||||||
|
output type can be inferred from the filename, if B<.ps>, B<.eps>, B<.pdf>,
|
||||||
|
B<.svg> or B<.png> is requested. If any other file type is requested,
|
||||||
|
C<--terminal> I<must> be passed in to tell gnuplot how to make the plot.
|
||||||
|
|
||||||
|
=head2 Self-plotting data files
|
||||||
|
|
||||||
|
This script can be used to enable self-plotting data files. There are 2 ways of
|
||||||
|
doing this: with a shebang (#!) or with inline perl data.
|
||||||
|
|
||||||
|
=head3 Self-plotting data with a #!
|
||||||
|
|
||||||
|
A self-plotting, executable data file C<data> is formatted as
|
||||||
|
|
||||||
|
$ cat data
|
||||||
|
#!/usr/bin/feedgnuplot --lines --points
|
||||||
|
2 1
|
||||||
|
4 4
|
||||||
|
6 9
|
||||||
|
8 16
|
||||||
|
10 25
|
||||||
|
12 36
|
||||||
|
14 49
|
||||||
|
16 64
|
||||||
|
18 81
|
||||||
|
20 100
|
||||||
|
22 121
|
||||||
|
24 144
|
||||||
|
26 169
|
||||||
|
28 196
|
||||||
|
30 225
|
||||||
|
|
||||||
|
This is the shebang (#!) line followed by the data, formatted as before. The
|
||||||
|
data file can be plotted simply with
|
||||||
|
|
||||||
|
$ ./data
|
||||||
|
|
||||||
|
The caveats here are that on Linux the whole #! line is limited to 127 charaters
|
||||||
|
and that the full path to feedgnuplot must be given. The 127 character limit is
|
||||||
|
a serious limitation, but this can likely be resolved with a kernel patch. I
|
||||||
|
have only tried on Linux 2.6.
|
||||||
|
|
||||||
|
=head3 Self-plotting data with perl inline data
|
||||||
|
|
||||||
|
Perl supports storing data and code in the same file. This can also be used to
|
||||||
|
create self-plotting files:
|
||||||
|
|
||||||
|
$ cat plotdata.pl
|
||||||
|
#!/usr/bin/perl
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
open PLOT, "| feedgnuplot --lines --points" or die "Couldn't open plotting pipe";
|
||||||
|
while( <DATA> )
|
||||||
|
{
|
||||||
|
my @xy = split;
|
||||||
|
print PLOT "@xy\n";
|
||||||
|
}
|
||||||
|
__DATA__
|
||||||
|
2 1
|
||||||
|
4 4
|
||||||
|
6 9
|
||||||
|
8 16
|
||||||
|
10 25
|
||||||
|
12 36
|
||||||
|
14 49
|
||||||
|
16 64
|
||||||
|
18 81
|
||||||
|
20 100
|
||||||
|
22 121
|
||||||
|
24 144
|
||||||
|
26 169
|
||||||
|
28 196
|
||||||
|
30 225
|
||||||
|
|
||||||
|
This is especially useful if the logged data is not in a format directly
|
||||||
|
supported by feedgnuplot. Raw data can be stored after the __DATA__ directive,
|
||||||
|
with a small perl script to manipulate the data into a useable format and send
|
||||||
|
it to the plotter.
|
||||||
|
|
||||||
|
=head1 ARGUMENTS
|
||||||
|
|
||||||
|
--[no]domain If enabled, the first element of each line is the
|
||||||
|
domain variable. If not, the point index is used
|
||||||
|
|
||||||
|
--[no]dataid If enabled, each data point is preceded by the ID
|
||||||
|
of the data set that point corresponds to. This ID is
|
||||||
|
interpreted as a string, NOT as just a number. If not
|
||||||
|
enabled, the order of the point is used.
|
||||||
|
|
||||||
|
As an example, if line 3 of the input is "0 9 1 20"
|
||||||
|
'--nodomain --nodataid' would parse the 4 numbers as points in 4
|
||||||
|
different curves at x=3
|
||||||
|
|
||||||
|
'--domain --nodataid' would parse the 4 numbers as points in 3 different
|
||||||
|
curves at x=0. Here, 0 is the x-variable and 9,1,20 are the data values
|
||||||
|
|
||||||
|
'--nodomain --dataid' would parse the 4 numbers as points in 2 different
|
||||||
|
curves at x=3. Here 0 and 1 are the data IDs and 9 and 20 are the
|
||||||
|
data values
|
||||||
|
|
||||||
|
'--domain --dataid' would parse the 4 numbers as a single point at
|
||||||
|
x=0. Here 9 is the data ID and 1 is the data value. 20 is an extra
|
||||||
|
value, so it is ignored. If another value followed 20, we'd get another
|
||||||
|
point in curve ID 20
|
||||||
|
|
||||||
|
--[no]3d Do [not] plot in 3D. This only makes sense with --domain.
|
||||||
|
Each domain here is an (x,y) tuple
|
||||||
|
|
||||||
|
--colormap Show a colormapped xy plot. Requires extra data for the color.
|
||||||
|
zmin/zmax can be used to set the extents of the colors.
|
||||||
|
Automatically increments extraValuesPerPoint
|
||||||
|
|
||||||
|
--stream [period] Plot the data as it comes in, in realtime. If period is given,
|
||||||
|
replot every period seconds. If no period is given, replot at
|
||||||
|
1Hz. If the period is given as 0 or 'trigger', replot ONLY when
|
||||||
|
the incoming data dictates this . See the "Real-time streaming
|
||||||
|
data" section of the man page.
|
||||||
|
|
||||||
|
--[no]lines Do [not] draw lines to connect consecutive points
|
||||||
|
--[no]points Do [not] draw points
|
||||||
|
--circles Plot with circles. This requires a radius be specified for
|
||||||
|
each point. Automatically increments extraValuesPerPoint
|
||||||
|
|
||||||
|
--xlabel xxx Set x-axis label
|
||||||
|
--ylabel xxx Set y-axis label
|
||||||
|
--y2label xxx Set y2-axis label. Does not apply to 3d plots
|
||||||
|
--zlabel xxx Set y-axis label. Only applies to 3d plots
|
||||||
|
|
||||||
|
--title xxx Set the title of the plot
|
||||||
|
|
||||||
|
--legend curveID legend
|
||||||
|
Set the label for a curve plot. Use this option multiple times
|
||||||
|
for multiple curves. With --dataid, curveID is the ID. Otherwise,
|
||||||
|
it's the index of the curve, starting at 0
|
||||||
|
|
||||||
|
--autolegend Use the curve IDs for the legend. Titles given with --legend
|
||||||
|
override these
|
||||||
|
|
||||||
|
--xlen xxx When using --stream, sets the size of the x-window to plot.
|
||||||
|
Omit this or set it to 0 to plot ALL the data. Does not
|
||||||
|
make sense with 3d plots. Implies --monotonic
|
||||||
|
|
||||||
|
--xmin xxx Set the range for the x axis. These are ignored in a
|
||||||
|
streaming plot
|
||||||
|
--xmax xxx Set the range for the x axis. These are ignored in a
|
||||||
|
streaming plot
|
||||||
|
--ymin xxx Set the range for the y axis.
|
||||||
|
--ymax xxx Set the range for the y axis.
|
||||||
|
--y2min xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
||||||
|
--y2max xxx Set the range for the y2 axis. Does not apply to 3d plots.
|
||||||
|
--zmin xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
||||||
|
--zmax xxx Set the range for the z axis. Only applies to 3d plots or colormaps.
|
||||||
|
|
||||||
|
--y2 xxx Plot the data specified by this curve ID on the y2 axis.
|
||||||
|
Without --dataid, the ID is just an ordered 0-based index.
|
||||||
|
Does not apply to 3d plots. Can be passed multiple times, or passed a
|
||||||
|
comma-separated list
|
||||||
|
|
||||||
|
--histogram curveID
|
||||||
|
Set up a this specific curve to plot a histogram. The bin
|
||||||
|
width is given with the --binwidth option (assumed 1.0 if
|
||||||
|
omitted). --histogram does NOT touch the drawing style.
|
||||||
|
It is often desired to plot these with boxes, and this
|
||||||
|
MUST be explicitly requested with --curvestyleall 'with
|
||||||
|
boxes'. This works with --domain and/or --stream, but in
|
||||||
|
those cases the x-value is used ONLY to cull old data
|
||||||
|
because of --xlen or --monotonic. I.e. the x-values are
|
||||||
|
NOT drawn in any way. Can be passed multiple times, or passed a comma-
|
||||||
|
separated list
|
||||||
|
--binwidth width The width of bins when making histograms. This setting applies to ALL
|
||||||
|
histograms in the plot. Defaults to 1.0 if not given.
|
||||||
|
--histstyle style Normally, histograms are generated with the 'smooth freq'
|
||||||
|
gnuplot style. --histstyle can be used to select
|
||||||
|
different 'smooth' settings. Allowed are 'unique',
|
||||||
|
'cumulative' and 'cnormal'. 'unique' indicates whether a
|
||||||
|
bin has at least one item in it: instead of counting the
|
||||||
|
items, it'll always report 0 or 1. 'cumulative' is the
|
||||||
|
integral of the "normal" histogram. 'cnormal' is like
|
||||||
|
'cumulative', but rescaled to end up at 1.0.
|
||||||
|
|
||||||
|
--curvestyle curveID style
|
||||||
|
Additional styles per curve. With --dataid, curveID is
|
||||||
|
the ID. Otherwise, it's the index of the curve, starting
|
||||||
|
at 0. Use this option multiple times for multiple curves.
|
||||||
|
--curvestylall does NOT apply to curves that have a
|
||||||
|
--curvestyle
|
||||||
|
|
||||||
|
--curvestyleall xxx Additional styles for all curves that have no --curvestyle
|
||||||
|
|
||||||
|
--extracmds xxx Additional commands. These could contain extra global styles
|
||||||
|
for instance. Can be passed multiple times.
|
||||||
|
|
||||||
|
--square Plot data with aspect ratio 1. For 3D plots, this controls the
|
||||||
|
aspect ratio for all 3 axes
|
||||||
|
|
||||||
|
--square_xy For 3D plots, set square aspect ratio for ONLY the x,y axes
|
||||||
|
|
||||||
|
--hardcopy xxx If not streaming, output to a file specified here. Format
|
||||||
|
inferred from filename, unless specified by --terminal
|
||||||
|
--terminal xxx String passed to 'set terminal'. No attempts are made to
|
||||||
|
validate this. --hardcopy sets this to some sensible
|
||||||
|
defaults if --hardcopy is given .png, .pdf, .ps, .eps or
|
||||||
|
.svg. If any other file type is desired, use both
|
||||||
|
--hardcopy and --terminal
|
||||||
|
|
||||||
|
--maxcurves xxx The maximum allowed number of curves. This is 100 by default,
|
||||||
|
but can be reset with this option. This exists purely to
|
||||||
|
prevent perl from allocating all of the system's memory when
|
||||||
|
reading bogus data
|
||||||
|
|
||||||
|
--monotonic If --domain is given, checks to make sure that the x-
|
||||||
|
coordinate in the input data is monotonically increasing.
|
||||||
|
If a given x-variable is in the past, all data currently
|
||||||
|
cached for this curve is purged. Without --monotonic, all
|
||||||
|
data is kept. Does not make sense with 3d plots.
|
||||||
|
No --monotonic by default.
|
||||||
|
|
||||||
|
--extraValuesPerPoint xxx
|
||||||
|
How many extra values are given for each data point. Normally this
|
||||||
|
is 0, and does not need to be specified, but sometimes we want
|
||||||
|
extra data, like for colors or point sizes or error bars, etc.
|
||||||
|
feedgnuplot options that require this (colormap, circles)
|
||||||
|
automatically set it. This option is ONLY needed if unknown styles are
|
||||||
|
used, with --curvestyleall for instance
|
||||||
|
|
||||||
|
--dump Instead of printing to gnuplot, print to STDOUT. For
|
||||||
|
debugging.
|
||||||
|
|
||||||
|
--geometry If using X11, specifies the size, position of the plot window
|
||||||
|
|
||||||
|
=head1 ACKNOWLEDGEMENT
|
||||||
|
|
||||||
|
This program is originally based on the driveGnuPlots.pl script from
|
||||||
|
Thanassis Tsiodras. It is available from his site at
|
||||||
|
L<http://users.softlab.ece.ntua.gr/~ttsiod/gnuplotStreaming.html>
|
||||||
|
|
||||||
|
=head1 REPOSITORY
|
||||||
|
|
||||||
|
L<https://github.com/dkogan/feedgnuplot>
|
||||||
|
|
||||||
|
=head1 AUTHOR
|
||||||
|
|
||||||
|
Dima Kogan, C<< <dima@secretsauce.net> >>
|
||||||
|
|
||||||
|
=head1 LICENSE AND COPYRIGHT
|
||||||
|
|
||||||
|
Copyright 2011-2012 Dima Kogan.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify it
|
||||||
|
under the terms of either: the GNU General Public License as published
|
||||||
|
by the Free Software Foundation; or the Artistic License.
|
||||||
|
|
||||||
|
See http://dev.perl.org/licenses/ for more information.
|
||||||
|
|
||||||
|
=cut
|
@@ -27,7 +27,6 @@ complete -W \
|
|||||||
--y2 \
|
--y2 \
|
||||||
--curvestyleall \
|
--curvestyleall \
|
||||||
--extracmds \
|
--extracmds \
|
||||||
--size \
|
|
||||||
--square \
|
--square \
|
||||||
--square_xy \
|
--square_xy \
|
||||||
--hardcopy \
|
--hardcopy \
|
||||||
@@ -37,4 +36,8 @@ complete -W \
|
|||||||
--dump \
|
--dump \
|
||||||
--geometry \
|
--geometry \
|
||||||
--curvestyle \
|
--curvestyle \
|
||||||
|
--histogram \
|
||||||
|
--binwidth \
|
||||||
|
--histstyle \
|
||||||
|
--terminal \
|
||||||
--legend' feedgnuplot
|
--legend' feedgnuplot
|
||||||
|
@@ -3,7 +3,7 @@
|
|||||||
_arguments -S \
|
_arguments -S \
|
||||||
'()--domain[first element of each line is the domain variable]' \
|
'()--domain[first element of each line is the domain variable]' \
|
||||||
'--dataid[each data point is preceded by the corresponding ID]' \
|
'--dataid[each data point is preceded by the corresponding ID]' \
|
||||||
'(--monotonic --xlen)--3d' \
|
'(--monotonic --xlen --histogram)--3d' \
|
||||||
'--colormap[show a colormapped xy plot]' \
|
'--colormap[show a colormapped xy plot]' \
|
||||||
'--stream[Plot the data in realtime]::period in s:' \
|
'--stream[Plot the data in realtime]::period in s:' \
|
||||||
'--lines' \
|
'--lines' \
|
||||||
@@ -28,7 +28,6 @@ _arguments -S
|
|||||||
'*--y2:plot to place on the Y2 axis:' \
|
'*--y2:plot to place on the Y2 axis:' \
|
||||||
'--curvestyleall[Additional styles for ALL curves]:' \
|
'--curvestyleall[Additional styles for ALL curves]:' \
|
||||||
'*--extracmds[Additional gnuplot commands]:' \
|
'*--extracmds[Additional gnuplot commands]:' \
|
||||||
'--size[Gnuplot size option]:' \
|
|
||||||
'--square[Plot data with square aspect ratio]' \
|
'--square[Plot data with square aspect ratio]' \
|
||||||
'--square_xy[For 3D plots, set square aspect ratio for ONLY the x,y axes]' \
|
'--square_xy[For 3D plots, set square aspect ratio for ONLY the x,y axes]' \
|
||||||
'--hardcopy[Plot to a file]:' \
|
'--hardcopy[Plot to a file]:' \
|
||||||
@@ -38,4 +37,8 @@ _arguments -S
|
|||||||
'--dump[Instead of printing to gnuplot, print to STDOUT]' \
|
'--dump[Instead of printing to gnuplot, print to STDOUT]' \
|
||||||
'--geometry[The X11 geometry string]:geometry string:' \
|
'--geometry[The X11 geometry string]:geometry string:' \
|
||||||
'*--curvestyle[Additional styles for a curve]:curve id: :style:' \
|
'*--curvestyle[Additional styles for a curve]:curve id: :style:' \
|
||||||
|
'(--3d)*--histogram:plot to treat as a histogram:' \
|
||||||
|
'--binwidth:Histogram bin width:' \
|
||||||
|
'--histstyle:Style of histogram:(frequency unique cumulative cnormal)' \
|
||||||
|
'--terminal:Terminal options to set with "set terminal":' \
|
||||||
'*--legend[Legend for a curve]:curve id: :legend:'
|
'*--legend[Legend for a curve]:curve id: :legend:'
|
||||||
|
89
debian/changelog
vendored
89
debian/changelog
vendored
@@ -1,88 +1,5 @@
|
|||||||
feedgnuplot (1.19) unstable; urgency=low
|
feedgnuplot (1.23-2) unstable; urgency=low
|
||||||
|
|
||||||
* added --geometry option to specify plot dimensions
|
* Initial Debian release (Closes: #686413)
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sat, 11 Feb 2012 21:04:42 -0800
|
-- Dima Kogan <dima@secretsauce.net> Tue, 30 Oct 2012 11:14:01 -0700
|
||||||
|
|
||||||
feedgnuplot (1.18) unstable; urgency=low
|
|
||||||
|
|
||||||
* data-ids can now include characters such as -. Any non-whitespace
|
|
||||||
works
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Tue, 27 Dec 2011 16:47:36 -0800
|
|
||||||
|
|
||||||
feedgnuplot (1.17) unstable; urgency=low
|
|
||||||
|
|
||||||
[ Dima Kogan ]
|
|
||||||
* POD: removed -Winteractive, since this was apparently a mawk-ism
|
|
||||||
* added zsh and bash completions to the package
|
|
||||||
|
|
||||||
[ Hermann Schwarting ]
|
|
||||||
* add build dependency libtest-script-run-perl
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 20 Nov 2011 19:17:22 -0800
|
|
||||||
|
|
||||||
feedgnuplot (1.16) unstable; urgency=low
|
|
||||||
|
|
||||||
* deb version parser now works for any package name
|
|
||||||
* Some POD fixes
|
|
||||||
* now building a native package
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Fri, 11 Nov 2011 00:10:18 -0800
|
|
||||||
|
|
||||||
feedgnuplot (1.15-2) unstable; urgency=low
|
|
||||||
|
|
||||||
* added source format for the debianization
|
|
||||||
* added configuration to let git-buildpackage build this package
|
|
||||||
* standards bump to make lintian happier
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 23 Oct 2011 13:38:15 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.15-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* Renamed main script from feedGnuplot to feedgnuplot
|
|
||||||
* Slightly improved packaging, added instructions, etc
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 16 Oct 2011 11:58:15 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.14-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release (added 'clear' command, documented commands)
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 22 May 2011 15:25:28 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.13-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release (Better streaming plot control)
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Tue, 26 Apr 2011 14:24:09 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.12-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Tue, 19 Apr 2011 11:02:23 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.11-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sat, 09 Apr 2011 14:10:21 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.10-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sat, 09 Apr 2011 14:08:06 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.09-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* New upstream release
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 03 Apr 2011 17:23:38 -0700
|
|
||||||
|
|
||||||
feedgnuplot (1.08-1) unstable; urgency=low
|
|
||||||
|
|
||||||
* Initial debianized release.
|
|
||||||
|
|
||||||
-- Dima Kogan <dima@secretsauce.net> Sun, 6 Feb 2011 15:58:22 -0800
|
|
||||||
|
2
debian/compat
vendored
2
debian/compat
vendored
@@ -1 +1 @@
|
|||||||
7
|
9
|
||||||
|
24
debian/control
vendored
24
debian/control
vendored
@@ -1,17 +1,19 @@
|
|||||||
Source: feedgnuplot
|
Source: feedgnuplot
|
||||||
Section: perl
|
Section: science
|
||||||
Priority: optional
|
Priority: extra
|
||||||
Build-Depends: debhelper (>= 7), libtest-script-run-perl
|
Build-Depends: debhelper (>= 9), libtest-script-run-perl, perl
|
||||||
Build-Depends-Indep: perl
|
Maintainer: Debian Science Maintainers <debian-science-maintainers@lists.alioth.debian.org>
|
||||||
Maintainer: Dima Kogan <dima@secretsauce.net>
|
Uploaders: Dima Kogan <dima@secretsauce.net>, Anton Gladky <gladky.anton@gmail.com>
|
||||||
Standards-Version: 3.9.2
|
Standards-Version: 3.9.4
|
||||||
Homepage: https://github.com/dkogan/feedgnuplot
|
Homepage: https://github.com/dkogan/feedgnuplot
|
||||||
|
Vcs-Git: git://git.debian.org/git/debian-science/packages/feedgnuplot.git
|
||||||
|
Vcs-Browser: http://git.debian.org/?p=debian-science/packages/feedgnuplot.git
|
||||||
|
|
||||||
Package: feedgnuplot
|
Package: feedgnuplot
|
||||||
Architecture: all
|
Architecture: all
|
||||||
Depends: ${misc:Depends}, ${perl:Depends}, gnuplot
|
Depends: ${misc:Depends}, ${perl:Depends}, gnuplot
|
||||||
Description: A pipe-oriented frontend to Gnuplot
|
Description: Pipe-oriented frontend to Gnuplot
|
||||||
This is a flexible, command-line-oriented frontend to Gnuplot. It creates
|
Flexible, command-line-oriented frontend to Gnuplot. Creates plots from data
|
||||||
plots from data coming in on STDIN or given in a filename passed on the
|
coming in on STDIN or given in a filename passed on the commandline. Various
|
||||||
commandline. Various data representations are supported, as is hardcopy
|
data representations are supported, as is hardcopy output and streaming display
|
||||||
output and streaming display of live data.
|
of live data.
|
||||||
|
12
debian/copyright
vendored
12
debian/copyright
vendored
@@ -1,13 +1,9 @@
|
|||||||
Format-Specification: http://svn.debian.org/wsvn/dep/web/deps/dep5.mdwn?op=file&rev=135
|
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
||||||
Maintainer: Dima Kogan, <dima at secretsauce.net>
|
Source: https://github.com/dkogan/feedgnuplot
|
||||||
Source: http://search.cpan.org/dist/feedGnuplot/
|
Upstream-Contact: Dima Kogan, <dima@secretsauce.net>
|
||||||
Name: feedgnuplot
|
Upstream-Name: feedgnuplot
|
||||||
|
|
||||||
Files: *
|
Files: *
|
||||||
Copyright: Dima Kogan, <dima at secretsauce.net>
|
|
||||||
License:
|
|
||||||
|
|
||||||
Files: debian/*
|
|
||||||
Copyright: 2011, Dima Kogan <dima@secretsauce.net>
|
Copyright: 2011, Dima Kogan <dima@secretsauce.net>
|
||||||
License: Artistic or GPL-1+
|
License: Artistic or GPL-1+
|
||||||
|
|
||||||
|
9
debian/feedgnuplot.doc-base
vendored
Normal file
9
debian/feedgnuplot.doc-base
vendored
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
Document: feedgnuplot
|
||||||
|
Title: Feedgnuplot Manual
|
||||||
|
Author: Dima Kogan
|
||||||
|
Abstract: Formatted manpage for feedgnuplot
|
||||||
|
Section: Science/Data Analysis
|
||||||
|
|
||||||
|
Format: HTML
|
||||||
|
Index: /usr/share/doc/feedgnuplot/feedgnuplot.html
|
||||||
|
Files: /usr/share/doc/feedgnuplot/feedgnuplot.html
|
1
debian/feedgnuplot.docs
vendored
Normal file
1
debian/feedgnuplot.docs
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
feedgnuplot.html
|
11
debian/gbp.conf
vendored
11
debian/gbp.conf
vendored
@@ -1,5 +1,8 @@
|
|||||||
[DEFAULT]
|
[DEFAULT]
|
||||||
upstream-tree = branch
|
debian-branch = debian
|
||||||
upstream-branch = master
|
upstream-tree = tag
|
||||||
debian-branch = master
|
debian-tag = debian/%(version)s
|
||||||
debian-tag = debian-%(version)s
|
upstream-tag = v%(version)s
|
||||||
|
pristine-tar = False
|
||||||
|
sign-tags = True
|
||||||
|
sign-changelog = True
|
||||||
|
8
debian/rules
vendored
8
debian/rules
vendored
@@ -2,3 +2,11 @@
|
|||||||
|
|
||||||
%:
|
%:
|
||||||
dh $@
|
dh $@
|
||||||
|
|
||||||
|
override_dh_auto_build:
|
||||||
|
dh_auto_build
|
||||||
|
pod2html --title=feedgnuplot bin/feedgnuplot.pod > feedgnuplot.html
|
||||||
|
|
||||||
|
override_dh_auto_clean:
|
||||||
|
rm -rf feedgnuplot.html pod2htm*
|
||||||
|
dh_auto_clean
|
||||||
|
2
debian/source/format
vendored
2
debian/source/format
vendored
@@ -1 +1 @@
|
|||||||
3.0 (native)
|
3.0 (quilt)
|
||||||
|
4
debian/watch
vendored
4
debian/watch
vendored
@@ -1,2 +1,2 @@
|
|||||||
version=3
|
version = 3
|
||||||
http://search.cpan.org/dist/feedGnuplot/ .*/feedgnuplot-v?(\d[\d.-]+)\.(?:tar(?:\.gz|\.bz2)?|tgz|zip)$
|
https://github.com/dkogan/feedgnuplot/tags .*/tarball/v(\d[\d\.]+)
|
||||||
|
111
package_definitions/debian/changelog
Normal file
111
package_definitions/debian/changelog
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
feedgnuplot (1.22) unstable; urgency=low
|
||||||
|
|
||||||
|
* removed --size option
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Mon, 03 Sep 2012 08:33:26 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.21) unstable; urgency=low
|
||||||
|
|
||||||
|
* removed the POD from the script to its own file
|
||||||
|
* fixed regression to allow no given extracmds, histogram or y2
|
||||||
|
options
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 02 Sep 2012 23:52:21 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.20) unstable; urgency=low
|
||||||
|
|
||||||
|
* no longer hardcoding 'x11' as the default terminal
|
||||||
|
* added histogram support
|
||||||
|
* generic terminals can now be requested
|
||||||
|
* --extracmds, --histogram, --y2 can now take comma-separated lists
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Fri, 31 Aug 2012 01:35:50 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.19) unstable; urgency=low
|
||||||
|
|
||||||
|
* added --geometry option to specify plot dimensions
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sat, 11 Feb 2012 21:04:42 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.18) unstable; urgency=low
|
||||||
|
|
||||||
|
* data-ids can now include characters such as -. Any non-whitespace
|
||||||
|
works
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Tue, 27 Dec 2011 16:47:36 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.17) unstable; urgency=low
|
||||||
|
|
||||||
|
[ Dima Kogan ]
|
||||||
|
* POD: removed -Winteractive, since this was apparently a mawk-ism
|
||||||
|
* added zsh and bash completions to the package
|
||||||
|
|
||||||
|
[ Hermann Schwarting ]
|
||||||
|
* add build dependency libtest-script-run-perl
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 20 Nov 2011 19:17:22 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.16) unstable; urgency=low
|
||||||
|
|
||||||
|
* deb version parser now works for any package name
|
||||||
|
* Some POD fixes
|
||||||
|
* now building a native package
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Fri, 11 Nov 2011 00:10:18 -0800
|
||||||
|
|
||||||
|
feedgnuplot (1.15-2) unstable; urgency=low
|
||||||
|
|
||||||
|
* added source format for the debianization
|
||||||
|
* added configuration to let git-buildpackage build this package
|
||||||
|
* standards bump to make lintian happier
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 23 Oct 2011 13:38:15 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.15-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* Renamed main script from feedGnuplot to feedgnuplot
|
||||||
|
* Slightly improved packaging, added instructions, etc
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 16 Oct 2011 11:58:15 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.14-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release (added 'clear' command, documented commands)
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 22 May 2011 15:25:28 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.13-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release (Better streaming plot control)
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Tue, 26 Apr 2011 14:24:09 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.12-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Tue, 19 Apr 2011 11:02:23 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.11-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sat, 09 Apr 2011 14:10:21 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.10-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sat, 09 Apr 2011 14:08:06 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.09-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 03 Apr 2011 17:23:38 -0700
|
||||||
|
|
||||||
|
feedgnuplot (1.08-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* Initial debianized release.
|
||||||
|
|
||||||
|
-- Dima Kogan <dima@secretsauce.net> Sun, 6 Feb 2011 15:58:22 -0800
|
1
package_definitions/debian/compat
Normal file
1
package_definitions/debian/compat
Normal file
@@ -0,0 +1 @@
|
|||||||
|
7
|
20
package_definitions/debian/control
Normal file
20
package_definitions/debian/control
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
Source: feedgnuplot
|
||||||
|
Section: science
|
||||||
|
Priority: extra
|
||||||
|
Build-Depends: debhelper (>= 7), libtest-script-run-perl, perl
|
||||||
|
Maintainer: Dima Kogan <dima@secretsauce.net>
|
||||||
|
Uploaders: Dima Kogan <dima@secretsauce.net>
|
||||||
|
Standards-Version: 3.9.3
|
||||||
|
Homepage: https://github.com/dkogan/feedgnuplot
|
||||||
|
Vcs-Git: git://github.com/dkogan/feedgnuplot.git
|
||||||
|
Vcs-Browser: https://github.com/dkogan/feedgnuplot
|
||||||
|
DM-Upload-Allowed: yes
|
||||||
|
|
||||||
|
Package: feedgnuplot
|
||||||
|
Architecture: all
|
||||||
|
Depends: ${misc:Depends}, ${perl:Depends}, gnuplot
|
||||||
|
Description: Pipe-oriented frontend to Gnuplot
|
||||||
|
Flexible, command-line-oriented frontend to Gnuplot. Creates plots from data
|
||||||
|
coming in on STDIN or given in a filename passed on the commandline. Various
|
||||||
|
data representations are supported, as is hardcopy output and streaming display
|
||||||
|
of live data.
|
24
package_definitions/debian/copyright
Normal file
24
package_definitions/debian/copyright
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
||||||
|
Source: https://github.com/dkogan/feedgnuplot
|
||||||
|
Upstream-Contact: Dima Kogan, <dima@secretsauce.net>
|
||||||
|
Upstream-Name: feedgnuplot
|
||||||
|
|
||||||
|
Files: *
|
||||||
|
Copyright: 2011, Dima Kogan <dima@secretsauce.net>
|
||||||
|
License: Artistic or GPL-1+
|
||||||
|
|
||||||
|
License: Artistic
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the Artistic License, which comes with Perl.
|
||||||
|
.
|
||||||
|
On Debian GNU/Linux systems, the complete text of the Artistic License
|
||||||
|
can be found in `/usr/share/common-licenses/Artistic'.
|
||||||
|
|
||||||
|
License: GPL-1+
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 1, or (at your option)
|
||||||
|
any later version.
|
||||||
|
.
|
||||||
|
On Debian GNU/Linux systems, the complete text of version 1 of the
|
||||||
|
General Public License can be found in `/usr/share/common-licenses/GPL-1'.
|
2
package_definitions/debian/feedgnuplot.install
Normal file
2
package_definitions/debian/feedgnuplot.install
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
completions/bash/feedgnuplot /etc/bash_completion.d/
|
||||||
|
completions/zsh/_feedgnuplot /usr/share/zsh/vendor-completions
|
5
package_definitions/debian/gbp.conf
Normal file
5
package_definitions/debian/gbp.conf
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
upstream-tree = branch
|
||||||
|
upstream-branch = master
|
||||||
|
debian-branch = master
|
||||||
|
debian-tag = debian-%(version)s
|
4
package_definitions/debian/rules
Executable file
4
package_definitions/debian/rules
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/make -f
|
||||||
|
|
||||||
|
%:
|
||||||
|
dh $@
|
1
package_definitions/debian/source/format
Normal file
1
package_definitions/debian/source/format
Normal file
@@ -0,0 +1 @@
|
|||||||
|
3.0 (native)
|
Reference in New Issue
Block a user