Navigation

Operators and Keywords

Function List:

C++ API

Function File: plot (y)
Function File: plot (x, y)
Function File: plot (x, y, fmt)
Function File: plot (…, property, value, …)
Function File: plot (x1, y1, …, xn, yn)
Function File: plot (hax, …)
Function File: h = plot (…)

Produce 2-D plots.

Many different combinations of arguments are possible. The simplest form is

plot (y)

where the argument is taken as the set of y coordinates and the x coordinates are taken to be the range 1:numel (y).

If more than one argument is given, they are interpreted as

plot (y, property, value, …)

or

plot (x, y, property, value, …)

or

plot (x, y, fmt, …)

and so on. Any number of argument sets may appear. The x and y values are interpreted as follows:

  • If a single data argument is supplied, it is taken as the set of y coordinates and the x coordinates are taken to be the indices of the elements, starting with 1.
  • If x and y are scalars, a single point is plotted.
  • squeeze() is applied to arguments with more than two dimensions, but no more than two singleton dimensions.
  • If both arguments are vectors, the elements of y are plotted versus the elements of x.
  • If x is a vector and y is a matrix, then the columns (or rows) of y are plotted versus x. (using whichever combination matches, with columns tried first.)
  • If the x is a matrix and y is a vector, y is plotted versus the columns (or rows) of x. (using whichever combination matches, with columns tried first.)
  • If both arguments are matrices, the columns of y are plotted versus the columns of x. In this case, both matrices must have the same number of rows and columns and no attempt is made to transpose the arguments to make the number of rows match.

Multiple property-value pairs may be specified, but they must appear in pairs. These arguments are applied to the line objects drawn by plot. Useful properties to modify are "linestyle", "linewidth", "color", "marker", "markersize", "markeredgecolor", "markerfacecolor".

The fmt format argument can also be used to control the plot style. The format is composed of three parts: linestyle, markerstyle, color. When a markerstyle is specified, but no linestyle, only the markers are plotted. Similarly, if a linestyle is specified, but no markerstyle, then only lines are drawn. If both are specified then lines and markers will be plotted. If no fmt and no property/value pairs are given, then the default plot style is solid lines with no markers and the color determined by the "colororder" property of the current axes.

Format arguments:

linestyle
-Use solid lines (default).
--Use dashed lines.
:Use dotted lines.
-.Use dash-dotted lines.
markerstyle
+crosshair
ocircle
*star
.point
xcross
ssquare
ddiamond
^upward-facing triangle
vdownward-facing triangle
>right-facing triangle
<left-facing triangle
ppentagram
hhexagram
color
kblacK
rRed
gGreen
bBlue
mMagenta
cCyan
wWhite
";key;"

Here "key" is the label to use for the plot legend.

The fmt argument may also be used to assign legend keys. To do so, include the desired label between semicolons after the formatting sequence described above, e.g., "+b;Key Title;". Note that the last semicolon is required and Octave will generate an error if it is left out.

Here are some plot examples:

plot (x, y, "or", x, y2, x, y3, "m", x, y4, "+")

This command will plot y with red circles, y2 with solid lines, y3 with solid magenta lines, and y4 with points displayed as ‘+’.

plot (b, "*", "markersize", 10)

This command will plot the data in the variable b, with points displayed as ‘*’ and a marker size of 10.

t = 0:0.1:6.3;
plot (t, cos(t), "-;cos(t);", t, sin(t), "-b;sin(t);");

This will plot the cosine and sine functions and label them accordingly in the legend.

If the first argument hax is an axes handle, then plot into this axis, rather than the current axes returned by gca.

The optional return value h is a vector of graphics handles to the created line objects.

To save a plot, in one of several image formats such as PostScript or PNG, use the print command.

See also: axis, box, grid, hold, legend, title, xlabel, ylabel, xlim, ylim, ezplot, errorbar, fplot, line, plot3, polar, loglog, semilogx, semilogy, subplot.

Demonstration 1

The following code

 x = 1:5;  y = 1:5;
 plot (x,y,'g');
 title ('plot() of green line at 45 degrees');

Produces the following figure

Figure 1

Demonstration 2

The following code

 x = 1:5;  y = 1:5;
 plot (x,y,'g*');
 title ('plot() of green stars along a line at 45 degrees');

Produces the following figure

Figure 1

Demonstration 3

The following code

 x1 = 1:5;  y1 = 1:5;
 x2 = 5:9; y2 = 5:-1:1;
 plot (x1,y1,'bo-', x2,y2,'rs-');
 axis ('tight');
 title ({'plot() of blue circles ascending and red squares descending';
         'connecting lines drawn'});

Produces the following figure

Figure 1

Demonstration 4

The following code

 x = 0:10;
 plot (x, rand (numel (x), 3))
 axis ([0 10 0 1])
 title ({'Three random variables', 'x[1x11], y[11x3]'})

Produces the following figure

Figure 1

Demonstration 5

The following code

 x = 0:10;
 plot (x, rand (3, numel (x)))
 axis ([0 10 0 1])
 title ({'Three random variables', 'x[1x11], y[3x11]'})

Produces the following figure

Figure 1

Demonstration 6

The following code

 x = 0:10;
 plot (repmat (x, 2, 1), rand (2, numel (x)), '-s')
 axis ([0 10 0 1])
 title ({'Vertical lines with random height and lengths', ...
         'x[2x11], y[2,11]'})

Produces the following figure

Figure 1

Demonstration 7

The following code

 x = 0:10;
 plot (repmat (x(:), 1, 2), rand (numel (x), 2))
 axis ([0 10 0 1])
 title ({'Two random variables', 'x[11x2], y[11x2]'})

Produces the following figure

Figure 1

Demonstration 8

The following code

 x = 0:10;
 shape = [1, 1, numel(x), 2];
 x = reshape (repmat (x(:), 1, 2), shape);
 y = rand (shape);
 plot (x, y)
 axis ([0 10 0 1])
 title ({'Two random variables', 'squeezed from 4-d arrays'})

Produces the following output

warning: plot: N-d inputs have been squeezed to less than three dimensions

and the following figure

Figure 1

Package: octave