scatter3 - 3-D scatter plot - MATLAB (original) (raw)

Syntax

Description

Vector and Matrix Data

scatter3([X](#mw%5Fb4153fce-57f6-4b73-bf4e-1c0e692e046a),[Y](#mw%5Fced84682-813f-4ebc-b46d-1053c443e148),[Z](#mw%5Fe71a181e-7dfd-4410-b75c-69a2924b947a)) displays circles at the locations specified by X,Y, and Z.

example

scatter3([X](#mw%5Fb4153fce-57f6-4b73-bf4e-1c0e692e046a),[Y](#mw%5Fced84682-813f-4ebc-b46d-1053c443e148),[Z](#mw%5Fe71a181e-7dfd-4410-b75c-69a2924b947a),[S](#mw%5Fb556f712-aa82-4a50-8405-ab3624e1431d)) specifies the circle sizes.

example

scatter3([X](#mw%5Fb4153fce-57f6-4b73-bf4e-1c0e692e046a),[Y](#mw%5Fced84682-813f-4ebc-b46d-1053c443e148),[Z](#mw%5Fe71a181e-7dfd-4410-b75c-69a2924b947a),[S](#mw%5Fb556f712-aa82-4a50-8405-ab3624e1431d),[C](#mw%5F0ec595ed-40a4-4191-be63-534236f0fb9e)) specifies the circle colors. You can specify one color for all the circles, or you can vary the color. For example, you can plot all red circles by specifyingC as "red".

example

scatter3(___,['filled'](#mw%5F1780efd0-e7ac-40a1-8746-8f4a6cd8562e)) fills in the circles, using any of the input argument combinations in the previous syntaxes.

example

scatter3(___,[markertype](#btrui17-1-markertype)) specifies the marker type.

example

Table Data

scatter3([tbl](#btrui17-1%5Fsep%5Fmw%5F1f5b8358-45d8-4c4d-8a0d-17e2da07c841),[xvar](#mw%5Ff85adce2-8dcc-4627-99c7-066ecd038275),[yvar](#mw%5Faaaeb535-a57d-4789-a4fb-907d29c73c7a),[zvar](#mw%5F79fecb29-9d6b-45c7-9cd4-2b2557d9bcff)) plots the variables xvar, yvar, andzvar from the table tbl. To plot one data set, specify one variable each for xvar,yvar, and zvar. To plot multiple data sets, specify multiple variables for at least one of those arguments. The arguments that specify multiple variables must specify the same number of variables. (since R2021b)

example

scatter3([tbl](#btrui17-1%5Fsep%5Fmw%5F1f5b8358-45d8-4c4d-8a0d-17e2da07c841),[xvar](#mw%5Ff85adce2-8dcc-4627-99c7-066ecd038275),[yvar](#mw%5Faaaeb535-a57d-4789-a4fb-907d29c73c7a),[zvar](#mw%5F79fecb29-9d6b-45c7-9cd4-2b2557d9bcff),['filled'](#mw%5F1780efd0-e7ac-40a1-8746-8f4a6cd8562e)) plots the specified variables from the table with filled circles.(Since R2021b)

example

Additional Options

scatter3([ax](#btrui17-1-ax),___) plots into the axes specified by ax instead of into the current axes (gca). The ax option can precede any of the input argument combinations in the previous syntaxes.

example

scatter3(___,[Name,Value](#namevaluepairarguments)) modifies the scatter plot using one or more name-value arguments to set properties. For example:

For a full list of properties, see Scatter Properties.

example

[h](#btrui17-1-h) = scatter3(___) returns the Scatter object. Useh to modify properties of the scatter chart after it is created.

example

Examples

collapse all

Create a 3-D scatter plot. Use sphere to define vectors x, y, and z.

figure [X,Y,Z] = sphere(16); x = [0.5X(:); 0.75X(:); X(:)]; y = [0.5Y(:); 0.75Y(:); Y(:)]; z = [0.5Z(:); 0.75Z(:); Z(:)]; scatter3(x,y,z)

Figure contains an axes object. The axes object contains an object of type scatter.

Use sphere to define vectors x, y, and z.

[X,Y,Z] = sphere(16); x = [0.5X(:); 0.75X(:); X(:)]; y = [0.5Y(:); 0.75Y(:); Y(:)]; z = [0.5Z(:); 0.75Z(:); Z(:)];

Define vector s to specify the marker sizes.

S = repmat([100,50,5],numel(X),1); s = S(:);

Create a 3-D scatter plot and use view to change the angle of the axes in the figure.

figure scatter3(x,y,z,s) view(40,35)

Figure contains an axes object. The axes object contains an object of type scatter.

Corresponding entries in x, y, z, and s determine the location and size of each marker.

Use sphere to define vectors x, y, and z.

[X,Y,Z] = sphere(16); x = [0.5X(:); 0.75X(:); X(:)]; y = [0.5Y(:); 0.75Y(:); Y(:)]; z = [0.5Z(:); 0.75Z(:); Z(:)];

Define vectors s and c to specify the size and color of each marker.

S = repmat([50,25,10],numel(X),1); C = repmat([1,2,3],numel(X),1); s = S(:); c = C(:);

Create a 3-D scatter plot and use view to change the angle of the axes in the figure.

figure scatter3(x,y,z,s,c) view(40,35)

Figure contains an axes object. The axes object contains an object of type scatter.

Corresponding entries in x, y, z, and c determine the location and color of each marker.

Create vectors x and y as cosine and sine values with random noise.

z = linspace(0,4pi,250); x = 2cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);

Create a 3-D scatter plot and fill in the markers. Use view to change the angle of the axes in the figure.

scatter3(x,y,z,'filled') view(-30,10)

Figure contains an axes object. The axes object contains an object of type scatter.

Initialize the random-number generator to make the output of rand repeatable. Define vectors x and y as cosine and sine values with random noise.

rng default z = linspace(0,4pi,250); x = 2cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);

Create a 3-D scatter plot and set the marker type. Use view to change the angle of the axes in the figure.

figure scatter3(x,y,z,'*') view(-30,10)

Figure contains an axes object. The axes object contains an object of type scatter.

Initialize the random-number generator to make the output of rand repeatable. Define vectors x and y as cosine and sine values with random noise.

rng default z = linspace(0,4pi,250); x = 2cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);

Create a 3-D scatter plot and set the marker edge color and the marker face color. Use view to change the angle of the axes in the figure.

figure scatter3(x,y,z,... 'MarkerEdgeColor','k',... 'MarkerFaceColor',[0 .75 .75]) view(-30,10)

Figure contains an axes object. The axes object contains an object of type scatter.

Since R2021b

A convenient way to plot data from a table is to pass the table to the scatter3 function and specify the variables you want to plot. For example, read patients.xls as a table tbl. Plot the relationship between the Systolic, Diastolic, and Weight variables by passing tbl as the first argument to the scatter3 function followed by the variable names. By default, the axis labels match the variable names.

tbl = readtable('patients.xls'); scatter3(tbl,'Systolic','Diastolic','Weight');

Figure contains an axes object. The axes object with xlabel Systolic, ylabel Diastolic contains an object of type scatter.

You can also plot multiple variables at the same time. For example, plot both blood pressure variables on the _x_-axis by specifying the xvar argument as the cell array {'Systolic','Diastolic'}. Then add a legend. The legend labels match the variable names.

scatter3(tbl,{'Systolic','Diastolic'},'Age','Weight'); legend

Figure contains an axes object. The axes object with ylabel Age contains 2 objects of type scatter.

Since R2021b

One way to plot data from a table and customize the colors and marker sizes is to set the ColorVariable and SizeData properties. You can set these properties as name-value arguments when you call the scatter3 function, or you can set them on the Scatter object later.

For example, read patients.xls as a table tbl. Plot the relationship between the Systolic, Diastolic, and Weight variables with filled markers. Vary the marker colors by specifying the ColorVariable name-value argument. Return the Scatter object as s, so you can set other properties later.

tbl = readtable('patients.xls'); s = scatter3(tbl,'Systolic','Diastolic','Weight','filled', ... 'ColorVariable','Diastolic');

Figure contains an axes object. The axes object with xlabel Systolic, ylabel Diastolic contains an object of type scatter.

Change the marker sizes to 100 points by setting the SizeData property. Then add a colorbar.

s.SizeData = 100; colorbar

Figure contains an axes object. The axes object with xlabel Systolic, ylabel Diastolic contains an object of type scatter.

You can display a tiling of plots using the tiledlayout and nexttile functions.

Load the seamount data set to get vectors x, y, and z. Call the tiledlayout function to create a 2-by-1 tiled chart layout. Call the nexttile function to create the axes objects ax1 and ax2. Then create separate scatter plots in the axes by specifying the axes object as the first argument to scatter3.

load seamount tiledlayout(2,1) ax1 = nexttile; ax2 = nexttile; scatter3(ax1,x,y,z,'MarkerFaceColor',[0 .75 .75]) scatter3(ax2,x,y,z,'*')

Figure contains 2 axes objects. Axes object 1 contains an object of type scatter. Axes object 2 contains an object of type scatter.

Use the sphere function to create vectors x, y, and z.

[X,Y,Z] = sphere(16); x = [0.5X(:); 0.75X(:); X(:)]; y = [0.5Y(:); 0.75Y(:); Y(:)]; z = [0.5Z(:); 0.75Z(:); Z(:)];

Create vectors s and c to specify the size and color for each marker.

S = repmat([70,50,20],numel(X),1); C = repmat([1,2,3],numel(X),1); s = S(:); c = C(:);

Create a 3-D scatter plot and return the scatter series object.

Figure contains an axes object. The axes object contains an object of type scatter.

Use an RGB triplet color value to set the marker face color. Use dot notation to set properties.

h.MarkerFaceColor = [0 0.5 0.5];

Figure contains an axes object. The axes object contains an object of type scatter.

Input Arguments

collapse all

_x_-coordinates, specified as a scalar, vector, or matrix. The size and shape of X depends on the shape of your data. This table describes the most common situations.

Type of Plot How to Specify Coordinates
Single point Specify X,Y, and Z as scalars. For example:scatter3(1,2,3)
One set of points Specify X,Y, and Z as any combination of row or column vectors of the same length. For example:X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z)
Multiple sets of points that are different colors If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the same_x_-coordinates.X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z)If the matrices are square,scatter3 plots a separate set of points for each column in the matrices.Alternatively, specifyX, Y, andZ as matrices of equal size. In this case, scatter3 plots the columns of the matrices. For example, plot four data sets.X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z)

Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | categorical | datetime | duration

_y_-coordinates, specified as a scalar, vector, or matrix. The size and shape of y depends on the shape of your data. This table describes the most common situations.

Type of Plot How to Specify Coordinates
Single point Specify X,Y, and Z as scalars. For example:scatter3(1,2,3)
One set of points Specify X,Y, and Z as any combination of row or column vectors of the same length. For example:X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z)
Multiple sets of points that are different colors If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the same_x_-coordinates.X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z)If the matrices are square,scatter3 plots a separate set of points for each column in the matrices.Alternatively, specifyX, Y, andZ as matrices of equal size. In this case, scatter3 plots the columns of the matrices. For example, plot four data sets.X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z)

Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | categorical | datetime | duration

_z_-coordinates, specified as a scalar, vector, or matrix. The size and shape of Z depends on the shape of your data. This table describes the most common situations.

Type of Plot How to Specify Coordinates
Single point Specify X,Y, and Z as scalars. For example:scatter3(1,2,3)
One set of points Specify X, Y, and Z as any combination of row or column vectors of the same length. For example:X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z)
Multiple sets of points that are different colors If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the same_x_-coordinates.X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z)If the matrices are square,scatter3 plots a separate set of points for each column in the matrices.Alternatively, specifyX, Y, andZ as matrices of equal size. In this case, scatter3 plots the columns of the matrices. For example, plot four data sets.X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z)

Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | categorical | datetime | duration

Marker size, specified as a numeric scalar, vector, matrix, or empty array ([]). The size controls the area of each marker in points squared. An empty array specifies the default size of 36 points. The way you specify the size depends on how you specify X,Y, and Z and how you want the plot to look. This table describes the most common situations.

Marker Size X, Y, andZ S Example
Same size for all points Any valid combination of vectors or matrices described for X,Y, andZ Scalar Specify X as a vector,Y and Z as matrices, and S as a scalar.X = [1 2 3 4]; Y = [5 6 7 8; 9 10 11 12]; Z = [13 14 15 16; 17 18 19 20]; scatter3(X,Y,Z,100)
Different size for each point Vectors of the same length A vector with the same length asX, Y, andZ.A matrix with at least one dimension that matches the lengths of X,Y, and Z. Specifying a matrix is useful for displaying multiple markers with different sizes at each (x,y,z) location. Specify X,Y, Z, andS as vectors.X = [1 2 3 4]; Y = [4 5 6 7]; Z = [8 9 10 11]; S = [80 150 700 50]; scatter3(X,Y,Z,S)SpecifyX, Y, andZ as vectors andS as a matrix.X = [1 2 3 4]; Y = [5 6 7 8]; Z = [9 10 11 12]; S = [80 30; 150 900; 50 500; 200 350]; scatter3(X,Y,Z,S)
Different size for each point At least one of X,Y, or Z is a matrix for plotting multiple data sets A vector with the same number of elements as there are points in each data set.A matrix that has the same size as theX, Y, orZ matrix. Specify X as a vector,Y and Z as matrices, and S as a vector.X = [1 2 3 4]; Y = [1 6; 3 8; 2 7; 4 9]; Z = [2 8; 3 10; 4 7; 4 12]; S = [80 150 200 350]; scatter3(X,Y,Z,S)SpecifyX as a vector andY, Z, andS as matrices.X = [1 2 3 4]; Y = [1 6; 3 8; 2 7; 4 9]; Z = [10 11; 12 13; 14 15; 16 17]; S = [80 30; 150 900; 50 2000; 200 350]; scatter3(X,Y,Z,S)

Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

Marker color, specified as a color name, RGB triplet, matrix of RGB triplets, or a vector of colormap indices.

The way you specify the color depends on your preferred color scheme and whether you are plotting one set of coordinates or multiple sets of coordinates. This table describes the most common situations.

Color Scheme How to Specify the Color Example
Use one color for all the points. Specify a color name or a short name from the table below, or specify one RGB triplet. Plot one set of points, and specify the color as "red".X = [1 2 3 4]; Y = [2 5 3 6]; Z = [10 6 4 7]; S = 50; scatter3(X,Y,Z,S,"red")Plot two sets of points, and specify the color as red using the RGB triplet [1 0 0].X = [1 2 3 4]; Y = [2 5 3 6]; Z = [2 5; 1 2; 8 4; 7 9]; S = 50; scatter3(X,Y,Z,S,[1 0 0])
Assign different colors to each point using a colormap. Specify a row or column vector of numbers. The numbers map into the current colormap array. The smallest value maps to the first row in the colormap, and the largest value maps to the last row. The intermediate values map linearly to the intermediate rows.If your plot has three points, specify a column vector to ensure the values are interpreted as colormap indices.You can use this method only when X, Y, andZ are vectors, andS is either a vector or a scalar. Create a vector C that specifies four colormap indices. Plot four points using the colors from the current colormap. Then, change the colormap towinter.C = [1 2 3 4]; X = [1 2 3 4]; Y = [1 0 6 2]; Z = [2 5 3 7]; S = 50; scatter3(X,Y,Z,S,C) colormap(gca,"winter")
Create a custom color for each point. Specify an m-by-3 matrix of RGB triplets, where m is the number of points in the plot.You can use this method only whenX, Y, andZ are vectors, andS is either a vector or a scalar. Create a matrix C that specifies RGB triplets for green, red, gray, and purple. Then create a scatter plot of four points using those colors.C = [0 1 0; 1 0 0; 0.5 0.5 0.5; 0.6 0 1]; X = [1 2 3 4]; Y = [2 5 3 6]; Z = [10 6 4 7]; S = 50; scatter3(X,Y,Z,S,C)
Create a different color for each data set. Specify an n-by-3 matrix of RGB triplets, where n is the number of data sets.You can use this method only when at least one ofX, Y,Z, or S is a matrix. Create a matrix C that contains two RGB triplets. Then plot two data sets using those colors.C = [1 0 0; 0.6 0 1]; X = [1 2 3 4]; Y = [5 6 7 8]; Z = [2 5; 1 2; 8 4; 11 9]; S = 50; scatter3(X,Y,Z,S,C)

Color Names and RGB Triplets for Common Colors

Color Name Short Name RGB Triplet Hexadecimal Color Code Appearance
"red" "r" [1 0 0] "#FF0000" Sample of the color red
"green" "g" [0 1 0] "#00FF00" Sample of the color green
"blue" "b" [0 0 1] "#0000FF" Sample of the color blue
"cyan" "c" [0 1 1] "#00FFFF" Sample of the color cyan
"magenta" "m" [1 0 1] "#FF00FF" Sample of the color magenta
"yellow" "y" [1 1 0] "#FFFF00" Sample of the color yellow
"black" "k" [0 0 0] "#000000" Sample of the color black
"white" "w" [1 1 1] "#FFFFFF" Sample of the color white

This table lists the default color palettes for plots in the light and dark themes.

Palette Palette Colors
"gem" — Light theme default_Before R2025a: Most plots use these colors by default._ Sample of the "gem" color palette
"glow" — Dark theme default Sample of the "glow" color palette

You can get the RGB triplets and hexadecimal color codes for these palettes using the orderedcolors and rgb2hex functions. For example, get the RGB triplets for the "gem" palette and convert them to hexadecimal color codes.

RGB = orderedcolors("gem"); H = rgb2hex(RGB);

Before R2023b: Get the RGB triplets using RGB = get(groot,"FactoryAxesColorOrder").

Before R2024a: Get the hexadecimal color codes using H = compose("#%02X%02X%02X",round(RGB*255)).

Marker, specified as one of the markers in this table.

Marker Description Resulting Marker
"o" Circle Sample of circle marker
"+" Plus sign Sample of plus sign marker
"*" Asterisk Sample of asterisk marker
"." Point Sample of point marker
"x" Cross Sample of cross marker
"_" Horizontal line Sample of horizontal line marker
"|" Vertical line Sample of vertical line marker
"square" Square Sample of square marker
"diamond" Diamond Sample of diamond marker
"^" Upward-pointing triangle Sample of upward-pointing triangle marker
"v" Downward-pointing triangle Sample of downward-pointing triangle marker
">" Right-pointing triangle Sample of right-pointing triangle marker
"<" Left-pointing triangle Sample of left-pointing triangle marker
"pentagram" Pentagram Sample of pentagram marker
"hexagram" Hexagram Sample of hexagram marker
"none" No markers Not applicable

Option to fill the interior of the markers, specified as'filled'. Use this option with markers that have a face, for example, 'o' or 'square'. Markers that do not have a face and contain only edges do not draw ('+', '*', '.', and 'x').

The 'filled' option sets theMarkerFaceColor property of the Scatter object to 'flat' and the MarkerEdgeColor property to'none', so the marker faces draw, but the edges do not.

Source table containing the data to plot, specified as a table or a timetable.

Table variables containing the _x_-coordinates, specified as one or more table variable indices.

Specifying Table Indices

Use any of the following indexing schemes to specify the desired variable or variables.

Indexing Scheme Examples
Variable names: A string, character vector, or cell array.A pattern object. "A" or 'A' — A variable named A["A","B"] or {'A','B'} — Two variables named A andB"Var"+digitsPattern(1) — Variables named"Var" followed by a single digit
Variable index: An index number that refers to the location of a variable in the table.A vector of numbers.A logical vector. Typically, this vector is the same length as the number of variables, but you can omit trailing0 or false values. 3 — The third variable from the table[2 3] — The second and third variables from the table[false false true] — The third variable
Variable type: A vartype subscript that selects variables of a specified type. vartype("categorical") — All the variables containing categorical values

Plotting Your Data

The table variables you specify can contain numeric, categorical, datetime, or duration values.

To plot one data set, specify one variable for xvar, one variable foryvar, and one variable for zvar. For example, readPatients.xls into the table tbl. Plot theHeight, Weight, and Diastolic variables.

tbl = readtable("Patients.xls"); scatter3(tbl,"Height","Weight","Diastolic")

To plot multiple data sets together, specify multiple variables for at least one ofxvar, yvar, or zvar. If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.

For example, plot the Weight variable on the _x_-axis, theSystolic and Diastolic variables on the_y_-axis, and the Age variable on the_z_-axis.

scatter3(tbl,"Weight",["Systolic","Diastolic"],"Age")

You can also use different indexing schemes for xvar,yvar, and zvar. For example, specifyxvar as a variable name, yvar as an index number, and zvar as a logical vector.

scatter3(tbl,"Height",6,[false false true])

Table variables containing the _y_-coordinates, specified as one or more table variable indices.

Specifying Table Indices

Use any of the following indexing schemes to specify the desired variable or variables.

Indexing Scheme Examples
Variable names: A string, character vector, or cell array.A pattern object. "A" or 'A' — A variable named A["A","B"] or {'A','B'} — Two variables named A andB"Var"+digitsPattern(1) — Variables named"Var" followed by a single digit
Variable index: An index number that refers to the location of a variable in the table.A vector of numbers.A logical vector. Typically, this vector is the same length as the number of variables, but you can omit trailing0 or false values. 3 — The third variable from the table[2 3] — The second and third variables from the table[false false true] — The third variable
Variable type: A vartype subscript that selects variables of a specified type. vartype("categorical") — All the variables containing categorical values

Plotting Your Data

The table variables you specify can contain numeric, categorical, datetime, or duration values.

To plot one data set, specify one variable for xvar, one variable foryvar, and one variable for zvar. For example, readPatients.xls into the table tbl. Plot theHeight, Weight, and Diastolic variables.

tbl = readtable("Patients.xls"); scatter3(tbl,"Height","Weight","Diastolic")

To plot multiple data sets together, specify multiple variables for at least one ofxvar, yvar, or zvar. If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.

For example, plot the Weight variable on the _x_-axis, theSystolic and Diastolic variables on the_y_-axis, and the Age variable on the_z_-axis.

scatter3(tbl,"Weight",["Systolic","Diastolic"],"Age")

You can also use different indexing schemes for xvar,yvar, and zvar. For example, specifyxvar as a variable name, yvar as an index number, and zvar as a logical vector.

scatter3(tbl,"Height",6,[false false true])

Table variables containing the _z_-coordinates, specified as one or more table variable indices.

Specifying Table Indices

Use any of the following indexing schemes to specify the desired variable or variables.

Indexing Scheme Examples
Variable names: A string, character vector, or cell array.A pattern object. "A" or 'A' — A variable named A["A","B"] or {'A','B'} — Two variables named A andB"Var"+digitsPattern(1) — Variables named"Var" followed by a single digit
Variable index: An index number that refers to the location of a variable in the table.A vector of numbers.A logical vector. Typically, this vector is the same length as the number of variables, but you can omit trailing0 or false values. 3 — The third variable from the table[2 3] — The second and third variables from the table[false false true] — The third variable
Variable type: A vartype subscript that selects variables of a specified type. vartype("categorical") — All the variables containing categorical values

Plotting Your Data

The table variables you specify can contain numeric, categorical, datetime, or duration values.

To plot one data set, specify one variable for xvar, one variable foryvar, and one variable for zvar. For example, readPatients.xls into the table tbl. Plot theHeight, Weight, and Diastolic variables.

tbl = readtable("Patients.xls"); scatter3(tbl,"Height","Weight","Diastolic")

To plot multiple data sets together, specify multiple variables for at least one ofxvar, yvar, or zvar. If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.

For example, plot the Weight variable on the _x_-axis, theSystolic and Diastolic variables on the_y_-axis, and the Age variable on the_z_-axis.

scatter3(tbl,"Weight",["Systolic","Diastolic"],"Age")

You can also use different indexing schemes for xvar,yvar, and zvar. For example, specifyxvar as a variable name, yvar as an index number, and zvar as a logical vector.

scatter3(tbl,"Height",6,[false false true])

Axes object. If you do not specify an axes, then scatter3 plots into the current axes.

Name-Value Arguments

collapse all

Specify optional pairs of arguments asName1=Value1,...,NameN=ValueN, where Name is the argument name and Value is the corresponding value. Name-value arguments must appear after other arguments, but the order of the pairs does not matter.

Before R2021a, use commas to separate each name and value, and enclose Name in quotes.

Example: 'MarkerFaceColor','red' sets the marker face color to red.

The properties listed here are only a subset. For a complete list, see Scatter Properties.

Table variable containing the color data, specified as a variable index into the source table.

Specifying the Table Index

Use any of the following indexing schemes to specify the desired variable.

Indexing Scheme Examples
Variable name:A string scalar or character vector.A pattern object. The pattern object must refer to only one variable. "A" or 'A' — A variable named A"Var"+digitsPattern(1) — The variable with the name "Var" followed by a single digit
Variable index:An index number that refers to the location of a variable in the table.A logical vector. Typically, this vector is the same length as the number of variables, but you can omit trailing 0 or false values. 3 — The third variable from the table[false false true] — The third variable
Variable type:A vartype subscript that selects a table variable of a specified type. The subscript must refer to only one variable. vartype("double") — The variable containing double values

Specifying Color Data

Specifying the ColorVariable property controls the colors of the markers. The data in the variable controls the marker fill color when theMarkerFaceColor property is set to"flat". The data can also control the marker outline color, when the MarkerEdgeColor is set to"flat".

The table variable you specify can contain values of any numeric type. The values can be in either of the following forms:

When you set the ColorVariable property, MATLAB® updates the CData property.

Output Arguments

collapse all

Scatter object. This is a unique identifier, which you can use to query and modify the properties of the Scatter object after it is created.

Extended Capabilities

expand all

The scatter3 function supports GPU array input with these usage notes and limitations:

For more information, see Run MATLAB Functions on a GPU (Parallel Computing Toolbox).

Version History

Introduced before R2006a

expand all

When you pass a table and one or more variable names to the scatter3 function, the axis and legend labels now display any special characters that are included in the table variable names, such as underscores. Previously, special characters were interpreted as TeX or LaTeX characters.

For example, if you pass a table containing a variable named Sample_Number to the scatter3 function, the underscore appears in the axis and legend labels. In R2022a and earlier releases, the underscores are interpreted as subscripts.

Release Label for Table Variable "Sample_Number"
R2022b Label for the variable name "Sample_Number" in R2022b. The underscore is included in the label.
R2022a Label for the variable name "Sample_Number" in R2022a. The N character displays as a subscript.

To display axis and legend labels with TeX or LaTeX formatting, specify the labels manually. For example, after plotting, call the xlabel orlegend function with the desired label strings.

xlabel("Sample_Number") legend(["Sample_Number" "Another_Legend_Label"])

The scatter3 function now accepts combinations of vectors and matrices for the coordinates. As a result, you can visualize multiple data sets at once rather than using the hold function between plotting commands.

Create plots by passing a table to the scatter3 function followed by the variables you want to plot. When you specify your data as a table, the axis labels and the legend (if present) are automatically labeled using the table variable names.