Skip to main content
Engineering LibreTexts

5.8: Matlab Functions with No Outputs

  • Page ID
    84407
  • \( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)

    \( \newcommand{\id}{\mathrm{id}}\) \( \newcommand{\Span}{\mathrm{span}}\)

    ( \newcommand{\kernel}{\mathrm{null}\,}\) \( \newcommand{\range}{\mathrm{range}\,}\)

    \( \newcommand{\RealPart}{\mathrm{Re}}\) \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)

    \( \newcommand{\Argument}{\mathrm{Arg}}\) \( \newcommand{\norm}[1]{\| #1 \|}\)

    \( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)

    \( \newcommand{\Span}{\mathrm{span}}\)

    \( \newcommand{\id}{\mathrm{id}}\)

    \( \newcommand{\Span}{\mathrm{span}}\)

    \( \newcommand{\kernel}{\mathrm{null}\,}\)

    \( \newcommand{\range}{\mathrm{range}\,}\)

    \( \newcommand{\RealPart}{\mathrm{Re}}\)

    \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)

    \( \newcommand{\Argument}{\mathrm{Arg}}\)

    \( \newcommand{\norm}[1]{\| #1 \|}\)

    \( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)

    \( \newcommand{\Span}{\mathrm{span}}\) \( \newcommand{\AA}{\unicode[.8,0]{x212B}}\)

    \( \newcommand{\vectorA}[1]{\vec{#1}}      % arrow\)

    \( \newcommand{\vectorAt}[1]{\vec{\text{#1}}}      % arrow\)

    \( \newcommand{\vectorB}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vectorC}[1]{\textbf{#1}} \)

    \( \newcommand{\vectorD}[1]{\overrightarrow{#1}} \)

    \( \newcommand{\vectorDt}[1]{\overrightarrow{\text{#1}}} \)

    \( \newcommand{\vectE}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash{\mathbf {#1}}}} \)

    \( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)

    \(\newcommand{\avec}{\mathbf a}\) \(\newcommand{\bvec}{\mathbf b}\) \(\newcommand{\cvec}{\mathbf c}\) \(\newcommand{\dvec}{\mathbf d}\) \(\newcommand{\dtil}{\widetilde{\mathbf d}}\) \(\newcommand{\evec}{\mathbf e}\) \(\newcommand{\fvec}{\mathbf f}\) \(\newcommand{\nvec}{\mathbf n}\) \(\newcommand{\pvec}{\mathbf p}\) \(\newcommand{\qvec}{\mathbf q}\) \(\newcommand{\svec}{\mathbf s}\) \(\newcommand{\tvec}{\mathbf t}\) \(\newcommand{\uvec}{\mathbf u}\) \(\newcommand{\vvec}{\mathbf v}\) \(\newcommand{\wvec}{\mathbf w}\) \(\newcommand{\xvec}{\mathbf x}\) \(\newcommand{\yvec}{\mathbf y}\) \(\newcommand{\zvec}{\mathbf z}\) \(\newcommand{\rvec}{\mathbf r}\) \(\newcommand{\mvec}{\mathbf m}\) \(\newcommand{\zerovec}{\mathbf 0}\) \(\newcommand{\onevec}{\mathbf 1}\) \(\newcommand{\real}{\mathbb R}\) \(\newcommand{\twovec}[2]{\left[\begin{array}{r}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\ctwovec}[2]{\left[\begin{array}{c}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\threevec}[3]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\cthreevec}[3]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\fourvec}[4]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\cfourvec}[4]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\fivevec}[5]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\cfivevec}[5]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\mattwo}[4]{\left[\begin{array}{rr}#1 \amp #2 \\ #3 \amp #4 \\ \end{array}\right]}\) \(\newcommand{\laspan}[1]{\text{Span}\{#1\}}\) \(\newcommand{\bcal}{\cal B}\) \(\newcommand{\ccal}{\cal C}\) \(\newcommand{\scal}{\cal S}\) \(\newcommand{\wcal}{\cal W}\) \(\newcommand{\ecal}{\cal E}\) \(\newcommand{\coords}[2]{\left\{#1\right\}_{#2}}\) \(\newcommand{\gray}[1]{\color{gray}{#1}}\) \(\newcommand{\lgray}[1]{\color{lightgray}{#1}}\) \(\newcommand{\rank}{\operatorname{rank}}\) \(\newcommand{\row}{\text{Row}}\) \(\newcommand{\col}{\text{Col}}\) \(\renewcommand{\row}{\text{Row}}\) \(\newcommand{\nul}{\text{Nul}}\) \(\newcommand{\var}{\text{Var}}\) \(\newcommand{\corr}{\text{corr}}\) \(\newcommand{\len}[1]{\left|#1\right|}\) \(\newcommand{\bbar}{\overline{\bvec}}\) \(\newcommand{\bhat}{\widehat{\bvec}}\) \(\newcommand{\bperp}{\bvec^\perp}\) \(\newcommand{\xhat}{\widehat{\xvec}}\) \(\newcommand{\vhat}{\widehat{\vvec}}\) \(\newcommand{\uhat}{\widehat{\uvec}}\) \(\newcommand{\what}{\widehat{\wvec}}\) \(\newcommand{\Sighat}{\widehat{\Sigma}}\) \(\newcommand{\lt}{<}\) \(\newcommand{\gt}{>}\) \(\newcommand{\amp}{&}\) \(\definecolor{fillinmathshade}{gray}{0.9}\)

    Tags recommended by the template: article:topic

    By Carey A. Smith

    A MATLAB function can have no output variable, although it may display something or do some action. An example is:

    clear all -- clears all variables

    The user-defined function below draws a star, but does not return a value. Note that in the function declaration line (signature) that empty square brackets are placed where the output value would normally go. The inputs are the size and color of the star.

    Example \(\PageIndex{1}\) Function with no outputs: starxy()

    function [] = starxy(r, color)

    % Draw a star of radius r

    % color is a character, such as 'r'

    dth = (4*pi/5); % delta theta

    theta = (pi/2) + [1:1:6]*dth;

    x = r*cos(theta);

    y = r*sin(theta);

    figure;

    plot(x, y);

    axis equal;

    end

    Test of starxy():

    starxy(2, 'g') % This draws the green star shown in the figure.

    starxy_example.png

    Figure \(\PageIndex{i}\): Function with no outputs: starxy() draws a star.

    Solution

    Add example text here.

    MATLAB and Octave also allow the []= to be omitted from the function declaration when there is no return value. So this declaration also works:

    function starxy(r, color)

    .

    Exercise \(\PageIndex{1}\) Rectangle Draw

    Part A. Write a function rectangle_draw_YourName

    % Function's 1st line is:

    function [ ] = rectangle_draw_YourName(width, height, color)

    % It has 3 input variables (a.k.a. arguments):
    % width (x direction)

    % height (y direction)

    % color: Can be any one these: 'b', 'c', ''g', 'k', 'r', or 'y'

    % The [ ] in the function's 1st line indicates that it has no output variable. It draws a figure instead of computing an output value.

    Inside the function, open a figure and turn on hold.

    figure;
    hold on;

    Then draw 4 line segments to create a rectangle. Think of the base paths on a baseball field.
    The 1st line segment is like going from home plate to 1st base.

    This line is horizontal, so the y coordinates of both points are the same.

    % Home to 1st base:
    x1 = [0, width];
    y1 = [0, 0];
    plot(x1,y1,color,'LineWidth',10)

    The 2nd line segment is like going from 1st to 2nd base.

    This line is vertical, so the x coordinates of both points are the same.

    %% 1st base to 2nd base:
    x2 = [width, width];
    y2 = [0, height];
    plot(x2,y2,color,'LineWidth',10)

    The 3rd line segment is like going from 2nd to 3rd base. Try to figure this out.

    The 4th line segment is like going from 3rd base to home plate. Try to figure this out.

    Part B. Write a test file that tests your function with these inputs:

    width = 40;

    height = 30;

    color = your choice of 'b', 'c', 'g', 'k', 'r', or 'y'

    rectangle_draw_YourName(width, height, color)

    Answer

    function [ ] = rectangle_draw(width, height, color)
    %% The code opens a figure and draws a rectangle
    % The inputs are:
    % width (x direction)
    % height (y direction)
    % color: One these: 'b', 'c', 'g', 'k', 'r', or 'y'
    % There is no returned value.
    figure;
    hold on;

    %% It will draw 4 line segments.
    % Think of these as the lines between the 4 bases in baseball.
    % For each line segment, specify a vector of the first and last x coordinates
    % and a vector of the first and last y coordinates.

    % Note that the x and y vectors have only 2 values.

    %% Home to 1st base:
    x1 = [0, width];
    y1 = [0, 0];
    plot(x1,y1,color,'LineWidth',10)

    %% 1st base to 2nd base:
    x2 = [width, width];
    y2 = [0, height];
    plot(x2,y2,color,'LineWidth',10)

    %% 2nd base to 3rd base:
    x3 = [width, 0];
    y3 = [height, height];
    plot(x3,y3,color,'LineWidth',10)

    %% 3rd base to home
    x4 = [0, 0];
    y4 = [height, 0];
    plot(x4,y4,color,'LineWidth',10)

    %% % Set the x and y limits bigger than the rectangle
    xlim([-0.1*width, 1.1*width])
    ylim([-0.1*height, 1.1*height])

    .

    Exercise \(\PageIndex{1}\) Trinagle Draw

    You can use refer to the rectangle_draw.m function as a pattern for this assignment.

    Assignment:

    Write a function triangle_draw_YourName

    The code opens a figure and draws a right triangle

    % The inputs are:
    % width
    % height

    % Option: specify the color as a 3rd input. This is not required.

    % The function draws 3 line segments.

    % The 1st line segment is horizontal. x goes from 0 to width; y is 0.

    % The 2nd line segment is vertical. It goes up by height from the end of the 1st segment.

    % The 3rd line segment goes from the end of the 2nd segment back to the strating point (0, 0). This line is diagonal.

    % Write a test file that tests your function with these inputs:

    width = 40;

    height = 30;

    Answer

    The answer is not given here.

    .


    This page titled 5.8: Matlab Functions with No Outputs is shared under a CC BY-NC-SA 4.0 license and was authored, remixed, and/or curated by Carey Smith.