Skip to content

This curriculum module contains interactive live scripts that teach fundamental concepts and basic terminology related to programming computers. This module focuses on organizing code into functions, and describing, debugging, and sharing code.

License

Notifications You must be signed in to change notification settings

MathWorks-Teaching-Resources/Programming-Structuring-Code

Repository files navigation

Programming: Structuring Code

View on File Exchange or Open in MATLAB Online

MATLAB Versions Tested

Curriculum Module

Created with R2024a. Compatible with R2024a and later releases.

Information

This curriculum module contains interactive MATLAB® live scripts that teach fundamental concepts and basic terminology related to programming computers. This module focuses on organizing code into functions, describing, debugging, and sharing code.

Background

You can use these live scripts as demonstrations in lectures, class activities, or interactive assignments outside class. This module covers using built-in and user-defined functions, commenting code and choosing variable names, utilizing warning messages and run-time errors to locate and fix bugs, comparing different versions of a script, cloning a GitHub repository, and creating a MATLAB project.

The instructions inside the live scripts will guide you through the exercises and activities. Get started with each live script by running it one section at a time. To stop running the script or a section midway (for example, when an animation is in progress), use the EndIcon.png Stop button in the RUN section of the Live Editor tab in the MATLAB Toolstrip.

Contact Us

Solutions are available upon instructor request. Contact the MathWorks teaching resources team if you would like to request solutions, provide feedback, or if you have a question.

Prerequisites

This module assumes familiarity with basic programming concepts such as floating point doubles and strings, structures including constants, vectors, matrices, and arrays, and control flows including if/else, for loops, and while loops, as well as how to use them in MATLAB. These ideas are all presented with interactive examples in Fundamentals of Programming.

Getting Started

Accessing the Module

On MATLAB Online:

Use the OpenInMO.png link to download the module. You will be prompted to log in or create a MathWorks account. The project will be loaded, and you will see an app with several navigation options to get you started.

On Desktop:

Download or clone this repository. Open MATLAB, navigate to the folder containing these scripts and double-click on StructuringCode.prj. It will add the appropriate files to your MATLAB path and open an app that asks you where you would like to start.

Ensure you have all the required products (listed below) installed. If you need to include a product, add it using the Add-On Explorer. To install an add-on, go to the Home tab and select AddOnsIcon.png Add-Ons > Get Add-Ons.

Products

MATLAB® is used throughout, and the Symbolic Math Toolbox™ is used for the ShowTaylor example in Functions.mlx.

Scripts

In this script, students will...
Summary
Refactor.png
$\bullet$ use mathematical functions to use MATLAB as a calculator.
$\bullet$ use the documentation to locate functions and determine how to use them.
$\bullet$ write simple functions with inputs, outputs, and side effects, and ensure the functions are on your MATLAB path.
$\bullet$ pass functions as arguments by using function handles.
Organizing code into functions improves the readability, reusability, and ease of testing. This script addresses built-in functions, refactoring code to create functions, local functions, functions defined in their own files, programmatic scope and the MATLAB path, and how to pass functions as arguments to other functions.
In this script, students will...
Summary
StoppedAtBreakpoint.png
$\bullet$ identify warning messages and locate and fix the problem.
$\bullet$ locate and fix syntax errors.
$\bullet$ recognize and isolate run-time errors.
Everyone makes mistakes when coding or interacting with computer programs, but you can fix these mistakes. This script introduces the MATLAB Code Analyzer, errors, warnings, breakpoints, stepping, and other tools for minimizing errors as well as identifying and removing bugs from your programs.
In this script, students will...
Summary
Comment.png
$\bullet$ write comments and documentation for a self-defined function.
$\bullet$ select meaningful variable names and add code and documentation to an existing function.
Clearly documenting and communicating your thinking is essential to program with others or even your future self. This script addresses why and how you should document and comment your code.
In this script, students will...
Summary
CodeCompare.png
$\bullet$ add scripts to a project.
$\bullet$ clone a GitHub repository.
$\bullet$ use the Compare tool to see differences between two versions of the same live script
Writing code for yourself is the first step, but when you create something useful or interesting, you also need to know how to share your work with others. This script offers a brief introduction to sharing your code with others.

License

The license for this module is available in the LICENSE.md.

Related Courseware Modules

Courseware Module
Sample Content
Available on:
Programming: Organizing Data
Learn more about strings, numeric data types,
memory, and ways of storing data
image_7.png
OpenInFX.png
OpenInMO.png
GitHub
Programming: A Starter Project Using MATLAB and Python
Use MATLAB, Python, and the OpenWeather API
together to implement a weather prediction dashboard
image_10.gif
OpenInFX.png
OpenInMO.png
GitHub

Introductory content:

Or feel free to explore our other modular courseware content.

Educator Resources

Contribute

Looking for more? Find an issue? Have a suggestion? Please contact the MathWorks teaching resources team. If you want to contribute directly to this project, you can find information about how to do so in the CONTRIBUTING.md page on GitHub.

© Copyright 2024 The MathWorks™, Inc

About

This curriculum module contains interactive live scripts that teach fundamental concepts and basic terminology related to programming computers. This module focuses on organizing code into functions, and describing, debugging, and sharing code.

Topics

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages