MATLAB - Краткое руководство

MATLAB (матричная лаборатория) - это язык программирования высокого уровня четвертого поколения и интерактивная среда для численных вычислений, визуализации и программирования.

MATLAB разработан MathWorks.

Позволяет манипулировать матрицей; построение графиков функций и данных; реализация алгоритмов; создание пользовательских интерфейсов; взаимодействие с программами, написанными на других языках, включая C, C ++, Java и FORTRAN; анализировать данные; разрабатывать алгоритмы; и создавать модели и приложения.

Он имеет множество встроенных команд и математических функций, которые помогут вам в математических вычислениях, построении графиков и выполнении численных методов.

Возможности MATLAB в области вычислительной математики

MATLAB используется во всех аспектах вычислительной математики. Ниже приведены некоторые часто используемые математические вычисления, где он используется чаще всего.

  • Работа с матрицами и массивами
  • Двухмерные и трехмерные черчения и графика
  • Линейная алгебра
  • Алгебраические уравнения
  • Нелинейные функции
  • Statistics
  • Анализ данных
  • Исчисление и дифференциальные уравнения
  • Численные расчеты
  • Integration
  • Transforms
  • Подгонка кривой
  • Различные другие специальные функции

Особенности MATLAB

Ниже приведены основные функции MATLAB:

  • Это язык высокого уровня для числовых вычислений, визуализации и разработки приложений.

  • Он также предоставляет интерактивную среду для итеративного исследования, проектирования и решения проблем.

  • Он предоставляет обширную библиотеку математических функций для линейной алгебры, статистики, анализа Фурье, фильтрации, оптимизации, численного интегрирования и решения обыкновенных дифференциальных уравнений.

  • Он предоставляет встроенную графику для визуализации данных и инструменты для создания пользовательских графиков.

  • Программный интерфейс MATLAB предоставляет инструменты разработки для улучшения качества кода и повышения производительности.

  • Он предоставляет инструменты для создания приложений с настраиваемыми графическими интерфейсами.

  • Он предоставляет функции для интеграции алгоритмов на основе MATLAB с внешними приложениями и языками, такими как C, Java, .NET и Microsoft Excel.

Использование MATLAB

MATLAB широко используется в качестве вычислительного инструмента в науке и технике, охватывающем области физики, химии, математики и всех направлений инженерии. Он используется в ряде приложений, включая -

  • Обработка сигналов и связь
  • Обработка изображений и видео
  • Системы управления
  • Испытания и измерения
  • Вычислительные финансы
  • Вычислительная биология

Настройка локальной среды

Настройка среды MATLAB - дело нескольких щелчков мышью. Установщик можно скачать отсюда .

MathWorks предоставляет лицензионный продукт, пробную версию и студенческую версию. Вам необходимо авторизоваться на сайте и немного подождать их одобрения.

После загрузки установщика программное обеспечение можно установить в несколько кликов.

Понимание среды MATLAB

Среду разработки MATLAB можно запустить с помощью значка, созданного на рабочем столе. Главное рабочее окно в MATLAB называется рабочим столом. Когда MATLAB запущен, рабочий стол появляется в его компоновке по умолчанию -

На рабочем столе есть следующие панели -

  • Current Folder - Эта панель позволяет получить доступ к папкам и файлам проекта.

  • Command Window- Это основная область, где можно вводить команды в командной строке. Об этом свидетельствует командная строка (>>).

  • Workspace - В рабочем пространстве отображаются все переменные, созданные и / или импортированные из файлов.

  • Command History - На этой панели отображаются или возвращаются команды, введенные в командной строке.

Настроить GNU Octave

Если вы хотите использовать Octave на своем компьютере (Linux, BSD, OS X или Windows), пожалуйста, загрузите последнюю версию с сайта Download GNU Octave . Вы можете проверить данные инструкции по установке для вашей машины.

Среда MATLAB ведет себя как сверхсложный калькулятор. Вы можете вводить команды в командной строке >>.

MATLAB - это интерпретируемая среда. Другими словами, вы даете команду, и MATLAB сразу ее выполняет.

Практика на практике

Введите допустимое выражение, например,

5 + 5

И нажимаем ENTER

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

ans = 10

Приведем еще несколько примеров -

3 ^ 2	       % 3 raised to the power of 2

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

ans = 9

Другой пример,

sin(pi /2)	  % sine of angle 90o

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

ans = 1

Другой пример,

7/0		      % Divide by zero

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

ans = Inf
warning: division by zero

Другой пример,

732 * 20.3

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

ans =  1.4860e+04

MATLAB предоставляет некоторые специальные выражения для некоторых математических символов, таких как pi для π, Inf для ∞, i (и j) для √-1 и т. Д. Nan означает «не число».

Использование точки с запятой (;) в MATLAB

Точка с запятой (;) указывает конец инструкции. Однако, если вы хотите подавить и скрыть вывод MATLAB для выражения, добавьте точку с запятой после выражения.

Например,

x = 3;
y = x + 5

Когда вы нажимаете кнопку «Выполнить» или вводите Ctrl + E, MATLAB выполняет его немедленно, и возвращается результат -

y =  8

Добавление комментариев

Символ процента (%) используется для обозначения строки комментария. Например,

x = 9	     % assign the value 9 to x

Вы также можете написать блок комментариев, используя операторы блочных комментариев% {и%}.

Редактор MATLAB включает инструменты и элементы контекстного меню, чтобы помочь вам добавить, удалить или изменить формат комментариев.

Часто используемые операторы и специальные символы

MATLAB поддерживает следующие часто используемые операторы и специальные символы -

Оператор Цель
+ Плюс; оператор сложения.
- Минус; оператор вычитания.
* Оператор скалярного и матричного умножения.
.* Оператор умножения массива.
^ Оператор скалярного и матричного возведения в степень.
.^ Оператор возведения в степень массива.
\ Оператор левого деления.
/ Оператор правого деления.
.\ Оператор деления влево для массива.
./ Оператор правого деления массива.
: Двоеточие; генерирует элементы с регулярным интервалом и представляет собой всю строку или столбец.
( ) Скобки; включает аргументы функции и индексы массива; имеет приоритет над приоритетом.
[ ] Скобки; включает элементы массива.
. Десятичная точка.
Многоточие; оператор продолжения строки
, Запятая; разделяет операторы и элементы подряд
; Точка с запятой; разделяет столбцы и подавляет отображение.
% Знак процента; обозначает комментарий и определяет форматирование.
_ Цитировать знак и транспонировать оператор.
._ Несопряженный оператор транспонирования.
= Оператор присваивания.

Специальные переменные и константы

MATLAB поддерживает следующие специальные переменные и константы -

имя Имея в виду
ans Самый последний ответ.
eps Точность точности с плавающей запятой.
i,j Мнимая единица √-1.
Inf Бесконечность.
NaN Неопределенный числовой результат (не число).
pi Число π

Именование переменных

Имена переменных состоят из буквы, за которой следует любое количество букв, цифр или символа подчеркивания.

MATLAB - это case-sensitive.

Имена переменных могут быть любой длины, однако MATLAB использует только первые N символов, где N задается функцией namelengthmax.

Сохранение вашей работы

В save Команда используется для сохранения всех переменных в рабочей области в виде файла с расширением .mat в текущем каталоге.

Например,

save myfile

Вы можете повторно загрузить файл в любое время позже, используя load команда.

load myfile

В среде MATLAB каждая переменная представляет собой массив или матрицу.

Вы можете просто назначить переменные. Например,

x = 3	       % defining x and initializing it with a value

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

x = 3

Он создает матрицу 1 на 1 с именем x и сохраняет значение 3 в своем элементе. Давайте проверим еще один пример,

x = sqrt(16) 	% defining x and initializing it with an expression

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

x = 4

Обратите внимание, что -

  • Как только переменная введена в систему, вы можете обратиться к ней позже.

  • Перед использованием переменные должны иметь значения.

  • Когда выражение возвращает результат, который не присвоен какой-либо переменной, система присваивает его переменной с именем ans, которую можно использовать позже.

Например,

sqrt(78)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =  8.8318

Вы можете использовать эту переменную ans -

sqrt(78);
9876/ans

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =  1118.2

Давайте посмотрим на другой пример -

x = 7 * 8;
y = x * 7.89

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

y =  441.84

Множественные назначения

У вас может быть несколько заданий в одной строке. Например,

a = 2; b = 7; c = a * b

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

c = 14

Я забыл переменные!

В who команда отображает все имена переменных, которые вы использовали.

who

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

Your variables are:
a    ans  b    c

В whos команда отображает немного больше о переменных -

  • Переменные в настоящее время в памяти
  • Тип каждой переменной
  • Память, выделенная для каждой переменной
  • Являются ли они комплексными переменными или нет
whos

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

Attr Name        Size        Bytes      Class
==== ====        ====        ====       ===== 
   a             1x1           8        double
   ans           1x70         757        cell
   b             1x1           8        double
   c             1x1           8        double

Total is 73 elements using 781 bytes

В clear Команда удаляет все (или указанные) переменные из памяти.

clear x     % it will delete x, won't display anything
clear       % it will delete all variables in the workspace
            %  peacefully and unobtrusively

Долгие задания

Длинные назначения могут быть расширены до другой строки с помощью многоточия (...). Например,

initial_velocity = 0;
acceleration = 9.8;
time = 20;
final_velocity = initial_velocity + acceleration * time

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

final_velocity = 196

Формат Command

По умолчанию MATLAB отображает числа с четырьмя десятичными значениями. Это известно какshort format.

Однако, если вам нужна более высокая точность, вам нужно использовать format команда.

В format long команда отображает 16 цифр после запятой.

Например -

format long
x = 7 + 10/3 + 5 ^ 1.2

MATLAB выполнит вышеуказанный оператор и вернет следующий результат:

x = 17.2319816406394

Другой пример,

format short
x = 7 + 10/3 + 5 ^ 1.2

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

x = 17.232

В format bankкоманда округляет числа до двух десятичных знаков. Например,

format bank
daily_wage = 177.45;
weekly_wage = daily_wage * 6

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

weekly_wage = 1064.70

MATLAB отображает большие числа с использованием экспоненциальной записи.

В format short e Команда позволяет отображать в экспоненциальной форме с четырьмя десятичными знаками и показателем степени.

Например,

format short e
4.678 * 4.9

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = 2.2922e+01

В format long eКоманда позволяет отображать в экспоненциальной форме с четырьмя десятичными знаками и показателем степени. Например,

format long e
x = pi

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

x = 3.141592653589793e+00

В format ratкоманда дает наиболее близкое рациональное выражение, полученное в результате вычисления. Например,

format rat
4.678 * 4.9

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = 34177/1491

Создание векторов

Вектор - это одномерный массив чисел. MATLAB позволяет создавать два типа векторов -

  • Векторы строк
  • Векторы-столбцы

Row vectors создаются путем заключения набора элементов в квадратные скобки с использованием пробела или запятой для разделения элементов.

Например,

r = [7 8 9 10 11]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

r =

   7    8    9   10   11

Другой пример,

r = [7 8 9 10 11];
t = [2, 3, 4, 5, 6];
res = r + t

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

res =

         9         11         13         15         17

Column vectors создаются путем заключения набора элементов в квадратные скобки с использованием точки с запятой (;) для разделения элементов.

c = [7;  8;  9;  10; 11]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

c =
       7       
       8       
       9       
      10       
      11

Создание матриц

Матрица - это двумерный массив чисел.

В MATLAB матрица создается путем ввода каждой строки как последовательности элементов, разделенных пробелом или запятыми, а конец строки разграничивается точкой с запятой. Например, давайте создадим матрицу 3 на 3 как -

m = [1 2 3; 4 5 6; 7 8 9]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

m =
       1              2              3       
       4              5              6       
       7              8              9

MATLAB - это интерактивная программа для числовых вычислений и визуализации данных. Вы можете ввести команду, набрав ее в приглашении MATLAB '>>' наCommand Window.

В этом разделе мы предоставим списки часто используемых общих команд MATLAB.

Команды для управления сеансом

MATLAB предоставляет различные команды для управления сеансом. В следующей таблице представлены все такие команды -

Команда Цель
clc Очищает командное окно.
Чисто Удаляет переменные из памяти.
существовать Проверяет наличие файла или переменной.
Глобальный Объявляет переменные глобальными.
Помогите Ищет справочную тему.
искать Выполняет поиск в справочных статьях по ключевому слову.
уволиться Останавливает MATLAB.
ВОЗ Список текущих переменных.
кто Перечисляет текущие переменные (длинное отображение).

Команды для работы с системой

MATLAB предоставляет различные полезные команды для работы с системой, такие как сохранение текущей работы в рабочем пространстве в виде файла и загрузка файла позже.

Он также предоставляет различные команды для других действий, связанных с системой, таких как отображение даты, список файлов в каталоге, отображение текущего каталога и т. Д.

В следующей таблице показаны некоторые часто используемые системные команды.

Команда Цель
CD Изменяет текущий каталог.
свидание Отображает текущую дату.
удалять Удаляет файл.
дневник Включает / выключает запись файла дневника.
реж Список всех файлов в текущем каталоге.
грузить Загружает переменные рабочей области из файла.
путь Отображает путь поиска.
pwd Отображает текущий каталог.
спасти Сохраняет переменные рабочей области в файл.
тип Отображает содержимое файла.
какие Перечисляет все файлы MATLAB в текущем каталоге.
wklread Читает файл электронной таблицы .wk1.

Команды ввода и вывода

MATLAB предоставляет следующие команды, относящиеся к вводу и выводу:

Команда Цель
дисп Отображает содержимое массива или строки.
fscanf Чтение форматированных данных из файла.
формат Управляет форматом отображения экрана.
fprintf Выполняет форматированную запись на экран или в файл.
ввод Отображает запросы и ожидает ввода.
; Подавляет трафаретную печать.

В fscanf и fprintfкоманды ведут себя как функции C scanf и printf. Они поддерживают следующие коды формата -

Код формата Цель
%s Форматировать как строку.
%d Форматировать как целое число.
%f Форматировать как значение с плавающей запятой.
%e Отформатируйте как значение с плавающей запятой в экспоненциальном представлении.
%g Форматируйте в наиболее компактном виде:% f или% e.
\n Вставьте новую строку в строку вывода.
\t Вставьте табуляцию в строку вывода.

Функция формата имеет следующие формы, используемые для числового отображения:

Функция форматирования Показать до
формат короткий Четыре десятичных цифры (по умолчанию).
форматировать длинный 16 десятичных цифр.
формат короткий e Пять цифр плюс показатель степени.
формат long e 16 цифр плюс показатель степени.
формат банка Две десятичные цифры.
формат + Положительный, отрицательный или ноль.
формат крысы Рациональное приближение.
формат компактный Подавляет некоторые переводы строки.
формат свободный Возврат к менее компактному режиму отображения.

Команды вектора, матрицы и массива

В следующей таблице показаны различные команды, используемые для работы с массивами, матрицами и векторами.

Команда Цель
Кот Объединяет массивы.
находить Находит индексы ненулевых элементов.
длина Вычисляет количество элементов.
внутреннее пространство Создает регулярно расположенный вектор.
logspace Создает вектор с логарифмическими интервалами.
Максимум Возвращает самый большой элемент.
мин Возвращает наименьший элемент.
толкать Произведение каждого столбца.
изменить форму Меняет размер.
размер Вычисляет размер массива.
Сортировать Сортирует каждый столбец.
сумма Суммирует каждый столбец.
глаз Создает единичную матрицу.
те Создает массив единиц.
нули Создает массив нулей.
пересекать Вычисляет матричные перекрестные произведения.
точка Вычисляет матричные скалярные произведения.
Det Вычисляет определитель массива.
inv Вычисляет инверсию матрицы.
pinv Вычисляет псевдообратную матрицу.
ранг Вычисляет ранг матрицы.
rref Вычисляет сокращенную форму эшелона строки.
ячейка Создает массив ячеек.
celldisp Отображает массив ячеек.
участок Отображает графическое представление массива ячеек.
num2cell Преобразует числовой массив в массив ячеек.
по рукам Соответствует спискам ввода и вывода.
iscell Определяет массив ячеек.

Команды построения графиков

MATLAB предоставляет множество команд для построения графиков. В следующей таблице показаны некоторые из часто используемых команд для построения графика.

Команда Цель
ось Устанавливает пределы оси.
график Интеллектуальное построение функций.
сетка Отображает линии сетки.
сюжет Создает график xy.
Распечатать Печатает график или сохраняет график в файл.
заглавие Помещает текст в начало графика.
xlabel Добавляет текстовую метку к оси x.
ярлык Добавляет текстовую метку к оси Y.
топоры Создает объекты осей.
Закрыть Закрывает текущий сюжет.
закрыть все Закрывает все участки.
фигура Открывает новое окно рисунка.
gtext Позволяет размещать метки мышью.
держать Замораживает текущий сюжет.
легенда Размещение легенды мышью.
обновить Перерисовывает окно текущего рисунка.
набор Задает свойства таких объектов, как оси.
подсюжет Создает графики в подокнах.
текст Помещает строку в рисунок.
бар Создает гистограмму.
журнал Создает график журнала.
полярный Создает полярный сюжет.
полулогекс Создает полулогарифмический сюжет. (логарифмическая абсцисса).
полулогия Создает полулогарифмический сюжет. (логарифмическая ордината).
лестница Создает участок лестницы.
стебель Создает стволовой сюжет.

До сих пор мы использовали среду MATLAB в качестве калькулятора. Однако MATLAB также является мощным языком программирования, а также интерактивной вычислительной средой.

В предыдущих главах вы узнали, как вводить команды из командной строки MATLAB. MATLAB также позволяет вам записывать серию команд в файл и выполнять файл как полную единицу, например, писать функцию и вызывать ее.

Файлы M

MATLAB позволяет писать два типа программных файлов -

  • Scripts - файлы сценариев - это программные файлы с .m extension. В этих файлах вы пишете серию команд, которые хотите выполнять вместе. Скрипты не принимают входные данные и не возвращают никаких выходных данных. Они работают с данными в рабочей области.

  • Functions - файлы функций также являются программными файлами с .m extension. Функции могут принимать входные и выходные данные. Внутренние переменные являются локальными для функции.

Вы можете использовать редактор MATLAB или любой другой текстовый редактор, чтобы создать свой .mфайлы. В этом разделе мы обсудим файлы сценариев. Файл сценария содержит несколько последовательных строк команд MATLAB и вызовов функций. Вы можете запустить сценарий, набрав его имя в командной строке.

Создание и запуск файла сценария

Для создания файлов сценариев необходимо использовать текстовый редактор. Вы можете открыть редактор MATLAB двумя способами -

  • Использование командной строки
  • Использование IDE

Если вы используете командную строку, введите editв командной строке. Это откроет редактор. Вы можете напрямую ввестиedit а затем имя файла (с расширением .m)

edit 
Or
edit <filename>

Приведенная выше команда создаст файл в каталоге MATLAB по умолчанию. Если вы хотите хранить все программные файлы в определенной папке, вам нужно будет указать полный путь.

Создадим папку с именем progs. Введите следующие команды в командной строке (>>) -

mkdir progs    % create directory progs under default directory
chdir progs    % changing the current directory to progs
edit  prog1.m  % creating an m file named prog1.m

Если вы создаете файл в первый раз, MATLAB предлагает вам подтвердить его. Щелкните Да.

Либо, если вы используете IDE, выберите NEW -> Script. Это также открывает редактор и создает файл с именем Untitled. Вы можете назвать файл и сохранить его после ввода кода.

Введите в редакторе следующий код -

NoOfStudents = 6000;
TeachingStaff = 150;
NonTeachingStaff = 20;
Total = NoOfStudents + TeachingStaff ...
   + NonTeachingStaff;
disp(Total);

После создания и сохранения файла вы можете запустить его двумя способами:

  • Нажав на Run кнопку в окне редактора или

  • Просто введите имя файла (без расширения) в командной строке: >> prog1

В командной строке отображается результат -

6170

пример

Создайте файл сценария и введите следующий код -

a = 5; b = 7;
c = a + b
d = c + sin(b)
e = 5 * d
f = exp(-d)

Когда приведенный выше код компилируется и выполняется, он дает следующий результат:

c =  12
d =  12.657
e =  63.285
f =    3.1852e-06

MATLAB не требует какого-либо объявления типа или операторов измерения. Всякий раз, когда MATLAB встречает новое имя переменной, он создает переменную и выделяет соответствующее пространство памяти.

Если переменная уже существует, то MATLAB заменяет исходное содержимое новым содержимым и выделяет новое пространство для хранения, где это необходимо.

Например,

Total = 42

Вышеупомянутый оператор создает матрицу 1 на 1 с именем Total и сохраняет в ней значение 42.

Типы данных, доступные в MATLAB

MATLAB предоставляет 15 основных типов данных. Каждый тип данных хранит данные в форме матрицы или массива. Размер этой матрицы или массива составляет минимум 0 на 0, и он может увеличиваться до матрицы или массива любого размера.

В следующей таблице показаны наиболее часто используемые типы данных в MATLAB -

Sr.No. Тип данных и описание
1

int8

8-битное целое число со знаком

2

uint8

8-битное целое число без знака

3

int16

16-битное целое число со знаком

4

uint16

16-битное целое число без знака

5

int32

32-битное целое число со знаком

6

uint32

32-битное целое число без знака

7

int64

64-битное целое число со знаком

8

uint64

64-битное целое число без знака

9

single

числовые данные одинарной точности

10

double

числовые данные двойной точности

11

logical

логические значения 1 или 0 представляют истину и ложь соответственно

12

char

символьные данные (строки хранятся как вектор символов)

13

cell array

массив проиндексированных ячеек, каждая из которых может хранить массив другого измерения и типа данных

14

structure

C-подобные структуры, каждая структура имеет именованные поля, способные хранить массив другого измерения и типа данных

15

function handle

указатель на функцию

16

user classes

объекты, созданные из определенного пользователем класса

17

java classes

объекты, созданные из класса Java

пример

Создайте файл сценария со следующим кодом -

str = 'Hello World!'
n = 2345
d = double(n)
un = uint32(789.50)
rn = 5678.92347
c = int32(rn)

Когда приведенный выше код компилируется и выполняется, он дает следующий результат:

str = Hello World!
n =  2345
d =  2345
un = 790
rn = 5678.9
c =  5679

Преобразование типов данных

MATLAB предоставляет различные функции для преобразования значения из одного типа данных в другой. В следующей таблице показаны функции преобразования типов данных -

Функция Цель
char Преобразовать в символьный массив (строку)
int2str Преобразование целочисленных данных в строку
mat2str Преобразовать матрицу в строку
num2str Преобразовать число в строку
str2double Преобразовать строку в значение с двойной точностью
str2num Преобразовать строку в число
native2unicode Преобразование числовых байтов в символы Юникода
unicode2native Преобразование символов Юникода в числовые байты
base2dec Преобразование числовой строки с основанием N в десятичное число
bin2dec Преобразование строки двоичного числа в десятичное число
dec2base Преобразование десятичного числа в число с основанием N в строке
dec2bin Преобразование десятичного числа в двоичное в строке
dec2hex Преобразование десятичного числа в шестнадцатеричное в строке
hex2dec Преобразование строки шестнадцатеричного числа в десятичное число
hex2num Преобразование строки шестнадцатеричного числа в число двойной точности
num2hex Преобразование одиночных и двойных чисел в шестнадцатеричные строки IEEE
cell2mat Преобразование массива ячеек в числовой массив
cell2struct Преобразование массива ячеек в массив структур
Cellstr Создать массив ячеек строк из массива символов
mat2cell Преобразование массива в массив ячеек с ячейками потенциально разного размера
num2cell Преобразование массива в массив ячеек с ячейками постоянного размера
struct2cell Преобразовать структуру в массив ячеек

Определение типов данных

MATLAB предоставляет различные функции для идентификации типа данных переменной.

В следующей таблице представлены функции для определения типа данных переменной.

Функция Цель
является Обнаружить состояние
это Определите, является ли ввод объектом указанного класса
iscell Определите, является ли ввод массивом ячеек
iscellstr Определите, является ли ввод массивом ячеек строк
Ischar Определите, является ли элемент массивом символов
Isfield Определите, является ли ввод полем массива структуры
Isfloat Определите, является ли ввод массивом с плавающей запятой
ishghandle Истина для дескрипторов графических объектов
целое число Определите, является ли ввод целочисленным массивом
Isjava Определите, является ли ввод объектом Java
логичен Определите, является ли ввод логическим массивом
нечисловой Определите, является ли ввод числовым массивом
изобъект Определите, является ли ввод объектом MATLAB
это реально Проверьте, является ли ввод реальным массивом
Искаляр Определите, является ли ввод скалярным
isstr Определите, является ли ввод массивом символов
строить Определите, является ли ввод структурным массивом
isvector Определите, является ли ввод векторным
класс Определить класс объекта
проверить атрибуты Проверить действительность массива
кто Список переменных в рабочей области с размерами и типами

пример

Создайте файл сценария со следующим кодом -

x = 3
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)
 
x = 23.54
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)
 
x = [1 2 3]
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
 
x = 'Hello'
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)

Когда вы запускаете файл, он дает следующий результат -

x = 3
ans = 0
ans = 1
ans = 1
ans = 1
ans = 1
x = 23.540
ans = 0
ans = 1
ans = 1
ans = 1
ans = 1
x =

          1          2          3

ans = 0
ans = 1
ans = 1
ans = 0
x = Hello
ans = 0
ans = 0
ans = 1
ans = 0
ans = 0

Оператор - это символ, который сообщает компилятору о необходимости выполнения определенных математических или логических операций. MATLAB предназначен для работы в первую очередь с целыми матрицами и массивами. Следовательно, операторы в MATLAB работают как со скалярными, так и с нескалярными данными. MATLAB позволяет выполнять следующие типы элементарных операций -

  • Арифметические операторы
  • Операторы отношения
  • Логические операторы
  • Побитовые операции
  • Установить операции

Арифметические операторы

MATLAB позволяет выполнять два разных типа арифметических операций -

  • Матричные арифметические операции
  • Арифметические операции с массивами

Матричные арифметические операции такие же, как и в линейной алгебре. Операции с массивами выполняются поэлементно, как над одномерным, так и с многомерным массивом.

Операторы матрицы и операторы массива различаются символом точки (.). Однако, поскольку операции сложения и вычитания одинаковы для матриц и массивов, оператор одинаков для обоих случаев. В следующей таблице дано краткое описание операторов -

Показать примеры

Sr.No. Оператор и описание
1

+

Дополнение или одинарный плюс. A + B складывает значения, хранящиеся в переменных A и B. A и B должны иметь одинаковый размер, если только один не является скаляром. Скаляр можно добавить к матрице любого размера.

2

-

Вычитание или унарный минус. AB вычитает значение B из A. A и B должны иметь одинаковый размер, если только один не является скаляром. Скаляр можно вычесть из матрицы любого размера.

3

*

Умножение матриц. C = A * B - линейное алгебраическое произведение матриц A и B. Точнее,

Для нескалярных A и B количество столбцов A должно быть равно количеству строк B. Скаляр может умножать матрицу любого размера.

4

.*

Умножение массива. A. * B - это поэлементное произведение массивов A и B. A и B должны иметь одинаковый размер, если только один из них не является скаляром.

5

/

Косая черта или матричное деление справа. B / A примерно то же самое, что B * inv (A). Точнее, B / A = (A '\ B') '.

6

./

Правое деление массива. A./B - матрица с элементами A (i, j) / B (i, j). A и B должны иметь одинаковый размер, если только один из них не является скаляром.

7

\

Обратная косая черта или матричное левое деление. Если A - квадратная матрица, A \ B примерно то же самое, что inv (A) * B, за исключением того, что вычисляется другим способом. Если А является п-по-п матрицы и В представляет собой вектор - столбец с п компонентами, или матрицу с несколькими такими столбцами, то Х = А \ В является решением уравнения AX = B . Предупреждающее сообщение отображается, если A плохо масштабирован или почти единичный.

8

.\

Левое деление массива. A. \ B - матрица с элементами B (i, j) / A (i, j). A и B должны иметь одинаковый размер, если только один из них не является скаляром.

9

^

Матрица мощности. X ^ p - это X в степени p, если p - скаляр. Если p - целое число, мощность вычисляется путем повторного возведения в квадрат. Если целое число отрицательное, сначала инвертируется X. Для других значений p в расчет используются собственные значения и собственные векторы, так что если [V, D] = eig (X), то X ^ p = V * D. ^ p / V.

10

.^

Мощность массива. A. ^ B - матрица с элементами A (i, j) в степени B (i, j). A и B должны иметь одинаковый размер, если только один из них не является скаляром.

11

'

Матрица транспонирована. A '- это линейное алгебраическое транспонирование A. Для комплексных матриц это комплексно-сопряженное транспонирование.

12

.'

Транспонирование массива. А. ' - это массив, транспонированный к A. Для сложных матриц это не требует сопряжения.

Операторы отношения

Операторы отношения также могут работать как с скалярными, так и с нескалярными данными. Операторы отношения для массивов выполняют поэлементное сравнение между двумя массивами и возвращают логический массив того же размера с элементами, установленными на логическую 1 (истина), где отношение истинно, и элементами, установленными на логический 0 (ложь), где это не.

В следующей таблице показаны реляционные операторы, доступные в MATLAB -

Показать примеры

Sr.No. Оператор и описание
1

<

Меньше, чем

2

<=

Меньше или равно

3

>

Лучше чем

4

>=

Больше или равно

5

==

Равно

6

~=

Не равно

Логические операторы

MATLAB предлагает два типа логических операторов и функций -

  • Поэлементно - эти операторы работают с соответствующими элементами логических массивов.

  • Короткое замыкание - эти операторы работают со скалярными и логическими выражениями.

Поэлементные логические операторы работают с логическими массивами поэлементно. Символы &, | и ~ являются операторами логического массива И, ИЛИ и НЕ.

Логические операторы короткого замыкания позволяют замыкать логические операции. Символы && и || являются логическими операторами короткого замыкания И и ИЛИ.

Показать примеры

Побитовые операции

Поразрядные операторы работают с битами и выполняют побитовые операции. Таблицы истинности для &, | и ^ следующие:

п q p & q p | q p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

Допустим, если A = 60; и B = 13; Теперь в двоичном формате они будут такими:

А = 0011 1100

В = 0000 1101

-----------------

A&B = 0000 1100

А | В = 0011 1101

A ^ B = 0011 0001

~ А = 1100 0011

MATLAB предоставляет различные функции для побитовых операций, таких как операции «побитовое и», «побитовое или» и «побитовое не», операция сдвига и т. Д.

В следующей таблице показаны обычно используемые побитовые операции -

Показать примеры

Функция Цель
битанд (а, б) Побитовое И целых чисел a и b
bitcmp (а) Двоичное дополнение а
bitget (a, pos) Получить бит в указанной позиции pos в целочисленном массиве a
битор (а, б) Побитовое ИЛИ целых чисел a и b
bitset (a, pos) Набор бит в определенном месте поз из а
битовый сдвиг (а, к) Возвращает сдвинуто влево на K битов, что эквивалентно умножению на 2 к . Отрицательные значения k соответствуют сдвигу битов вправо или делению на 2 | k | и округление до ближайшего целого числа в сторону отрицательной бесконечности. Любые биты переполнения усекаются.
bitxor (а, б) Побитовое исключающее ИЛИ целых чисел a и b
swapbytes Поменять местами порядок байтов

Установить операции

MATLAB предоставляет различные функции для операций с множеством, такие как объединение, пересечение и проверка принадлежности к множеству и т. Д.

В следующей таблице показаны некоторые часто используемые операции с наборами -

Показать примеры

Sr.No. Описание функции
1

intersect(A,B)

Установить пересечение двух массивов; возвращает значения, общие для A и B. Возвращенные значения отсортированы.

2

intersect(A,B,'rows')

Treats each row of A and each row of B as single entities and returns the rows common to both A and B. The rows of the returned matrix are in sorted order.

3

ismember(A,B)

Returns an array the same size as A, containing 1 (true) where the elements of A are found in B. Elsewhere, it returns 0 (false).

4

ismember(A,B,'rows')

Treats each row of A and each row of B as single entities and returns a vector containing 1 (true) where the rows of matrix A are also rows of B. Elsewhere, it returns 0 (false).

5

issorted(A)

Returns logical 1 (true) if the elements of A are in sorted order and logical 0 (false) otherwise. Input A can be a vector or an N-by-1 or 1-by-N cell array of strings. A is considered to be sorted if A and the output of sort(A) are equal.

6

issorted(A, 'rows')

Returns logical 1 (true) if the rows of two-dimensional matrix A is in sorted order, and logical 0 (false) otherwise. Matrix A is considered to be sorted if A and the output of sortrows(A) are equal.

7

setdiff(A,B)

Sets difference of two arrays; returns the values in A that are not in B. The values in the returned array are in sorted order.

8

setdiff(A,B,'rows')

Treats each row of A and each row of B as single entities and returns the rows from A that are not in B. The rows of the returned matrix are in sorted order.

The 'rows' option does not support cell arrays.

9

setxor

Sets exclusive OR of two arrays

10

union

Sets union of two arrays

11

unique

Unique values in array

Decision making structures require that the programmer should specify one or more conditions to be evaluated or tested by the program, along with a statement or statements to be executed if the condition is determined to be true, and optionally, other statements to be executed if the condition is determined to be false.

Following is the general form of a typical decision making structure found in most of the programming languages −

MATLAB provides following types of decision making statements. Click the following links to check their detail −

Sr.No. Statement & Description
1 if ... end statement

An if ... end statement consists of a boolean expression followed by one or more statements.

2 if...else...end statement

An if statement can be followed by an optional else statement, which executes when the boolean expression is false.

3 If... elseif...elseif...else...end statements

An if statement can be followed by one (or more) optional elseif... and an else statement, which is very useful to test various conditions.

4 nested if statements

You can use one if or elseif statement inside another if or elseif statement(s).

5 switch statement

A switch statement allows a variable to be tested for equality against a list of values.

6 nested switch statements

You can use one switch statement inside another switch statement(s).

There may be a situation when you need to execute a block of code several number of times. In general, statements are executed sequentially. The first statement in a function is executed first, followed by the second, and so on.

Programming languages provide various control structures that allow for more complicated execution paths.

A loop statement allows us to execute a statement or group of statements multiple times and following is the general form of a loop statement in most of the programming languages −

MATLAB provides following types of loops to handle looping requirements. Click the following links to check their detail −

Sr.No. Loop Type & Description
1 while loop

Repeats a statement or group of statements while a given condition is true. It tests the condition before executing the loop body.

2 for loop

Executes a sequence of statements multiple times and abbreviates the code that manages the loop variable.

3 nested loops

You can use one or more loops inside any another loop.

Loop Control Statements

Loop control statements change execution from its normal sequence. When execution leaves a scope, all automatic objects that were created in that scope are destroyed.

MATLAB supports the following control statements. Click the following links to check their detail.

Sr.No. Control Statement & Description
1 break statement

Terminates the loop statement and transfers execution to the statement immediately following the loop.

2 continue statement

Causes the loop to skip the remainder of its body and immediately retest its condition prior to reiterating.

A vector is a one-dimensional array of numbers. MATLAB allows creating two types of vectors −

  • Row vectors
  • Column vectors

Row Vectors

Row vectors are created by enclosing the set of elements in square brackets, using space or comma to delimit the elements.

r = [7 8 9 10 11]

MATLAB will execute the above statement and return the following result −

r =

   7    8    9   10   11

Column Vectors

Column vectors are created by enclosing the set of elements in square brackets, using semicolon to delimit the elements.

c = [7;  8;  9;  10; 11]

MATLAB will execute the above statement and return the following result −

c =
      7       
      8       
      9       
      10       
      11

Referencing the Elements of a Vector

You can reference one or more of the elements of a vector in several ways. The ith component of a vector v is referred as v(i). For example −

v = [ 1; 2; 3; 4; 5; 6];	% creating a column vector of 6 elements
v(3)

MATLAB will execute the above statement and return the following result −

ans =  3

When you reference a vector with a colon, such as v(:), all the components of the vector are listed.

v = [ 1; 2; 3; 4; 5; 6];	% creating a column vector of 6 elements
v(:)

MATLAB will execute the above statement and return the following result −

ans =
     1
     2
     3
     4
     5
     6

MATLAB allows you to select a range of elements from a vector.

For example, let us create a row vector rv of 9 elements, then we will reference the elements 3 to 7 by writing rv(3:7) and create a new vector named sub_rv.

rv = [1 2 3 4 5 6 7 8 9];
sub_rv = rv(3:7)

MATLAB will execute the above statement and return the following result −

sub_rv =

   3   4   5   6   7

Vector Operations

In this section, let us discuss the following vector operations −

  • Addition and Subtraction of Vectors

  • Scalar Multiplication of Vectors

  • Transpose of a Vector

  • Appending Vectors

  • Magnitude of a Vector

  • Vector Dot Product

  • Vectors with Uniformly Spaced Elements

A matrix is a two-dimensional array of numbers.

In MATLAB, you create a matrix by entering elements in each row as comma or space delimited numbers and using semicolons to mark the end of each row.

For example, let us create a 4-by-5 matrix a

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8]

MATLAB will execute the above statement and return the following result −

a =
      1     2     3     4     5
      2     3     4     5     6
      3     4     5     6     7
      4     5     6     7     8

Referencing the Elements of a Matrix

To reference an element in the mth row and nth column, of a matrix mx, we write −

mx(m, n);

Например, чтобы сослаться на элемент во 2- й строке и 5- м столбце матрицы a , созданной в последнем разделе, мы набираем -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(2,5)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =  6

Чтобы ссылаться на все элементы в m- м столбце, мы набираем A (:, m).

Создадим вектор-столбец v из элементов 4- й строки матрицы a -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
v = a(:,4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

v =
      4
      5
      6
      7

Вы также можете выбрать элементы в столбцах с m- го по n- й , для этого мы пишем -

a(:,m:n)

Давайте создадим матрицу меньшего размера, взяв элементы из второго и третьего столбцов -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(:, 2:3)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
      2     3
      3     4
      4     5
      5     6

Таким же образом вы можете создать подматрицу, взяв подчасть матрицы.

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(:, 2:3)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
      2     3
      3     4
      4     5
      5     6

Таким же образом вы можете создать подматрицу, взяв подчасть матрицы.

Например, давайте создадим подматрицу sa, взяв внутреннюю подчасть -

3     4     5     
4     5     6

Для этого напишите -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
sa = a(2:3,2:4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

sa =
      3     4     5
      4     5     6

Удаление строки или столбца в матрице

Вы можете удалить всю строку или столбец матрицы, назначив пустой набор квадратных скобок [] этой строке или столбцу. Обычно [] обозначает пустой массив.

Например, давайте удалим четвертую строку -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a( 4 , : ) = []

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

a =
      1     2     3     4     5
      2     3     4     5     6
      3     4     5     6     7

Затем давайте удалим пятую колонку -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(: , 5)=[]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

a =
      1     2     3     4
      2     3     4     5
      3     4     5     6
      4     5     6     7

пример

В этом примере давайте создадим матрицу m 3 на 3, затем мы дважды скопируем вторую и третью строки этой матрицы, чтобы создать матрицу 4 на 3.

Создайте файл сценария со следующим кодом -

a = [ 1 2 3 ; 4 5 6; 7 8 9];
new_mat = a([2,3,2,3],:)

Когда вы запускаете файл, он отображает следующий результат -

new_mat =
      4     5     6
      7     8     9
      4     5     6
      7     8     9

Матричные операции

В этом разделе давайте обсудим следующие основные и часто используемые матричные операции:

  • Сложение и вычитание матриц

  • Деление матриц

  • Скалярные операции с матрицами

  • Транспонирование матрицы

  • Объединение матриц

  • Умножение матриц

  • Определитель матрицы

  • Обратная матрица

Все переменные всех типов данных в MATLAB - это многомерные массивы. Вектор - это одномерный массив, а матрица - двумерный массив.

Мы уже обсуждали векторы и матрицы. В этой главе мы обсудим многомерные массивы. Однако перед этим давайте обсудим некоторые специальные типы массивов.

Специальные массивы в MATLAB

В этом разделе мы обсудим некоторые функции, которые создают специальные массивы. Для всех этих функций один аргумент создает квадратный массив, двойной аргумент создает прямоугольный массив.

В zeros() функция создает массив всех нулей -

Например -

zeros(5)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0

В ones() функция создает массив из всех -

Например -

ones(4,3)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
      1     1     1
      1     1     1
      1     1     1
      1     1     1

В eye() функция создает единичную матрицу.

Например -

eye(4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
      1     0     0     0
      0     1     0     0
      0     0     1     0
      0     0     0     1

В rand() функция создает массив равномерно распределенных случайных чисел на (0,1) -

Например -

rand(3, 5)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   0.8147    0.9134    0.2785    0.9649    0.9572
   0.9058    0.6324    0.5469    0.1576    0.4854
   0.1270    0.0975    0.9575    0.9706    0.8003

Волшебный квадрат

А magic square квадрат, который дает ту же сумму, когда его элементы складываются по строкам, столбцам или по диагонали.

В magic()функция создает массив магических квадратов. Требуется единственный аргумент, который дает размер квадрата. Аргумент должен быть скаляром, большим или равным 3.

magic(4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   16     2     3    13
   5    11    10     8
   9     7     6    12
   4    14    15     1

Многомерные массивы

Массив, имеющий более двух измерений, называется в MATLAB многомерным массивом. Многомерные массивы в MATLAB являются расширением нормальной двумерной матрицы.

Обычно для создания многомерного массива мы сначала создаем двумерный массив и расширяем его.

Например, давайте создадим двумерный массив a.

a = [7 9 5; 6 1 9; 4 3 2]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

a =
   7     9     5
   6     1     9
   4     3     2

Массив a представляет собой массив 3 на 3; мы можем добавить третье измерение к a , указав такие значения, как -

a(:, :, 2)= [ 1 2 3; 4 5 6; 7 8 9]

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

a =

ans(:,:,1) =

   0   0   0
   0   0   0
   0   0   0

ans(:,:,2) =

   1   2   3
   4   5   6
   7   8   9

Мы также можем создавать многомерные массивы, используя функции ones (), zeros () или rand ().

Например,

b = rand(4,3,2)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

b(:,:,1) =
   0.0344    0.7952    0.6463
   0.4387    0.1869    0.7094
   0.3816    0.4898    0.7547
   0.7655    0.4456    0.2760

b(:,:,2) =
   0.6797    0.4984    0.2238
   0.6551    0.9597    0.7513
   0.1626    0.3404    0.2551
   0.1190    0.5853    0.5060

Мы также можем использовать cat()функция для построения многомерных массивов. Он объединяет список массивов по указанному измерению -

Синтаксис функции cat ():

B = cat(dim, A1, A2...)

Где,

  • B - новый созданный массив

  • A1 , A2 , ... - объединяемые массивы

  • dim - это размерность, по которой объединяются массивы

пример

Создайте файл сценария и введите в него следующий код -

a = [9 8 7; 6 5 4; 3 2 1];
b = [1 2 3; 4 5 6; 7 8 9];
c = cat(3, a, b, [ 2 3 1; 4 7 8; 3 9 0])

Когда вы запускаете файл, он отображает -

c(:,:,1) =
      9     8     7
      6     5     4
      3     2     1
c(:,:,2) =
      1     2     3
      4     5     6
      7     8     9
c(:,:,3) =
      2     3     1
      4     7     8
      3     9     0

Функции для работы с массивами

MATLAB предоставляет следующие функции для сортировки, поворота, перестановки, изменения формы или сдвига содержимого массива.

Функция Цель
длина Длина вектора или наибольшее измерение массива
ndims Количество измерений массива
число Количество элементов массива
размер Размеры массива
iscolumn Определяет, является ли ввод вектор-столбцом
пусто Определяет, пуст ли массив
ismatrix Определяет, является ли ввод матричным
Isrow Определяет, является ли ввод векторной строкой
Искаляр Определяет, является ли ввод скалярным
isvector Определяет, является ли ввод векторным
blkdiag Строит блочно-диагональную матрицу из входных аргументов
круговой сдвиг Сдвигает массив по кругу
ctranspose Комплексно сопряженное транспонирование
диагональ Диагональные матрицы и диагонали матрицы
флипдим Переворачивает массив по указанному размеру
fliplr Переворачивает матрицу слева направо
флипуд Переворачивает матрицу вверх вниз
ipermute Инвертирует перестановку размеров массива ND
переставлять Переставляет размеры массива ND
повторять Реплики и массив плиток
изменить форму Изменяет массив
гниль90 Поворачивает матрицу на 90 градусов
shiftdim Сдвигает размеры
рассортированный Определяет, отсортированы ли элементы набора
Сортировать Сортирует элементы массива в порядке возрастания или убывания
сортировки Сортирует строки в порядке возрастания
сжимать Удаляет одноэлементные размеры
транспонировать Транспонировать
векторизовать Векторизует выражение

Примеры

Следующие примеры иллюстрируют некоторые из упомянутых выше функций.

Length, Dimension and Number of elements −

Создайте файл сценария и введите в него следующий код -

x = [7.1, 3.4, 7.2, 28/4, 3.6, 17, 9.4, 8.9];
length(x)      % length of x vector
y = rand(3, 4, 5, 2);
ndims(y)       % no of dimensions in array y
s = ['Zara', 'Nuha', 'Shamim', 'Riz', 'Shadab'];
numel(s)       % no of elements in s

Когда вы запускаете файл, он отображает следующий результат -

ans =  8
ans =  4
ans =  23

Circular Shifting of the Array Elements −

Создайте файл сценария и введите в него следующий код -

a = [1 2 3; 4 5 6; 7 8 9]  % the original array a
b = circshift(a,1)         %  circular shift first dimension values down by 1.
c = circshift(a,[1 -1])    % circular shift first dimension values % down by 1 
                           % and second dimension values to the left % by 1.

Когда вы запускаете файл, он отображает следующий результат -

a =
   1     2     3
   4     5     6
   7     8     9

b =
   7     8     9
   1     2     3
   4     5     6

c =
   8     9     7
   2     3     1
   5     6     4

Сортировка массивов

Создайте файл сценария и введите в него следующий код -

v = [ 23 45 12 9 5 0 19 17]  % horizontal vector
sort(v)                      % sorting v
m = [2 6 4; 5 3 9; 2 0 1]    % two dimensional array
sort(m, 1)                   % sorting m along the row
sort(m, 2)                   % sorting m along the column

Когда вы запускаете файл, он отображает следующий результат -

v =
   23    45    12     9     5     0    19    17
ans =
   0     5     9    12    17    19    23    45
m =
   2     6     4
   5     3     9
   2     0     1
ans =
   2     0     1
   2     3     4
   5     6     9
ans =
   2     4     6
   3     5     9
   0     1     2

Массив ячеек

Массивы ячеек - это массивы проиндексированных ячеек, каждая из которых может хранить массив различных размеров и типов данных.

В cellфункция используется для создания массива ячеек. Синтаксис функции ячейки -

C = cell(dim)
C = cell(dim1,...,dimN)
D = cell(obj)

Где,

  • C - массив ячеек;

  • dim - скалярное целое число или вектор целых чисел, определяющий размеры массива ячеек C;

  • dim1, ..., dimN - целые скалярные числа, определяющие размеры C;

  • obj является одним из следующих:

    • Массив или объект Java
    • .NET-массив типа System.String или System.Object

пример

Создайте файл сценария и введите в него следующий код -

c = cell(2, 5);
c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5}

Когда вы запускаете файл, он отображает следующий результат -

c = 
{
   [1,1] = Red
   [2,1] =  1
   [1,2] = Blue
   [2,2] =  2
   [1,3] = Green
   [2,3] =  3
   [1,4] = Yellow
   [2,4] =  4
   [1,5] = White
   [2,5] =  5
}

Доступ к данным в массивах ячеек

Есть два способа обратиться к элементам массива ячеек:

  • Заключение индексов в первую скобку () для обозначения наборов ячеек
  • Заключение индексов в фигурные скобки {} для ссылки на данные в отдельных ячейках.

Когда вы заключаете индексы в первую скобку, это относится к набору ячеек.

Индексы массива ячеек в круглых скобках относятся к наборам ячеек.

Например -

c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5};
c(1:2,1:2)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = 
{
   [1,1] = Red
   [2,1] =  1
   [1,2] = Blue
   [2,2] =  2
}

Вы также можете получить доступ к содержимому ячеек путем индексации с помощью фигурных скобок.

Например -

c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5};
c{1, 2:4}

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = Blue
ans = Green
ans = Yellow

В colon(:)является одним из самых полезных операторов в MATLAB. Он используется для создания векторов, массивов индексов иspecify for iterations.

Если вы хотите создать вектор-строку, содержащий целые числа от 1 до 10, вы пишете -

1:10

MATLAB выполняет инструкцию и возвращает вектор-строку, содержащий целые числа от 1 до 10 -

ans =                                                                           
                                                                                
   1    2    3    4    5    6    7    8    9   10

Если вы хотите указать значение приращения, отличное от единицы, например -

100: -5: 50

MATLAB выполняет инструкцию и возвращает следующий результат -

ans =
   100    95    90    85    80    75    70    65    60    55    50

Возьмем другой пример -

0:pi/8:pi

MATLAB выполняет инструкцию и возвращает следующий результат -

ans =
   Columns 1 through 7
      0    0.3927    0.7854    1.1781    1.5708    1.9635    2.3562
   Columns 8 through 9
      2.7489    3.1416

Вы можете использовать оператор двоеточия, чтобы создать вектор индексов для выбора строк, столбцов или элементов массивов.

В следующей таблице описывается его использование для этой цели (пусть у нас есть матрица A) -

Формат Цель
A(:,j) является j-м столбцом A.
A(i,:) это i-я строка матрицы A.
A(:,:) - эквивалентный двумерный массив. Для матриц это то же самое, что и A.
A(j:k) есть A (j), A (j + 1), ..., A (k).
A(:,j:k) это A (:, j), A (:, j + 1), ..., A (:, k).
A(:,:,k) k- я страница трехмерного массива A.
A(i,j,k,:) - это вектор в четырехмерном массиве A. Вектор включает в себя A (i, j, k, 1), A (i, j, k, 2), A (i, j, k, 3) и так далее.
A(:) - это все элементы A, рассматриваемые как один столбец. В левой части оператора присваивания A (:) заполняет A, сохраняя его форму. В этом случае правая часть должна содержать то же количество элементов, что и A.

пример

Создайте файл сценария и введите в него следующий код -

A = [1 2 3 4; 4 5 6 7; 7 8 9 10]
A(:,2)      % second column of A
A(:,2:3)    % second and third column of A
A(2:3,2:3)  % second and third rows and second and third columns

Когда вы запускаете файл, он отображает следующий результат -

A =
      1     2     3     4
      4     5     6     7
      7     8     9    10

ans =
      2
      5
      8

ans =
      2     3
      5     6
      8     9

ans =
      5     6
      8     9

MATLAB поддерживает различные числовые классы, которые включают целые числа со знаком и без знака, а также числа с плавающей запятой одинарной и двойной точности. По умолчанию MATLAB сохраняет все числовые значения как числа с плавающей запятой двойной точности.

Вы можете хранить любое число или массив чисел как целые числа или как числа с одинарной точностью.

Все числовые типы поддерживают основные операции с массивами и математические операции.

Преобразование в различные числовые типы данных

MATLAB предоставляет следующие функции для преобразования в различные числовые типы данных -

Функция Цель
двойной Преобразует в число двойной точности
не замужем Преобразует в число одинарной точности
int8 Преобразует в 8-битовое целое число со знаком
int16 Преобразует в 16-разрядное целое число со знаком
int32 Преобразует в 32-битное целое число со знаком
int64 Преобразует в 64-битное целое число со знаком
uint8 Преобразует в 8-битовое целое число без знака
uint16 Преобразует в 16-битовое целое число без знака
uint32 Преобразует в 32-битное целое число без знака
uint64 Преобразует в 64-битное целое число без знака

пример

Создайте файл сценария и введите следующий код -

x = single([5.32 3.47 6.28]) .* 7.5
x = double([5.32 3.47 6.28]) .* 7.5
x = int8([5.32 3.47 6.28]) .* 7.5
x = int16([5.32 3.47 6.28]) .* 7.5
x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5

Когда вы запускаете файл, он показывает следующий результат -

x =

   39.900   26.025   47.100

x =

   39.900   26.025   47.100

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

пример

Давайте еще немного расширим предыдущий пример. Создайте файл сценария и введите следующий код -

x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5
x = num2cell(x)

Когда вы запускаете файл, он показывает следующий результат -

x =

   38  23  45

x =

   38  23  45

x = 
{
   [1,1] = 38
   [1,2] = 23
   [1,3] = 45
}

Наименьшее и наибольшее целые числа

Функции intmax() и intmin() возвращают максимальное и минимальное значения, которые могут быть представлены всеми типами целых чисел.

Обе функции принимают в качестве аргумента целочисленный тип данных, например intmax (int8) или intmin (int64), и возвращают максимальное и минимальное значения, которые вы можете представить с помощью целочисленного типа данных.

пример

В следующем примере показано, как получить наименьшее и наибольшее значения целых чисел. Создайте файл сценария и напишите в нем следующий код -

% displaying the smallest and largest signed integer data
str = 'The range for int8 is:\n\t%d to %d ';
sprintf(str, intmin('int8'), intmax('int8'))
str = 'The range for int16 is:\n\t%d to %d ';
sprintf(str, intmin('int16'), intmax('int16'))
str = 'The range for int32 is:\n\t%d to %d ';
sprintf(str, intmin('int32'), intmax('int32'))
str = 'The range for int64 is:\n\t%d to %d ';
sprintf(str, intmin('int64'), intmax('int64'))
 
% displaying the smallest and largest unsigned integer data
str = 'The range for uint8 is:\n\t%d to %d ';
sprintf(str, intmin('uint8'), intmax('uint8'))
str = 'The range for uint16 is:\n\t%d to %d ';
sprintf(str, intmin('uint16'), intmax('uint16'))
str = 'The range for uint32 is:\n\t%d to %d ';
sprintf(str, intmin('uint32'), intmax('uint32'))
str = 'The range for uint64 is:\n\t%d to %d ';
sprintf(str, intmin('uint64'), intmax('uint64'))

Когда вы запускаете файл, он показывает следующий результат -

ans = The range for int8 is:
	-128 to 127 
ans = The range for int16 is:
	-32768 to 32767 
ans = The range for int32 is:
	-2147483648 to 2147483647 
ans = The range for int64 is:
	0 to 0 
ans = The range for uint8 is:
	0 to 255 
ans = The range for uint16 is:
	0 to 65535 
ans = The range for uint32 is:
	0 to -1 
ans = The range for uint64 is:
	0 to 18446744073709551616

Наименьшие и наибольшие числа с плавающей запятой

Функции realmax() и realmin() возвращает максимальное и минимальное значения, которые могут быть представлены числами с плавающей запятой.

Обе функции при вызове с аргументом 'single' возвращают максимальное и минимальное значения, которые вы можете представить с помощью типа данных с одинарной точностью, а при вызове с аргументом 'double' возвращают максимальное и минимальное значения, которые вы можете представить с помощью тип данных с двойной точностью.

пример

В следующем примере показано, как получить наименьшее и наибольшее числа с плавающей запятой. Создайте файл сценария и напишите в нем следующий код -

% displaying the smallest and largest single-precision 
% floating point number
str = 'The range for single is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('single'), -realmin('single'), ...
   realmin('single'), realmax('single'))

% displaying the smallest and largest double-precision 
% floating point number
str = 'The range for double is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('double'), -realmin('double'), ...
   realmin('double'), realmax('double'))

Когда вы запускаете файл, он отображает следующий результат -

ans = The range for single is:                                                  
        -3.40282e+38 to -1.17549e-38 and                                        
         1.17549e-38 to  3.40282e+38                                            
ans = The range for double is:                                                  
        -1.79769e+308 to -2.22507e-308 and                                      
         2.22507e-308 to  1.79769e+308

Создание символьной строки в MATLAB довольно просто. Фактически, мы использовали его много раз. Например, вы вводите в командной строке следующее:

my_string = 'Tutorials Point'

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

my_string = Tutorials Point

MATLAB рассматривает все переменные как массивы, а строки рассматриваются как символьные массивы. Давайте использоватьwhos команда для проверки созданной выше переменной -

whos

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

Name           Size            Bytes  Class    Attributes
my_string      1x16               32  char

Интересно, что вы можете использовать числовые функции преобразования, такие как uint8 или же uint16для преобразования символов в строке в их числовые коды. Вchar функция преобразует целочисленный вектор обратно в символы -

пример

Создайте файл сценария и введите в него следующий код -

my_string = 'Tutorial''s Point';
str_ascii = uint8(my_string)        % 8-bit ascii values
str_back_to_char= char(str_ascii)  
str_16bit = uint16(my_string)       % 16-bit ascii values
str_back_to_char = char(str_16bit)

Когда вы запускаете файл, он отображает следующий результат -

str_ascii =

   84  117  116  111  114  105   97  108   39  115   32   80  111  105  110  116

str_back_to_char = Tutorial's Point
str_16bit =

   84  117  116  111  114  105   97  108   39  115   32   80  111  105  110  116

str_back_to_char = Tutorial's Point

Прямоугольный массив символов

Строки, которые мы обсуждали до сих пор, представляют собой одномерные массивы символов; однако нам нужно хранить больше. Нам нужно хранить в нашей программе более объемные текстовые данные. Это достигается путем создания массивов прямоугольных символов.

Самый простой способ создания прямоугольного массива символов - это объединение двух или более одномерных массивов символов, по необходимости, по вертикали или горизонтали.

Вы можете комбинировать струны по вертикали одним из следующих способов:

  • Использование оператора конкатенации MATLAB []и разделяя каждую строку точкой с запятой (;). Обратите внимание, что в этом методе каждая строка должна содержать одинаковое количество символов. Для строк разной длины вы должны заполнить пробелами по мере необходимости.

  • Используя charфункция. Если строки имеют разную длину, char дополняет более короткие строки завершающими пробелами, чтобы в каждой строке было одинаковое количество символов.

пример

Создайте файл сценария и введите в него следующий код -

doc_profile = ['Zara Ali                             '; ...
               'Sr. Surgeon                          '; ...
               'R N Tagore Cardiology Research Center']
doc_profile = char('Zara Ali', 'Sr. Surgeon', ...
                  'RN Tagore Cardiology Research Center')

Когда вы запускаете файл, он отображает следующий результат -

doc_profile =
Zara Ali                             
Sr. Surgeon                          
R N Tagore Cardiology Research Center
doc_profile =
Zara Ali                            
Sr. Surgeon                         
RN Tagore Cardiology Research Center

Вы можете комбинировать строки по горизонтали одним из следующих способов:

  • Используя оператор конкатенации MATLAB, []и разделение входных строк запятой или пробелом. Этот метод сохраняет любые конечные пробелы во входных массивах.

  • Используя функцию конкатенации строк, strcat. Этот метод удаляет конечные пробелы во входных данных.

пример

Создайте файл сценария и введите в него следующий код -

name =     'Zara Ali                             ';
position = 'Sr. Surgeon                          '; 
worksAt =  'R N Tagore Cardiology Research Center';
profile = [name ', ' position ', ' worksAt]
profile = strcat(name, ', ', position, ', ', worksAt)

Когда вы запускаете файл, он отображает следующий результат -

profile = Zara Ali      , Sr. Surgeon      , R N Tagore Cardiology Research Center
profile = Zara Ali,Sr. Surgeon,R N Tagore Cardiology Research Center

Объединение строк в массив ячеек

Из нашего предыдущего обсуждения ясно, что комбинирование строк разной длины может быть проблемой, поскольку все строки в массиве должны иметь одинаковую длину. Мы использовали пробелы в конце строк, чтобы уравнять их длину.

Однако более эффективный способ объединения строк - преобразование результирующего массива в массив ячеек.

Массив ячеек MATLAB может содержать различные размеры и типы данных в массиве. Массивы ячеек обеспечивают более гибкий способ хранения строк различной длины.

В cellstr Функция преобразует массив символов в массив ячеек строк.

пример

Создайте файл сценария и введите в него следующий код -

name =     'Zara Ali                             ';
position = 'Sr. Surgeon                          '; 
worksAt =  'R N Tagore Cardiology Research Center';
profile = char(name, position, worksAt);
profile = cellstr(profile);
disp(profile)

Когда вы запускаете файл, он отображает следующий результат -

{                                                                               
   [1,1] = Zara Ali                                                              
   [2,1] = Sr. Surgeon                                                           
   [3,1] = R N Tagore Cardiology Research Center                                 
}

Строковые функции в MATLAB

MATLAB предоставляет множество строковых функций, создающих, комбинирующих, анализирующих, сравнивающих и управляющих строками.

В следующей таблице представлено краткое описание строковых функций в MATLAB -

Функция Цель
Функции для хранения текста в массивах символов, объединения массивов символов и т. Д.
пробелы Создать строку пустых символов
Cellstr Создать массив ячеек строк из массива символов
char Преобразовать в символьный массив (строку)
iscellstr Определите, является ли ввод массивом ячеек строк
Ischar Определите, является ли элемент массивом символов
спринт Форматировать данные в строку
strcat Объединить строки по горизонтали
strjoin Объединить строки в массиве ячеек в одну строку
Функции для определения частей строк, поиска и замены подстрок
Ischar Определите, является ли элемент массивом символов
островок Элементы массива, представляющие собой буквы алфавита
isspace Элементы массива, являющиеся пробелами
isstrprop Определить, относится ли строка к указанной категории
sscanf Чтение форматированных данных из строки
strfind Найдите одну строку в другой
strrep Найти и заменить подстроку
strsplit Разделить строку по указанному разделителю
strtok Избранные части струны
валидация Проверить правильность текстовой строки
символ Определить символьные переменные в выражении
регулярное выражение Соответствие регулярному выражению (с учетом регистра)
регулярное выражение Соответствие регулярному выражению (без учета регистра)
регулярное выражение Заменить строку регулярным выражением
regexptranslate Перевести строку в регулярное выражение
Функции для сравнения строк
strcmp Сравнить строки (с учетом регистра)
strcmpi Сравнить строки (без учета регистра)
strncmp Сравните первые n символов строк (с учетом регистра)
strncmpi Сравните первые n символов строк (без учета регистра)
Функции для преобразования строки в верхний или нижний регистр, создания или удаления пробелов
дебланк Снимите замыкающие пробелы с конца строки
Strtrim Удалить начальные и конечные пробелы из строки
ниже Преобразовать строку в нижний регистр
верхний Преобразовать строку в верхний регистр
strjust Выровнять массив символов

Примеры

Следующие примеры иллюстрируют некоторые из вышеупомянутых строковых функций.

Форматирование строк

Создайте файл сценария и введите в него следующий код -

A = pi*1000*ones(1,5);
sprintf(' %f \n %.2f \n %+.2f \n %12.2f \n %012.2f \n', A)

Когда вы запускаете файл, он отображает следующий результат -

ans =  3141.592654 
   3141.59 
   +3141.59 
      3141.59 
   000003141.59

Соединение строк

Создайте файл сценария и введите в него следующий код -

%cell array of strings
str_array = {'red','blue','green', 'yellow', 'orange'};

% Join strings in cell array into single string
str1 = strjoin(str_array, "-")
str2 = strjoin(str_array, ",")

Когда вы запускаете файл, он отображает следующий результат -

str1 = red-blue-green-yellow-orange
str2 = red,blue,green,yellow,orange

Поиск и замена строк

Создайте файл сценария и введите в него следующий код -

students = {'Zara Ali', 'Neha Bhatnagar', ...
            'Monica Malik', 'Madhu Gautam', ...
            'Madhu Sharma', 'Bhawna Sharma',...
            'Nuha Ali', 'Reva Dutta', ...
            'Sunaina Ali', 'Sofia Kabir'};
 
% The strrep function searches and replaces sub-string.
new_student = strrep(students(8), 'Reva', 'Poulomi')
% Display first names
first_names = strtok(students)

Когда вы запускаете файл, он отображает следующий результат -

new_student = 
{
   [1,1] = Poulomi Dutta
}
first_names = 
{
   [1,1] = Zara
   [1,2] = Neha
   [1,3] = Monica
   [1,4] = Madhu
   [1,5] = Madhu
   [1,6] = Bhawna
   [1,7] = Nuha
   [1,8] = Reva
   [1,9] = Sunaina
   [1,10] = Sofia
}

Сравнение строк

Создайте файл сценария и введите в него следующий код -

str1 = 'This is test'
str2 = 'This is text'
if (strcmp(str1, str2))
   sprintf('%s and %s are equal', str1, str2)
else
   sprintf('%s and %s are not equal', str1, str2)
end

Когда вы запускаете файл, он отображает следующий результат -

str1 = This is test
str2 = This is text
ans = This is test and This is text are not equal

Функция - это группа операторов, которые вместе выполняют задачу. В MATLAB функции определены в отдельных файлах. Имя файла и функции должны совпадать.

Функции работают с переменными в своей собственной рабочей области, которая также называется local workspace, отдельно от рабочего пространства, к которому вы обращаетесь в командной строке MATLAB, которая называется base workspace.

Функции могут принимать более одного входного аргумента и могут возвращать более одного выходного аргумента.

Синтаксис оператора функции -

function [out1,out2, ..., outN] = myfun(in1,in2,in3, ..., inN)

пример

Следующая функция с именем mymax должна быть записана в файл с именем mymax.m . Он принимает пять чисел в качестве аргумента и возвращает максимальное из чисел.

Создайте файл функции с именем mymax.m и введите в него следующий код -

function max = mymax(n1, n2, n3, n4, n5)

%This function calculates the maximum of the
% five numbers given as input
max =  n1;
if(n2 > max)
   max = n2;
end
if(n3 > max)
   max = n3;
end
if(n4 > max)
   max = n4;
end
if(n5 > max)
   max = n5;
end

Первая строка функции начинается с ключевого слова function. Он дает имя функции и порядок аргументов. В нашем примере функция mymax имеет пять входных аргументов и один выходной аргумент.

Строки комментариев, которые идут сразу после оператора функции, содержат текст справки. Эти строки печатаются, когда вы вводите -

help mymax

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

This function calculates the maximum of the
   five numbers given as input

Вы можете вызвать функцию как -

mymax(34, 78, 89, 23, 11)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = 89

Анонимные функции

Анонимная функция похожа на встроенную функцию в традиционных языках программирования, определенную в одном операторе MATLAB. Он состоит из одного выражения MATLAB и любого количества входных и выходных аргументов.

Вы можете определить анонимную функцию прямо в командной строке MATLAB или внутри функции или сценария.

Таким образом, вы можете создавать простые функции, не создавая для них файл.

Синтаксис для создания анонимной функции из выражения:

f = @(arglist)expression

пример

В этом примере мы напишем анонимную функцию с именем power, которая будет принимать два числа в качестве входных и возвращать первое число, возведенное в степень второго числа.

Создайте файл сценария и введите в него следующий код -

power = @(x, n) x.^n;
result1 = power(7, 3)
result2 = power(49, 0.5)
result3 = power(10, -10)
result4 = power (4.5, 1.5)

Когда вы запускаете файл, он отображает -

result1 =  343
result2 =  7
result3 =  1.0000e-10
result4 =  9.5459

Основные и вспомогательные функции

Любая функция, кроме анонимной, должна быть определена в файле. Каждый файл функции содержит требуемую первичную функцию, которая появляется первой, и любое количество дополнительных подфункций, которые идут после первичной функции и используются ею.

Первичные функции могут быть вызваны извне файла, который их определяет, либо из командной строки, либо из других функций, но подфункции нельзя вызывать из командной строки или других функций вне файла функции.

Подфункции видны только основной функции и другим подфункциям в файле функции, который их определяет.

пример

Давайте напишем функцию с именем quadratic, которая будет вычислять корни квадратного уравнения. Функция будет принимать три входа: квадратичный коэффициент, линейный коэффициент и постоянный член. Это вернет корни.

Файл функции quadratic.m будет содержать основную квадратичную функцию и диск подфункций , который вычисляет дискриминант.

Создайте файл функции quadratic.m и введите в него следующий код -

function [x1,x2] = quadratic(a,b,c)

%this function returns the roots of 
% a quadratic equation.
% It takes 3 input arguments
% which are the co-efficients of x2, x and the 
%constant term
% It returns the roots
d = disc(a,b,c); 
x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end   % end of quadratic

function dis = disc(a,b,c) 
%function calculates the discriminant
dis = sqrt(b^2 - 4*a*c);
end   % end of sub-function

Вы можете вызвать указанную выше функцию из командной строки как -

quadratic(2,4,-4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans = 0.7321

Вложенные функции

Вы можете определять функции в теле другой функции. Они называются вложенными функциями. Вложенная функция содержит любые или все компоненты любой другой функции.

Вложенные функции определены в рамках другой функции, и они имеют общий доступ к рабочей области содержащей функции.

Вложенная функция следует следующему синтаксису -

function x = A(p1, p2)
...
B(p2)
   function y = B(p3)
   ...
   end
...
end

пример

Давайте перепишем функцию quadratic из предыдущего примера, однако на этот раз дисковая функция будет вложенной функцией.

Создайте файл функции quadratic2.m и введите в него следующий код -

function [x1,x2] = quadratic2(a,b,c)
function disc  % nested function
d = sqrt(b^2 - 4*a*c);
end   % end of function disc

disc;
x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end   % end of function quadratic2

Вы можете вызвать указанную выше функцию из командной строки как -

quadratic2(2,4,-4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =  0.73205

Частные функции

Частная функция - это основная функция, которая видна только ограниченной группе других функций. Если вы не хотите раскрывать реализацию функции (функций), вы можете создать их как частные функции.

Частные функции находятся в subfolders со специальным названием private.

Они видны только функциям в родительской папке.

пример

Перепишем квадратичную функцию. Однако на этот раз дисковая функция, вычисляющая дискриминант, будет частной функцией.

Создайте подпапку с именем private в рабочем каталоге. Сохраните в нем следующий функциональный файл disc.m -

function dis = disc(a,b,c) 
%function calculates the discriminant
dis = sqrt(b^2 - 4*a*c);
end      % end of sub-function

Создайте функцию quadratic3.m в своем рабочем каталоге и введите в нее следующий код -

function [x1,x2] = quadratic3(a,b,c)

%this function returns the roots of 
% a quadratic equation.
% It takes 3 input arguments
% which are the co-efficient of x2, x and the 
%constant term
% It returns the roots
d = disc(a,b,c); 

x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end      % end of quadratic3

Вы можете вызвать указанную выше функцию из командной строки как -

quadratic3(2,4,-4)

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =  0.73205

Глобальные переменные

Глобальные переменные могут использоваться более чем одной функцией. Для этого вам нужно объявить переменную глобальной во всех функциях.

Если вы хотите получить доступ к этой переменной из базовой рабочей области, объявите переменную в командной строке.

Глобальное объявление должно произойти до того, как переменная будет фактически использована в функции. Рекомендуется использовать заглавные буквы в именах глобальных переменных, чтобы отличать их от других переменных.

пример

Давайте создадим файл функции с именем average.m и введем в него следующий код -

function avg = average(nums)
global TOTAL
avg = sum(nums)/TOTAL;
end

Создайте файл сценария и введите в него следующий код -

global TOTAL;
TOTAL = 10;
n = [34, 45, 25, 45, 33, 19, 40, 34, 38, 42];
av = average(n)

Когда вы запустите файл, он отобразит следующий результат -

av =  35.500

Импорт данных в MATLAB означает загрузку данных из внешнего файла. ВimportdataФункция позволяет загружать различные файлы данных разных форматов. Он имеет следующие пять форм -

Sr.No. Описание функции
1

A = importdata(filename)

Загружает данные в массив A из файла, обозначенного именем filename .

2

A = importdata('-pastespecial')

Загружает данные из системного буфера обмена, а не из файла.

3

A = importdata(___, delimiterIn)

Интерпретирует delimiterIn как разделитель столбцов в файле ASCII, имени файла или данных буфера обмена. Вы можете использовать delimiterIn с любым из входных аргументов в приведенных выше синтаксисах.

4

A = importdata(___, delimiterIn, headerlinesIn)

Загружает данные из файла ASCII, имени файла или буфера обмена, считывая числовые данные, начиная с заголовка строкиlinesIn + 1 .

5

[A, delimiterOut, headerlinesOut] = importdata(___)

Возвращает обнаруженный символ-разделитель для входного файла ASCII в delimiterOut и обнаруженное количество строк заголовка в headerlinesOut , используя любой из входных аргументов в предыдущих синтаксисах.

По умолчанию Octave не поддерживает функцию importdata () , поэтому вам придется найти и установить этот пакет, чтобы следующие примеры работали с вашей установкой Octave.

Пример 1

Загрузим и отобразим файл изображения. Создайте файл сценария и введите в него следующий код -

filename = 'smile.jpg';
A = importdata(filename);
image(A);

Когда вы запускаете файл, MATLAB отображает файл изображения. Однако вы должны сохранить его в текущем каталоге.

Пример 2

В этом примере мы импортируем текстовый файл и указываем разделитель и заголовок столбца. Давайте создадим ASCII-файл с разделителями- пробелами и заголовками столбцов с именем weeklydata.txt .

Наш текстовый файл weeklydata.txt выглядит так:

SunDay  MonDay  TuesDay  WednesDay  ThursDay  FriDay  SaturDay
95.01   76.21   61.54    40.57       55.79    70.28   81.53
73.11   45.65   79.19    93.55       75.29    69.87   74.68
60.68   41.85   92.18    91.69       81.32    90.38   74.51
48.60   82.14   73.82    41.03       0.99     67.22   93.18
89.13   44.47   57.63    89.36       13.89    19.88   46.60

Создайте файл сценария и введите в него следующий код -

filename = 'weeklydata.txt';
delimiterIn = ' ';
headerlinesIn = 1;
A = importdata(filename,delimiterIn,headerlinesIn);

% View data
for k = [1:7]
   disp(A.colheaders{1, k})
   disp(A.data(:, k))
   disp(' ')
end

Когда вы запускаете файл, он отображает следующий результат -

SunDay
   95.0100
   73.1100
   60.6800
   48.6000
   89.1300
 
MonDay
   76.2100
   45.6500
   41.8500
   82.1400
   44.4700
 
TuesDay
   61.5400
   79.1900
   92.1800
   73.8200
   57.6300

WednesDay
   40.5700
   93.5500
   91.6900
   41.0300
   89.3600
 
ThursDay
   55.7900
   75.2900
   81.3200
   0.9900
   13.8900
 
FriDay
   70.2800
   69.8700
   90.3800
   67.2200
   19.8800

SaturDay
   81.5300
   74.6800
   74.5100
   93.1800
   46.6000

Пример 3

В этом примере давайте импортируем данные из буфера обмена.

Скопируйте следующие строки в буфер обмена -

Mathematics is simple

Создайте файл сценария и введите следующий код -

A = importdata('-pastespecial')

Когда вы запускаете файл, он отображает следующий результат -

A = 
   'Mathematics is simple'

Низкоуровневый файловый ввод-вывод

Функция importdata - это функция высокого уровня. Функции низкоуровневого файлового ввода-вывода в MATLAB позволяют максимально контролировать чтение или запись данных в файл. Однако для эффективной работы этим функциям требуется более подробная информация о вашем файле.

MATLAB предоставляет следующие функции для операций чтения и записи на байтовом или символьном уровне:

Функция Описание
fclose Закройте один или все открытые файлы
Feof Тест на конец файла
Ferror Информация об ошибках файлового ввода-вывода
fgetl Прочитать строку из файла, удалив символы новой строки
fgets Читать строку из файла, сохраняя символы новой строки
fopen Открыть файл или получить информацию об открытых файлах
fprintf Записать данные в текстовый файл
fread Прочитать данные из двоичного файла
frewind Переместить индикатор положения файла в начало открытого файла
fscanf Прочитать данные из текстового файла
fseek Перейти в указанную позицию в файле
ftell Позиция в открытом файле
fwrite Записать данные в двоичный файл

Импорт файлов текстовых данных с низкоуровневым вводом-выводом

MATLAB предоставляет следующие функции для низкоуровневого импорта файлов текстовых данных:

  • В fscanf функция читает отформатированные данные в текстовом или ASCII файле.

  • В fgetl и fgets функции читают по одной строке файла за раз, где символ новой строки разделяет каждую строку.

  • В fread функция читает поток данных на байтовом или битовом уровне.

пример

У нас есть файл текстовых данных myfile.txt, сохраненный в нашем рабочем каталоге. В файле хранятся данные об осадках за три месяца; Июнь, июль и август 2012 года.

Данные в myfile.txt содержат повторяющиеся наборы измерений времени, месяца и количества осадков в пяти местах. Данные заголовка хранят количество месяцев M; Итак, у нас есть M наборов измерений.

Файл выглядит так -

Rainfall Data
Months: June, July, August
 
M = 3
12:00:00
June-2012
17.21  28.52  39.78  16.55 23.67
19.15  0.35   17.57  NaN   12.01
17.92  28.49  17.40  17.06 11.09
9.59   9.33   NaN    0.31  0.23 
10.46  13.17  NaN    14.89 19.33
20.97  19.50  17.65  14.45 14.00
18.23  10.34  17.95  16.46 19.34
09:10:02
July-2012
12.76  16.94  14.38  11.86 16.89
20.46  23.17  NaN    24.89 19.33
30.97  49.50  47.65  24.45 34.00
18.23  30.34  27.95  16.46 19.34
30.46  33.17  NaN    34.89  29.33
30.97  49.50  47.65  24.45 34.00
28.67  30.34  27.95  36.46 29.34
15:03:40
August-2012
17.09  16.55  19.59  17.25 19.22
17.54  11.45  13.48  22.55 24.01
NaN    21.19  25.85  25.05 27.21
26.79  24.98  12.23  16.99 18.67
17.54  11.45  13.48  22.55 24.01
NaN    21.19  25.85  25.05 27.21
26.79  24.98  12.23  16.99 18.67

Мы импортируем данные из этого файла и отобразим эти данные. Сделайте следующие шаги -

  • Откройте файл с помощью fopen функция и получите идентификатор файла.

  • Опишите данные в файле с помощью format specifiers, такие как '%s'для строки'%d'для целого числа или'%f'для числа с плавающей запятой.

  • Чтобы пропустить буквальные символы в файле, включите их в описание формата. Чтобы пропустить поле данных, используйте звездочку ('*') в спецификаторе.

    Например, чтобы прочитать заголовки и вернуть единственное значение для M, мы пишем:

    M = fscanf(fid, '%*s %*s\n%*s %*s %*s %*s\nM=%d\n\n', 1);
  • По умолчанию, fscanfсчитывает данные в соответствии с нашим описанием формата до тех пор, пока не найдет совпадения для данных или не достигнет конца файла. Здесь мы будем использовать цикл for для чтения 3 наборов данных, и каждый раз он будет читать 7 строк и 5 столбцов.

  • Мы создадим структуру с именем mydata в рабочей области для хранения данных, считанных из файла. Эта структура имеет три поля - время , месяц и массив дождевых данных .

Создайте файл сценария и введите в него следующий код -

filename = '/data/myfile.txt';
rows = 7;
cols = 5;
 
% open the file
fid = fopen(filename);
 
% read the file headers, find M (number of months)
M = fscanf(fid, '%*s %*s\n%*s %*s %*s %*s\nM=%d\n\n', 1);
 
% read each set of measurements
for n = 1:M
   mydata(n).time = fscanf(fid, '%s', 1);
   mydata(n).month = fscanf(fid, '%s', 1);
 
   % fscanf fills the array in column order,
   % so transpose the results
   mydata(n).raindata  = ...
      fscanf(fid, '%f', [rows, cols]);
end
for n = 1:M
   disp(mydata(n).time), disp(mydata(n).month)
   disp(mydata(n).raindata)
end
 
% close the file
fclose(fid);

Когда вы запускаете файл, он отображает следующий результат -

12:00:00
June-2012
   17.2100   17.5700   11.0900   13.1700   14.4500
   28.5200       NaN    9.5900       NaN   14.0000
   39.7800   12.0100    9.3300   14.8900   18.2300
   16.5500   17.9200       NaN   19.3300   10.3400
   23.6700   28.4900    0.3100   20.9700   17.9500
   19.1500   17.4000    0.2300   19.5000   16.4600
   0.3500   17.0600   10.4600   17.6500   19.3400

09:10:02
July-2012
   12.7600       NaN   34.0000   33.1700   24.4500
   16.9400   24.8900   18.2300       NaN   34.0000
   14.3800   19.3300   30.3400   34.8900   28.6700
   11.8600   30.9700   27.9500   29.3300   30.3400
   16.8900   49.5000   16.4600   30.9700   27.9500
   20.4600   47.6500   19.3400   49.5000   36.4600
   23.1700   24.4500   30.4600   47.6500   29.3400

15:03:40
August-2012
   17.0900   13.4800   27.2100   11.4500   25.0500
   16.5500   22.5500   26.7900   13.4800   27.2100
   19.5900   24.0100   24.9800   22.5500   26.7900
   17.2500       NaN   12.2300   24.0100   24.9800
   19.2200   21.1900   16.9900       NaN   12.2300
   17.5400   25.8500   18.6700   21.1900   16.9900
   11.4500   25.0500   17.5400   25.8500   18.6700

Экспорт (или вывод) данных в MATLAB означает запись в файлы. MATLAB позволяет использовать ваши данные в другом приложении, которое читает файлы ASCII. Для этого MATLAB предоставляет несколько вариантов экспорта данных.

Вы можете создать следующие типы файлов -

  • Прямоугольный файл данных ASCII с разделителями из массива.

  • Файл дневника (или журнала) нажатий клавиш и результирующего текстового вывода.

  • Специализированный файл ASCII с использованием низкоуровневых функций, таких как fprintf.

  • MEX-файл для доступа к вашей подпрограмме C / C ++ или Fortran, которая записывает в определенный формат текстового файла.

Помимо этого, вы также можете экспортировать данные в электронные таблицы.

Есть два способа экспортировать числовой массив в виде файла данных ASCII с разделителями:

  • Используя save функция и указав -ascii квалификатор

  • Используя dlmwrite функция

Синтаксис для использования функции сохранения -

save my_data.out num_array -ascii

где my_data.out - это созданный файл данных ASCII с разделителями, num_array - числовой массив и−ascii - спецификатор.

Синтаксис для использования dlmwrite функция -

dlmwrite('my_data.out', num_array, 'dlm_char')

где my_data.out - это созданный файл данных ASCII с разделителями, num_array - числовой массив, а dlm_char - символ-разделитель.

пример

Следующий пример демонстрирует концепцию. Создайте файл сценария и введите следующий код -

num_array = [ 1 2 3 4 ; 4 5 6 7; 7 8 9 0];
save array_data1.out num_array -ascii;
type array_data1.out
dlmwrite('array_data2.out', num_array, ' ');
type array_data2.out

Когда вы запускаете файл, он отображает следующий результат -

1.0000000e+00   2.0000000e+00   3.0000000e+00   4.0000000e+00
   4.0000000e+00   5.0000000e+00   6.0000000e+00   7.0000000e+00
   7.0000000e+00   8.0000000e+00   9.0000000e+00   0.0000000e+00

1 2 3 4
4 5 6 7
7 8 9 0

Обратите внимание, что команда save -ascii и функция dlmwrite не работают с массивами ячеек в качестве входных данных. Чтобы создать файл ASCII с разделителями из содержимого массива ячеек, вы можете

  • Либо преобразуйте массив ячеек в матрицу, используя cell2mat функция

  • Или экспортируйте массив ячеек с помощью низкоуровневых функций файлового ввода-вывода.

Если вы используете save функция для записи массива символов в файл ASCII, она записывает в файл эквивалент символов ASCII.

Например, давайте напишем слово "привет" в файл -

h = 'hello';
save textdata.out h -ascii
type textdata.out

MATLAB выполняет приведенные выше операторы и отображает следующий результат. который представляет собой символы строки hello в 8-значном формате ASCII.

1.0400000e+02   1.0100000e+02   1.0800000e+02   1.0800000e+02   1.1100000e+02

Запись в файлы дневника

Файлы дневника - это журналы активности вашего сеанса MATLAB. Функция дневника создает точную копию вашего сеанса в файле на диске, за исключением графики.

Чтобы включить функцию дневника, введите -

diary

При желании вы можете указать имя файла журнала, скажем -

diary logdata.out

Чтобы отключить функцию дневника -

diary off

Вы можете открыть файл дневника в текстовом редакторе.

Экспорт данных в текстовые файлы данных с низкоуровневым вводом-выводом

Пока что мы экспортировали числовые массивы. Однако вам может потребоваться создать другие текстовые файлы, включая комбинации числовых и символьных данных, файлы вывода непрямоугольной формы или файлы со схемами кодирования, отличными от ASCII. Для этих целей MATLAB предоставляет низкоуровневуюfprintf функция.

Как и в случае с низкоуровневыми файловыми операциями ввода-вывода, перед экспортом вам необходимо открыть или создать файл с fopenфункция и получите идентификатор файла. По умолчанию fopen открывает файл только для чтения. Вы должны указать разрешение на запись или добавление, например «w» или «a».

После обработки файла нужно закрыть его с помощью fclose(fid) функция.

Следующий пример демонстрирует концепцию -

пример

Создайте файл сценария и введите в него следующий код -

% create a matrix y, with two rows
x = 0:10:100;
y = [x; log(x)];
 
% open a file for writing
fid = fopen('logtable.txt', 'w');
 
% Table Header
fprintf(fid, 'Log     Function\n\n');
 
% print values in column order
% two values appear on each row of the file
fprintf(fid, '%f    %f\n', y);
fclose(fid);

% display the file created
type logtable.txt

Когда вы запускаете файл, он отображает следующий результат -

Log         Function

0.000000    -Inf
10.000000    2.302585
20.000000    2.995732
30.000000    3.401197
40.000000    3.688879
50.000000    3.912023
60.000000    4.094345
70.000000    4.248495
80.000000    4.382027
90.000000    4.499810
100.000000    4.605170

Чтобы построить график функции, вам необходимо выполнить следующие шаги -

  • Определить x, указав range of values для переменной x, для которого строится функция

  • Определите функцию, y = f(x)

  • Позвоните в plot команда, как plot(x, y)

Следующий пример продемонстрирует концепцию. Построим простую функциюy = x для диапазона значений x от 0 до 100 с шагом 5.

Создайте файл сценария и введите следующий код -

x = [0:5:100];
y = x;
plot(x, y)

Когда вы запускаете файл, MATLAB отображает следующий график -

Давайте возьмем еще один пример, чтобы построить функцию y = x 2 . В этом примере мы нарисуем два графика с одной и той же функцией, но во второй раз мы уменьшим значение приращения. Обратите внимание, что по мере уменьшения приращения график становится более плавным.

Создайте файл сценария и введите следующий код -

x = [1 2 3 4 5 6 7 8 9 10];
x = [-100:20:100];
y = x.^2;
plot(x, y)

Когда вы запускаете файл, MATLAB отображает следующий график -

Немного измените файл кода, уменьшите шаг до 5 -

x = [-100:5:100];
y = x.^2;
plot(x, y)

MATLAB рисует более гладкий график -

Добавление заголовка, меток, линий сетки и масштабирования на график

MATLAB позволяет добавлять заголовок, метки по оси x и оси y, линии сетки, а также настраивать оси, чтобы украсить график.

  • В xlabel и ylabel Команды генерируют метки по оси x и оси y.

  • В title Команда позволяет нанести заголовок на график.

  • В grid on Команда позволяет наносить линии сетки на график.

  • В axis equal Команда позволяет построить график с одинаковыми масштабными коэффициентами и промежутками по обеим осям.

  • В axis square команда генерирует квадратный график.

пример

Создайте файл сценария и введите следующий код -

x = [0:0.01:10];
y = sin(x);
plot(x, y), xlabel('x'), ylabel('Sin(x)'), title('Sin(x) Graph'),
grid on, axis equal

MATLAB генерирует следующий график -

Рисование нескольких функций на одном графике

Вы можете нарисовать несколько графиков на одном графике. Следующий пример демонстрирует концепцию -

пример

Создайте файл сценария и введите следующий код -

x = [0 : 0.01: 10];
y = sin(x);
g = cos(x);
plot(x, y, x, g, '.-'), legend('Sin(x)', 'Cos(x)')

MATLAB генерирует следующий график -

Настройка цветов на графике

MATLAB предоставляет восемь основных вариантов цвета для рисования графиков. В следующей таблице показаны цвета и их коды -

Код цвет
ш Белый
k Черный
б Синий
р Красный
c Голубой
г Зеленый
м Пурпурный
y Желтый

пример

Нарисуем график двух многочленов

  • f (x) = 3x 4 + 2x 3 + 7x 2 + 2x + 9 и

  • г (х) = 5х 3 + 9х + 2

Создайте файл сценария и введите следующий код -

x = [-10 : 0.01: 10];
y = 3*x.^4 + 2 * x.^3 + 7 * x.^2 + 2 * x + 9;
g = 5 * x.^3 + 9 * x + 2;
plot(x, y, 'r', x, g, 'g')

Когда вы запускаете файл, MATLAB генерирует следующий график -

Установка шкалы осей

В axisКоманда позволяет установить масштабы оси. Вы можете указать минимальные и максимальные значения для осей x и y, используя команду оси следующим образом:

axis ( [xmin xmax ymin ymax] )

Следующий пример показывает это -

пример

Создайте файл сценария и введите следующий код -

x = [0 : 0.01: 10];
y = exp(-x).* sin(2*x + 3);
plot(x, y), axis([0 10 -1 1])

Когда вы запускаете файл, MATLAB генерирует следующий график -

Создание подграфов

Когда вы создаете массив графиков на одном рисунке, каждый из этих графиков называется второстепенным. Вsubplot команда используется для создания подсюжетов.

Синтаксис команды -

subplot(m, n, p)

где m и n - количество строк и столбцов в массиве графиков, а p указывает, куда поместить конкретный график.

Каждый график, созданный с помощью команды subplot, может иметь свои собственные характеристики. Следующий пример демонстрирует концепцию -

пример

Сгенерируем два графика -

y = e −1,5x sin (10x)

у = е - грех (10х)

Создайте файл сценария и введите следующий код -

x = [0:0.01:5];
y = exp(-1.5*x).*sin(10*x);
subplot(1,2,1)
plot(x,y), xlabel('x'),ylabel('exp(–1.5x)*sin(10x)'),axis([0 5 -1 1])
y = exp(-2*x).*sin(10*x);
subplot(1,2,2)
plot(x,y),xlabel('x'),ylabel('exp(–2x)*sin(10x)'),axis([0 5 -1 1])

Когда вы запускаете файл, MATLAB генерирует следующий график -

В этой главе мы продолжим изучение графических и графических возможностей MATLAB. Обсудим -

  • Рисование гистограмм
  • Рисование контуров
  • Трехмерные сюжеты

Рисование гистограмм

В barкоманда рисует двухмерную гистограмму. Давайте рассмотрим пример, чтобы продемонстрировать идею.

пример

У нас будет воображаемый класс с 10 учениками. Нам известно, что эти студенты получают 75, 58, 90, 87, 50, 85, 92, 75, 60 и 95 процентов. Мы построим гистограмму для этих данных.

Создайте файл сценария и введите следующий код -

x = [1:10];
y = [75, 58, 90, 87, 50, 85, 92, 75, 60, 95];
bar(x,y), xlabel('Student'),ylabel('Score'),
title('First Sem:')
print -deps graph.eps

Когда вы запускаете файл, MATLAB отображает следующую гистограмму -

Рисование контуров

Линия контура функции двух переменных - это кривая, вдоль которой функция имеет постоянное значение. Контурные линии используются для создания контурных карт путем соединения точек с одинаковой высотой над заданным уровнем, например среднего уровня моря.

MATLAB предоставляет contour функция рисования контурных карт.

пример

Создадим контурную карту, которая показывает контурные линии для данной функции g = f (x, y). Эта функция имеет две переменные. Итак, нам нужно будет сгенерировать две независимые переменные, то есть два набора данных x и y. Это делается путем вызоваmeshgrid команда.

В meshgrid Команда используется для создания матрицы элементов, которые дают диапазон по x и y вместе со спецификацией приращения в каждом случае.

Построим график нашей функции g = f (x, y), где −5 ≤ x ≤ 5, −3 ≤ y ≤ 3. Возьмем приращение 0,1 для обоих значений. Переменные установлены как -

[x,y] = meshgrid(–5:0.1:5, –3:0.1:3);

Наконец, нам нужно назначить функцию. Пусть наша функция будет: x 2 + y 2

Создайте файл сценария и введите следующий код -

[x,y] = meshgrid(-5:0.1:5,-3:0.1:3);   %independent variables
g = x.^2 + y.^2;                       % our function
contour(x,y,g)                         % call the contour function
print -deps graph.eps

Когда вы запускаете файл, MATLAB отображает следующую контурную карту -

Давайте немного изменим код, чтобы нарядить карту

[x,y] = meshgrid(-5:0.1:5,-3:0.1:3);   %independent variables
g = x.^2 + y.^2;                       % our function
[C, h] = contour(x,y,g);               % call the contour function
set(h,'ShowText','on','TextStep',get(h,'LevelStep')*2)
print -deps graph.eps

Когда вы запускаете файл, MATLAB отображает следующую контурную карту -

Трехмерные графики

Трехмерные графики в основном отображают поверхность, определенную функцией от двух переменных, g = f (x, y).

Как и раньше, чтобы определить g, мы сначала создаем набор точек (x, y) в области определения функции, используя meshgridкоманда. Далее мы назначаем саму функцию. Наконец, мы используемsurf команда для создания графика поверхности.

Следующий пример демонстрирует концепцию -

пример

Создадим трехмерную карту поверхности для функции g = xe - (x 2 + y 2 )

Создайте файл сценария и введите следующий код -

[x,y] = meshgrid(-2:.2:2);
g = x .* exp(-x.^2 - y.^2);
surf(x, y, g)
print -deps graph.eps

Когда вы запускаете файл, MATLAB отображает следующую трехмерную карту -

Вы также можете использовать meshкоманда для создания трехмерной поверхности. Тем не менееsurf команда отображает как соединительные линии, так и грани поверхности в цвете, тогда как mesh команда создает каркасную поверхность с цветными линиями, соединяющими определяющие точки.

До сих пор мы видели, что все примеры работают в MATLAB, а также в его GNU, альтернативно называемом Octave. Но для решения основных алгебраических уравнений и MATLAB, и Octave немного отличаются, поэтому мы попытаемся охватить MATLAB и Octave в отдельных разделах.

Мы также обсудим факторизацию и упрощение алгебраических выражений.

Решение основных алгебраических уравнений в MATLAB

В solveфункция используется для решения алгебраических уравнений. В простейшей форме функция решения принимает уравнение, заключенное в кавычки, в качестве аргумента.

Например, давайте решим относительно x в уравнении x-5 = 0

solve('x-5=0')

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   5

Вы также можете вызвать функцию решения как -

y = solve('x-5 = 0')

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

y =
   5

Вы можете даже не включать правую часть уравнения -

solve('x-5')

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   5

Если уравнение включает в себя несколько символов, то MATLAB по умолчанию предполагает, что вы решаете для x, однако функция решения имеет другую форму -

solve(equation, variable)

где вы также можете указать переменную.

Например, давайте решим уравнение v - u - 3t 2 = 0 для v. В этом случае мы должны написать -

solve('v-u-3*t^2=0', 'v')

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   3*t^2 + u

Решение основных алгебраических уравнений в октаве

В roots функция используется для решения алгебраических уравнений в Octave, и вы можете написать приведенные выше примеры следующим образом:

Например, давайте решим относительно x в уравнении x-5 = 0

roots([1, -5])

Octave выполнит вышеуказанный оператор и вернет следующий результат -

ans = 5

Вы также можете вызвать функцию решения как -

y = roots([1, -5])

Octave выполнит вышеуказанный оператор и вернет следующий результат -

y = 5

Решение квадратных уравнений в MATLAB

В solveфункция также может решать уравнения более высокого порядка. Его часто используют для решения квадратных уравнений. Функция возвращает корни уравнения в массиве.

В следующем примере решается квадратное уравнение x 2 -7x +12 = 0. Создайте файл сценария и введите следующий код -

eq = 'x^2 -7*x + 12 = 0';
s = solve(eq);
disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));

Когда вы запускаете файл, он отображает следующий результат -

The first root is: 
   3
The second root is: 
   4

Решение квадратных уравнений в октаве

В следующем примере решается квадратное уравнение x 2 -7x +12 = 0 в октаве. Создайте файл сценария и введите следующий код -

s = roots([1, -7, 12]);

disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));

Когда вы запускаете файл, он отображает следующий результат -

The first root is: 
   4
The second root is: 
   3

Решение уравнений высшего порядка в MATLAB

В solveфункция также может решать уравнения более высокого порядка. Например, давайте решим кубическое уравнение как (x-3) 2 (x-7) = 0

solve('(x-3)^2*(x-7)=0')

MATLAB выполнит вышеуказанный оператор и вернет следующий результат -

ans =
   3
   3
   7

В случае уравнений более высокого порядка корни длинные, содержащие много членов. Вы можете получить числовое значение таких корней, преобразовав их в двойные. В следующем примере решается уравнение четвертого порядка x 4 - 7x 3 + 3x 2 - 5x + 9 = 0.

Создайте файл сценария и введите следующий код -

eq = 'x^4 - 7*x^3 + 3*x^2 - 5*x + 9 = 0';
s = solve(eq);
disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));
disp('The third root is: '), disp(s(3));
disp('The fourth root is: '), disp(s(4));

% converting the roots to double type
disp('Numeric value of first root'), disp(double(s(1)));
disp('Numeric value of second root'), disp(double(s(2)));
disp('Numeric value of third root'), disp(double(s(3)));
disp('Numeric value of fourth root'), disp(double(s(4)));

Когда вы запускаете файл, он возвращает следующий результат -

The first root is: 
6.630396332390718431485053218985
 The second root is: 
1.0597804633025896291682772499885
 The third root is: 
- 0.34508839784665403032666523448675 - 1.0778362954630176596831109269793*i
 The fourth root is: 
- 0.34508839784665403032666523448675 + 1.0778362954630176596831109269793*i
Numeric value of first root
   6.6304
Numeric value of second root
   1.0598
Numeric value of third root
   -0.3451 - 1.0778i
Numeric value of fourth root
   -0.3451 + 1.0778i

Обратите внимание, что последние два корня являются комплексными числами.

Решение уравнений высшего порядка в октаве

В следующем примере решается уравнение четвертого порядка x 4 - 7x 3 + 3x 2 - 5x + 9 = 0.

Create a script file and type the following code −

v = [1, -7,  3, -5, 9];
s = roots(v);

% converting the roots to double type
disp('Numeric value of first root'), disp(double(s(1)));
disp('Numeric value of second root'), disp(double(s(2)));
disp('Numeric value of third root'), disp(double(s(3)));
disp('Numeric value of fourth root'), disp(double(s(4)));

When you run the file, it returns the following result −

Numeric value of first root
 6.6304
Numeric value of second root
-0.34509 + 1.07784i
Numeric value of third root
-0.34509 - 1.07784i
Numeric value of fourth root
 1.0598

Solving System of Equations in MATLAB

The solve function can also be used to generate solutions of systems of equations involving more than one variables. Let us take up a simple example to demonstrate this use.

Let us solve the equations −

5x + 9y = 5

3x – 6y = 4

Create a script file and type the following code −

s = solve('5*x + 9*y = 5','3*x - 6*y = 4');
s.x
s.y

When you run the file, it displays the following result −

ans =
   22/19
ans =
   -5/57

In same way, you can solve larger linear systems. Consider the following set of equations −

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

Solving System of Equations in Octave

We have a little different approach to solve a system of 'n' linear equations in 'n' unknowns. Let us take up a simple example to demonstrate this use.

Let us solve the equations −

5x + 9y = 5

3x – 6y = 4

Such a system of linear equations can be written as the single matrix equation Ax = b, where A is the coefficient matrix, b is the column vector containing the right-hand side of the linear equations and x is the column vector representing the solution as shown in the below program −

Create a script file and type the following code −

A = [5, 9; 3, -6];
b = [5;4];
A \ b

When you run the file, it displays the following result −

ans =

   1.157895
  -0.087719

In same way, you can solve larger linear systems as given below −

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

Expanding and Collecting Equations in MATLAB

The expand and the collect function expands and collects an equation respectively. The following example demonstrates the concepts −

When you work with many symbolic functions, you should declare that your variables are symbolic.

Create a script file and type the following code −

syms x   %symbolic variable x
syms y   %symbolic variable x
% expanding equations
expand((x-5)*(x+9))
expand((x+2)*(x-3)*(x-5)*(x+7))
expand(sin(2*x))
expand(cos(x+y))
 
% collecting equations
collect(x^3 *(x-7))
collect(x^4*(x-3)*(x-5))

When you run the file, it displays the following result −

ans =
   x^2 + 4*x - 45
ans =
   x^4 + x^3 - 43*x^2 + 23*x + 210
ans =
   2*cos(x)*sin(x)
ans =
   cos(x)*cos(y) - sin(x)*sin(y)
ans =
   x^4 - 7*x^3
ans =
   x^6 - 8*x^5 + 15*x^4

Expanding and Collecting Equations in Octave

You need to have symbolic package, which provides expand and the collect function to expand and collect an equation, respectively. The following example demonstrates the concepts −

When you work with many symbolic functions, you should declare that your variables are symbolic but Octave has different approach to define symbolic variables. Notice the use of Sin and Cos, which are also defined in symbolic package.

Create a script file and type the following code −

% first of all load the package, make sure its installed.
pkg load symbolic

% make symbols module available
symbols

% define symbolic variables
x = sym ('x');
y = sym ('y');
z = sym ('z');

% expanding equations
expand((x-5)*(x+9))
expand((x+2)*(x-3)*(x-5)*(x+7))
expand(Sin(2*x))
expand(Cos(x+y))
 
% collecting equations
collect(x^3 *(x-7), z)
collect(x^4*(x-3)*(x-5), z)

When you run the file, it displays the following result −

ans =

-45.0+x^2+(4.0)*x
ans =

210.0+x^4-(43.0)*x^2+x^3+(23.0)*x
ans =

sin((2.0)*x)
ans =

cos(y+x)
ans =

x^(3.0)*(-7.0+x)
ans =

(-3.0+x)*x^(4.0)*(-5.0+x)

Factorization and Simplification of Algebraic Expressions

The factor function factorizes an expression and the simplify function simplifies an expression. The following example demonstrates the concept −

Example

Create a script file and type the following code −

syms x
syms y
factor(x^3 - y^3)
factor([x^2-y^2,x^3+y^3])
simplify((x^4-16)/(x^2-4))

When you run the file, it displays the following result −

ans =
   (x - y)*(x^2 + x*y + y^2)
ans =
   [ (x - y)*(x + y), (x + y)*(x^2 - x*y + y^2)]
ans =
   x^2 + 4

MATLAB provides various ways for solving problems of differential and integral calculus, solving differential equations of any degree and calculation of limits. Best of all, you can easily plot the graphs of complex functions and check maxima, minima and other stationery points on a graph by solving the original function, as well as its derivative.

This chapter will deal with problems of calculus. In this chapter, we will discuss pre-calculus concepts i.e., calculating limits of functions and verifying the properties of limits.

In the next chapter Differential, we will compute derivative of an expression and find the local maxima and minima on a graph. We will also discuss solving differential equations.

Finally, in the Integration chapter, we will discuss integral calculus.

Calculating Limits

MATLAB provides the limit function for calculating limits. In its most basic form, the limit function takes expression as an argument and finds the limit of the expression as the independent variable goes to zero.

For example, let us calculate the limit of a function f(x) = (x3 + 5)/(x4 + 7), as x tends to zero.

syms x
limit((x^3 + 5)/(x^4 + 7))

MATLAB will execute the above statement and return the following result −

ans =
   5/7

The limit function falls in the realm of symbolic computing; you need to use the syms function to tell MATLAB which symbolic variables you are using. You can also compute limit of a function, as the variable tends to some number other than zero. To calculate lim x->a(f(x)), we use the limit command with arguments. The first being the expression and the second is the number, that x approaches, here it is a.

For example, let us calculate limit of a function f(x) = (x-3)/(x-1), as x tends to 1.

limit((x - 3)/(x-1),1)

MATLAB will execute the above statement and return the following result −

ans =
   NaN

Let's take another example,

limit(x^2 + 5, 3)

MATLAB will execute the above statement and return the following result −

ans =
   14

Calculating Limits using Octave

Following is Octave version of the above example using symbolic package, try to execute and compare the result −

pkg load symbolic
symbols

x = sym("x");
subs((x^3+5)/(x^4+7),x,0)

Octave will execute the above statement and return the following result −

ans =
   0.7142857142857142857

Verification of Basic Properties of Limits

Algebraic Limit Theorem provides some basic properties of limits. These are as follows −

Let us consider two functions −

  • f(x) = (3x + 5)/(x - 3)
  • g(x) = x2 + 1.

Let us calculate the limits of the functions as x tends to 5, of both functions and verify the basic properties of limits using these two functions and MATLAB.

Example

Create a script file and type the following code into it −

syms x
f = (3*x + 5)/(x-3);
g = x^2 + 1;
l1 = limit(f, 4)
l2 = limit (g, 4)
lAdd = limit(f + g, 4)
lSub = limit(f - g, 4)
lMult = limit(f*g, 4)
lDiv = limit (f/g, 4)

When you run the file, it displays −

l1 =
   17
  
l2 =
   17
  
lAdd =
   34
 
lSub =
   0
  
lMult =
   289
  
lDiv =
   1

Verification of Basic Properties of Limits using Octave

Following is Octave version of the above example using symbolic package, try to execute and compare the result −

pkg load symbolic
symbols

x = sym("x");
f = (3*x + 5)/(x-3);
g = x^2 + 1;

l1 = subs(f, x, 4)
l2 = subs (g, x, 4)
lAdd = subs (f+g, x, 4)
lSub = subs (f-g, x, 4)
lMult = subs (f*g, x, 4)
lDiv = subs (f/g, x, 4)

Octave will execute the above statement and return the following result −

l1 =
   17.0
l2 =
   17.0
lAdd =
   34.0
lSub =
   0.0
lMult =
   289.0
lDiv =
   1.0

Left and Right Sided Limits

When a function has a discontinuity for some particular value of the variable, the limit does not exist at that point. In other words, limits of a function f(x) has discontinuity at x = a, when the value of limit, as x approaches x from left side, does not equal the value of the limit as x approaches from right side.

This leads to the concept of left-handed and right-handed limits. A left-handed limit is defined as the limit as x -> a, from the left, i.e., x approaches a, for values of x < a. A right-handed limit is defined as the limit as x -> a, from the right, i.e., x approaches a, for values of x > a. When the left-handed limit and right-handed limit are not equal, the limit does not exist.

Let us consider a function −

f(x) = (x - 3)/|x - 3|

We will show that limx->3 f(x) does not exist. MATLAB helps us to establish this fact in two ways −

  • By plotting the graph of the function and showing the discontinuity.
  • By computing the limits and showing that both are different.

The left-handed and right-handed limits are computed by passing the character strings 'left' and 'right' to the limit command as the last argument.

Example

Create a script file and type the following code into it −

f = (x - 3)/abs(x-3);
ezplot(f,[-1,5])
l = limit(f,x,3,'left')
r = limit(f,x,3,'right')

When you run the file, MATLAB draws the following plot

After this following output is displayed −

l =
   -1
  
r =
   1

MATLAB provides the diff command for computing symbolic derivatives. In its simplest form, you pass the function you want to differentiate to diff command as an argument.

For example, let us compute the derivative of the function f(t) = 3t2 + 2t-2

Example

Create a script file and type the following code into it −

syms t
f = 3*t^2 + 2*t^(-2);
diff(f)

When the above code is compiled and executed, it produces the following result −

ans =
6*t - 4/t^3

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

t = sym("t");
f = 3*t^2 + 2*t^(-2);
differentiate(f,t)

Octave executes the code and returns the following result −

ans =
   -(4.0)*t^(-3.0)+(6.0)*t

Verification of Elementary Rules of Differentiation

Let us briefly state various equations or rules for differentiation of functions and verify these rules. For this purpose, we will write f'(x) for a first order derivative and f"(x) for a second order derivative.

Following are the rules for differentiation −

Rule 1

For any functions f and g and any real numbers a and b are the derivative of the function −

h(x) = af(x) + bg(x) with respect to x is given by −

h'(x) = af'(x) + bg'(x)

Rule 2

The sum and subtraction rules state that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f + g)' = f' + g'

(f - g)' = f' - g'

Rule 3

The product rule states that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f.g)' = f'.g + g'.f

Rule 4

The quotient rule states that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f/g)' = (f'.g - g'.f)/g2

Rule 5

The polynomial or elementary power rule states that, if y = f(x) = xn, then f' = n. x(n-1)

A direct outcome of this rule is that the derivative of any constant is zero, i.e., if y = k, any constant, then

f' = 0

Rule 6

The chain rule states that, derivative of the function of a function h(x) = f(g(x)) with respect to x is,

h'(x)= f'(g(x)).g'(x)

Example

Create a script file and type the following code into it −

syms x
syms t

f = (x + 2)*(x^2 + 3)
der1 = diff(f)
f = (t^2 + 3)*(sqrt(t) + t^3)
der2 = diff(f)
f = (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2)
der3 = diff(f)
f = (2*x^2 + 3*x)/(x^3 + 1)
der4 = diff(f)
f = (x^2 + 1)^17
der5 = diff(f)
f = (t^3 + 3* t^2 + 5*t -9)^(-6)
der6 = diff(f)

When you run the file, MATLAB displays the following result −

f =
   (x^2 + 3)*(x + 2)
 
   der1 =
   2*x*(x + 2) + x^2 + 3
  
f =
   (t^(1/2) + t^3)*(t^2 + 3)
 
   der2 =
   (t^2 + 3)*(3*t^2 + 1/(2*t^(1/2))) + 2*t*(t^(1/2) + t^3)
  
f =
   (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2)
  
der3 =
   (2*x - 2)*(3*x^3 - 5*x^2 + 2) - (- 9*x^2 + 10*x)*(x^2 - 2*x + 1)
 
f =
   (2*x^2 + 3*x)/(x^3 + 1)
  
der4 =
   (4*x + 3)/(x^3 + 1) - (3*x^2*(2*x^2 + 3*x))/(x^3 + 1)^2
  
f =
   (x^2 + 1)^17
  
der5 =
   34*x*(x^2 + 1)^16
  
f =
   1/(t^3 + 3*t^2 + 5*t - 9)^6
  
der6 =
   -(6*(3*t^2 + 6*t + 5))/(t^3 + 3*t^2 + 5*t - 9)^7

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
t = sym("t");
f = (x + 2)*(x^2 + 3) 
der1 = differentiate(f,x) 
f = (t^2 + 3)*(t^(1/2) + t^3) 
der2 = differentiate(f,t) 
f = (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2) 
der3 = differentiate(f,x) 
f = (2*x^2 + 3*x)/(x^3 + 1) 
der4 = differentiate(f,x) 
f = (x^2 + 1)^17 
der5 = differentiate(f,x) 
f = (t^3 + 3* t^2 + 5*t -9)^(-6) 
der6 = differentiate(f,t)

Octave executes the code and returns the following result −

f =

(2.0+x)*(3.0+x^(2.0))
der1 =

3.0+x^(2.0)+(2.0)*(2.0+x)*x
f =

(t^(3.0)+sqrt(t))*(3.0+t^(2.0))
der2 =

(2.0)*(t^(3.0)+sqrt(t))*t+((3.0)*t^(2.0)+(0.5)*t^(-0.5))*(3.0+t^(2.0))
f =

(1.0+x^(2.0)-(2.0)*x)*(2.0-(5.0)*x^(2.0)+(3.0)*x^(3.0))
der3 =

(-2.0+(2.0)*x)*(2.0-(5.0)*x^(2.0)+(3.0)*x^(3.0))+((9.0)*x^(2.0)-(10.0)*x)*(1.0+x^(2.0)-(2.0)*x)
f =

(1.0+x^(3.0))^(-1)*((2.0)*x^(2.0)+(3.0)*x)
der4 =

(1.0+x^(3.0))^(-1)*(3.0+(4.0)*x)-(3.0)*(1.0+x^(3.0))^(-2)*x^(2.0)*((2.0)*x^(2.0)+(3.0)*x)
f =

(1.0+x^(2.0))^(17.0)
der5 =

(34.0)*(1.0+x^(2.0))^(16.0)*x
f =

(-9.0+(3.0)*t^(2.0)+t^(3.0)+(5.0)*t)^(-6.0)
der6 =

-(6.0)*(-9.0+(3.0)*t^(2.0)+t^(3.0)+(5.0)*t)^(-7.0)*(5.0+(3.0)*t^(2.0)+(6.0)*t)

Derivatives of Exponential, Logarithmic and Trigonometric Functions

The following table provides the derivatives of commonly used exponential, logarithmic and trigonometric functions −

Function Derivative
ca.x ca.x.ln c.a (ln is natural logarithm)
ex ex
ln x 1/x
lncx 1/x.ln c
xx xx.(1 + ln x)
sin(x) cos(x)
cos(x) -sin(x)
tan(x) sec2(x), or 1/cos2(x), or 1 + tan2(x)
cot(x) -csc2(x), or -1/sin2(x), or -(1 + cot2(x))
sec(x) sec(x).tan(x)
csc(x) -csc(x).cot(x)

Example

Create a script file and type the following code into it −

syms x
y = exp(x)
diff(y)
y = x^9
diff(y)
y = sin(x)
diff(y)
y = tan(x)
diff(y)
y = cos(x)
diff(y)
y = log(x)
diff(y)
y = log10(x)
diff(y)
y = sin(x)^2
diff(y)
y = cos(3*x^2 + 2*x + 1)
diff(y)
y = exp(x)/sin(x)
diff(y)

When you run the file, MATLAB displays the following result −

y =
   exp(x)
   ans =
   exp(x)

y =
   x^9
   ans =
   9*x^8
  
y =
   sin(x)
   ans =
   cos(x)
  
y =
   tan(x)
   ans =
   tan(x)^2 + 1
 
y =
   cos(x)
   ans =
   -sin(x)
  
y =
   log(x)
   ans =
   1/x
  
y =
   log(x)/log(10)
   ans =
   1/(x*log(10))
 
y =
   sin(x)^2
   ans =
   2*cos(x)*sin(x)
 
y =
   cos(3*x^2 + 2*x + 1)
   ans =
   -sin(3*x^2 + 2*x + 1)*(6*x + 2)
  
y =
   exp(x)/sin(x)
   ans =
   exp(x)/sin(x) - (exp(x)*cos(x))/sin(x)^2

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
y = Exp(x)
differentiate(y,x)

y = x^9
differentiate(y,x)

y = Sin(x)
differentiate(y,x)

y = Tan(x)
differentiate(y,x)

y = Cos(x)
differentiate(y,x)

y = Log(x)
differentiate(y,x)

% symbolic packages does not have this support
%y = Log10(x)
%differentiate(y,x)

y = Sin(x)^2
differentiate(y,x)

y = Cos(3*x^2 + 2*x + 1)
differentiate(y,x)

y = Exp(x)/Sin(x)
differentiate(y,x)

Octave executes the code and returns the following result −

y =

exp(x)
ans =

exp(x)
y =

x^(9.0)
ans =

(9.0)*x^(8.0)
y =

sin(x)
ans =

cos(x)
y =

tan(x)
ans =

1+tan(x)^2
y =

cos(x)
ans =

-sin(x)
y =

log(x)
ans =

x^(-1)
y =

sin(x)^(2.0)
ans =

(2.0)*sin(x)*cos(x)
y =

cos(1.0+(2.0)*x+(3.0)*x^(2.0))
ans =

-(2.0+(6.0)*x)*sin(1.0+(2.0)*x+(3.0)*x^(2.0))
y =

sin(x)^(-1)*exp(x)
ans =

sin(x)^(-1)*exp(x)-sin(x)^(-2)*cos(x)*exp(x)

Computing Higher Order Derivatives

To compute higher derivatives of a function f, we use the syntax diff(f,n).

Let us compute the second derivative of the function y = f(x) = x .e-3x

f = x*exp(-3*x);
diff(f, 2)

MATLAB executes the code and returns the following result −

ans =
9*x*exp(-3*x) - 6*exp(-3*x)

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
f = x*Exp(-3*x);
differentiate(f, x, 2)

Octave executes the code and returns the following result −

ans =

(9.0)*exp(-(3.0)*x)*x-(6.0)*exp(-(3.0)*x)

Example

In this example, let us solve a problem. Given that a function y = f(x) = 3 sin(x) + 7 cos(5x). We will have to find out whether the equation f" + f = -5cos(2x) holds true.

Create a script file and type the following code into it −

syms x
y = 3*sin(x)+7*cos(5*x);  % defining the function
lhs = diff(y,2)+y;        %evaluting the lhs of the equation
rhs = -5*cos(2*x);        %rhs of the equation
if(isequal(lhs,rhs))
   disp('Yes, the equation holds true');
else
   disp('No, the equation does not hold true');
end
disp('Value of LHS is: '), disp(lhs);

When you run the file, it displays the following result −

No, the equation does not hold true
Value of LHS is: 
-168*cos(5*x)

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
y = 3*Sin(x)+7*Cos(5*x);           % defining the function
lhs = differentiate(y, x, 2) + y;  %evaluting the lhs of the equation
rhs = -5*Cos(2*x);                 %rhs of the equation

if(lhs == rhs)
   disp('Yes, the equation holds true');
else
   disp('No, the equation does not hold true');
end
disp('Value of LHS is: '), disp(lhs);

Octave выполняет код и возвращает следующий результат -

No, the equation does not hold true
Value of LHS is: 
-(168.0)*cos((5.0)*x)

Нахождение максимума и минимума кривой

Если мы ищем локальные максимумы и минимумы для графика, мы в основном ищем наивысшие или самые низкие точки на графике функции в определенной местности или для определенного диапазона значений символической переменной.

Для функции y = f (x) точки на графике, где график имеет нулевой наклон, называются stationary points. Другими словами, стационарные точки - это когда f '(x) = 0.

Чтобы найти стационарные точки дифференцируемой функции, нам нужно установить производную равной нулю и решить уравнение.

пример

Найдем стационарные точки функции f (x) = 2x 3 + 3x 2 - 12x + 17

Сделайте следующие шаги -

First let us enter the function and plot its graph.

syms x
y = 2*x^3 + 3*x^2 - 12*x + 17;   % defining the function
ezplot(y)

MATLAB выполняет код и возвращает следующий график -

Вот эквивалентный код Octave для приведенного выше примера -

pkg load symbolic
symbols

x = sym('x');
y = inline("2*x^3 + 3*x^2 - 12*x + 17");

ezplot(y)
print -deps graph.eps

Our aim is to find some local maxima and minima on the graph, so let us find the local maxima and minima for the interval [-2, 2] on the graph.

syms x
y = 2*x^3 + 3*x^2 - 12*x + 17;   % defining the function
ezplot(y, [-2, 2])

MATLAB выполняет код и возвращает следующий график -

Вот эквивалентный код Octave для приведенного выше примера -

pkg load symbolic
symbols

x = sym('x');
y = inline("2*x^3 + 3*x^2 - 12*x + 17");

ezplot(y, [-2, 2])
print -deps graph.eps

Next, let us compute the derivative.

g = diff(y)

MATLAB выполняет код и возвращает следующий результат -

g =
   6*x^2 + 6*x - 12

Вот октавный эквивалент приведенного выше расчета -

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)

Octave выполняет код и возвращает следующий результат -

g =
   -12.0+(6.0)*x+(6.0)*x^(2.0)

Let us solve the derivative function, g, to get the values where it becomes zero.

s = solve(g)

MATLAB выполняет код и возвращает следующий результат -

s =
   1
   -2

Ниже приведен октавный эквивалент приведенного выше расчета.

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)
roots([6, 6, -12])

Octave выполняет код и возвращает следующий результат -

g =

-12.0+(6.0)*x^(2.0)+(6.0)*x
ans =

  -2
   1

This agrees with our plot. So let us evaluate the function f at the critical points x = 1, -2. Мы можем подставить значение в символьную функцию, используя subs команда.

subs(y, 1), subs(y, -2)

MATLAB выполняет код и возвращает следующий результат -

ans =
   10
ans =
   37

Ниже приведен октавный эквивалент приведенного выше расчета.

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)

roots([6, 6, -12])
subs(y, x, 1), subs(y, x, -2)

ans =
   10.0
ans =
   37.0-4.6734207789940138748E-18*I

Следовательно, минимальное и максимальное значения функции f (x) = 2x 3 + 3x 2 - 12x + 17 в интервале [-2,2] равны 10 и 37.

Решение дифференциальных уравнений

MATLAB предоставляет dsolve команда для символьного решения дифференциальных уравнений.

Самая основная форма dsolve команда для поиска решения одного уравнения:

dsolve('eqn')

где eqn - текстовая строка, используемая для ввода уравнения.

Он возвращает символическое решение с набором произвольных констант, которые MATLAB помечает как C1, C2 и так далее.

Вы также можете указать начальные и граничные условия для задачи в виде списка с разделителями-запятыми, следующего за уравнением как -

dsolve('eqn','cond1', 'cond2',…)

Чтобы использовать команду dsolve, derivatives are indicated with a D. Например, уравнение вида f '(t) = -2 * f + cost (t) вводится как -

'Df = -2*f + cos(t)'

Высшие производные обозначаются следующим за D порядком производной.

Например, уравнение f "(x) + 2f '(x) = 5sin3x следует вводить как -

'D2y + 2Dy = 5*sin(3*x)'

Рассмотрим простой пример дифференциального уравнения первого порядка: y '= 5y.

s = dsolve('Dy = 5*y')

MATLAB выполняет код и возвращает следующий результат -

s =
   C2*exp(5*t)

Давайте рассмотрим другой пример дифференциального уравнения второго порядка: y "- y = 0, y (0) = -1, y '(0) = 2.

dsolve('D2y - y = 0','y(0) = -1','Dy(0) = 2')

MATLAB выполняет код и возвращает следующий результат -

ans =
   exp(t)/2 - (3*exp(-t))/2

Интеграция решает два принципиально разных типа проблем.

  • В первом типе дана производная функции, и мы хотим найти функцию. Таким образом, мы в основном обращаем вспять процесс дифференциации. Этот обратный процесс известен как антидифференциация, или поиск примитивной функции, или нахождениеindefinite integral.

  • Второй тип проблем заключается в суммировании очень большого количества очень малых величин и последующем установлении предела, поскольку размер величин приближается к нулю, в то время как количество членов стремится к бесконечности. Этот процесс приводит к определениюdefinite integral.

Определенные интегралы используются для определения площади, объема, центра тяжести, момента инерции, работы, совершаемой силой, и во многих других приложениях.

Нахождение неопределенного интеграла с помощью MATLAB

По определению, если производная функции f (x) равна f '(x), то мы говорим, что неопределенный интеграл от f' (x) относительно x равен f (x). Например, поскольку производная (по x) x 2 равна 2x, мы можем сказать, что неопределенный интеграл от 2x равен x 2 .

В символах -

f'(x2) = 2x, следовательно,

∫ 2xdx = x2.

Неопределенный интеграл не уникален, потому что производная x 2 + c для любого значения константы c также будет 2x.

Это выражается символами как -

∫ 2xdx = x2 + c.

Где c называется «произвольной константой».

MATLAB предоставляет intкоманда для вычисления интеграла выражения. Чтобы получить выражение для неопределенного интеграла функции, мы пишем -

int(f);

Например, из нашего предыдущего примера -

syms x 
int(2*x)

MATLAB выполняет вышеуказанный оператор и возвращает следующий результат -

ans =
   x^2

Пример 1

В этом примере давайте найдем интеграл некоторых часто используемых выражений. Создайте файл сценария и введите в него следующий код -

syms x n

int(sym(x^n))
f = 'sin(n*t)'
int(sym(f))
syms a t
int(a*cos(pi*t))
int(a^x)

Когда вы запускаете файл, он отображает следующий результат -

ans =
   piecewise([n == -1, log(x)], [n ~= -1, x^(n + 1)/(n + 1)])
f =
sin(n*t)
ans =
   -cos(n*t)/n
   ans =
   (a*sin(pi*t))/pi
   ans =
   a^x/log(a)

Пример 2

Создайте файл сценария и введите в него следующий код -

syms x n
int(cos(x))
int(exp(x))
int(log(x))
int(x^-1)
int(x^5*cos(5*x))
pretty(int(x^5*cos(5*x)))
int(x^-5)
int(sec(x)^2)
pretty(int(1 - 10*x + 9 * x^2))
int((3 + 5*x -6*x^2 - 7*x^3)/2*x^2)
pretty(int((3 + 5*x -6*x^2 - 7*x^3)/2*x^2))

Обратите внимание, что pretty функция возвращает выражение в более читаемом формате.

Когда вы запускаете файл, он отображает следующий результат -

ans =
   sin(x)
 
ans =
   exp(x)
 
ans =
   x*(log(x) - 1)
 
ans =
   log(x)
 
ans =
(24*cos(5*x))/3125 + (24*x*sin(5*x))/625 - (12*x^2*cos(5*x))/125 + (x^4*cos(5*x))/5 - (4*x^3*sin(5*x))/25 + (x^5*sin(5*x))/5
                                    2             4 
   24 cos(5 x)   24 x sin(5 x)   12 x  cos(5 x)   x  cos(5 x) 
   ----------- + ------------- - -------------- + ------------ 
      3125            625             125              5 
   
        3             5 
 
   4 x  sin(5 x)   x  sin(5 x) 
   ------------- + ----------- 
         25              5
 
ans =
-1/(4*x^4)
 
ans =
tan(x)
        2 
  x (3 x  - 5 x + 1)
 
ans = 
- (7*x^6)/12 - (3*x^5)/5 + (5*x^4)/8 + x^3/2
 
      6      5      4    3 
    7 x    3 x    5 x    x 
  - ---- - ---- + ---- + -- 
     12     5      8     2

Нахождение определенного интеграла с помощью MATLAB

По определению, определенный интеграл - это, по сути, предел суммы. Мы используем определенные интегралы, чтобы найти такие области, как площадь между кривой и осью x и площадь между двумя кривыми. Определенные интегралы могут также использоваться в других ситуациях, когда требуемая величина может быть выражена как предел суммы.

В int Функцию можно использовать для точного интегрирования, перейдя границы, за которые вы хотите вычислить интеграл.

Вычислять

мы пишем,

int(x, a, b)

Например, чтобы рассчитать значение,

мы пишем -

int(x, 4, 9)

MATLAB выполняет вышеуказанный оператор и возвращает следующий результат -

ans =
   65/2

Ниже приведен октавный эквивалент приведенного выше расчета.

pkg load symbolic
symbols

x = sym("x");
f = x;
c = [1, 0];
integral = polyint(c);

a = polyval(integral, 9) - polyval(integral, 4);
display('Area: '), disp(double(a));

Octave выполняет код и возвращает следующий результат -

Area: 

   32.500

Альтернативное решение может быть предоставлено с использованием функции quad (), предоставляемой Octave, следующим образом:

pkg load symbolic
symbols

f = inline("x");
[a, ierror, nfneval] = quad(f, 4, 9);

display('Area: '), disp(double(a));

Octave выполняет код и возвращает следующий результат -

Area: 
   32.500

Пример 1

Вычислим площадь, заключенную между осью x, кривой y = x 3 −2x + 5 и ординатами x = 1 и x = 2.

Требуемая площадь определяется как -

Создайте файл сценария и введите следующий код -

f = x^3 - 2*x +5;
a = int(f, 1, 2)
display('Area: '), disp(double(a));

Когда вы запускаете файл, он отображает следующий результат -

a =
23/4
Area: 
   5.7500

Ниже приведен октавный эквивалент приведенного выше расчета.

pkg load symbolic
symbols

x = sym("x");
f = x^3 - 2*x +5;
c = [1, 0, -2, 5];
integral = polyint(c);

a = polyval(integral, 2) - polyval(integral, 1);
display('Area: '), disp(double(a));

Octave выполняет код и возвращает следующий результат -

Area: 

   5.7500

Альтернативное решение может быть предоставлено с использованием функции quad (), предоставляемой Octave, следующим образом:

pkg load symbolic
symbols

x = sym("x");
f = inline("x^3 - 2*x +5");

[a, ierror, nfneval] = quad(f, 1, 2);
display('Area: '), disp(double(a));

Octave выполняет код и возвращает следующий результат -

Area: 
   5.7500

Пример 2

Найдите площадь под кривой: f (x) = x 2 cos (x) для −4 ≤ x ≤ 9.

Создайте файл сценария и напишите следующий код -

f = x^2*cos(x);
ezplot(f, [-4,9])
a = int(f, -4, 9)
disp('Area: '), disp(double(a));

Когда вы запускаете файл, MATLAB строит график -

Результат приведен ниже -

a = 
8*cos(4) + 18*cos(9) + 14*sin(4) + 79*sin(9)
 
Area: 
   0.3326

Ниже приведен октавный эквивалент приведенного выше расчета.

pkg load symbolic
symbols

x = sym("x");
f = inline("x^2*cos(x)");

ezplot(f, [-4,9])
print -deps graph.eps

[a, ierror, nfneval] = quad(f, -4, 9);
display('Area: '), disp(double(a));

MATLAB представляет полиномы как векторы-строки, содержащие коэффициенты, упорядоченные по убыванию степеней. Например, уравнение P (x) = x 4 + 7x 3 - 5x + 9 может быть представлено как -

р = [1 7 0 -5 9];

Оценка многочленов

В polyvalФункция используется для вычисления полинома по заданному значению. Например, чтобы оценить наш предыдущий многочленp, при x = 4 введите -

p = [1 7 0  -5 9];
polyval(p,4)

MATLAB выполняет вышеуказанные операторы и возвращает следующий результат -

ans = 693

MATLAB также предоставляет polyvalmфункция для вычисления матричного полинома. Матричный полином - этоpolynomial с матрицами в качестве переменных.

Например, давайте создадим квадратную матрицу X и вычислим многочлен p, в X -

p = [1 7 0  -5 9];
X = [1 2 -3 4; 2 -5 6 3; 3 1 0 2; 5 -7 3 8];
polyvalm(p, X)

MATLAB выполняет вышеуказанные операторы и возвращает следующий результат -

ans =
      2307       -1769        -939        4499
      2314       -2376        -249        4695
      2256       -1892        -549        4310
      4570       -4532       -1062        9269

Поиск корней многочленов

В rootsфункция вычисляет корни многочлена. Например, чтобы вычислить корни нашего многочлена p, введите -

p = [1 7 0  -5 9];
r = roots(p)

MATLAB выполняет вышеуказанные операторы и возвращает следующий результат -

r =
   -6.8661 + 0.0000i
   -1.4247 + 0.0000i
   0.6454 + 0.7095i
   0.6454 - 0.7095i

Функция polyявляется функцией, обратной корням, и возвращается к полиномиальным коэффициентам. Например -

p2 = poly(r)

MATLAB выполняет вышеуказанные операторы и возвращает следующий результат -

p2 =

   Columns 1 through 3:

      1.00000 + 0.00000i   7.00000 + 0.00000i   0.00000 + 0.00000i

   Columns 4 and 5:

      -5.00000 - 0.00000i   9.00000 + 0.00000i

Аппроксимация полиномиальной кривой

В polyfitФункция находит коэффициенты полинома, который соответствует набору данных методом наименьших квадратов. Если x и y - два вектора, содержащие данные x и y, которые нужно подогнать под полином n-й степени, то мы получаем полином, соответствующий данным, записывая -

p = polyfit(x,y,n)

пример

Создайте файл сценария и введите следующий код -

x = [1 2 3 4 5 6]; y = [5.5 43.1 128 290.7 498.4 978.67];   %data
p = polyfit(x,y,4)   %get the polynomial

% Compute the values of the polyfit estimate over a finer range, 
% and plot the estimate over the real data values for comparison:
x2 = 1:.1:6;          
y2 = polyval(p,x2);
plot(x,y,'o',x2,y2)
grid on

Когда вы запускаете файл, MATLAB отображает следующий результат -

p =
   4.1056  -47.9607  222.2598 -362.7453  191.1250

И строит следующий график -

MATLAB предоставляет команду для работы с преобразованиями, такими как преобразования Лапласа и Фурье. Преобразования используются в науке и технике как инструмент для упрощения анализа и просмотра данных под другим углом.

Например, преобразование Фурье позволяет нам преобразовывать сигнал, представленный как функцию времени, в функцию частоты. Преобразование Лапласа позволяет преобразовать дифференциальное уравнение в алгебраическое уравнение.

MATLAB предоставляет laplace, fourier и fft команды для работы с преобразованиями Лапласа, Фурье и быстрого преобразования Фурье.

Преобразование Лапласа

Преобразование Лапласа функции времени f (t) дается следующим интегралом -

Преобразование Лапласа также обозначается как преобразование f (t) в F (s). Вы можете видеть, что этот процесс преобразования или интегрирования преобразует f (t), функцию символьной переменной t, в другую функцию F (s) с другой переменной s.

Преобразование Лапласа превращает дифференциальные уравнения в алгебраические. Чтобы вычислить преобразование Лапласа функции f (t), напишите -

laplace(f(t))

пример

В этом примере мы вычислим преобразование Лапласа некоторых часто используемых функций.

Создайте файл сценария и введите следующий код -

syms s t a b w

laplace(a)
laplace(t^2)
laplace(t^9)
laplace(exp(-b*t))
laplace(sin(w*t))
laplace(cos(w*t))

Когда вы запускаете файл, он отображает следующий результат -

ans =
   1/s^2

ans =
   2/s^3

ans =
   362880/s^10

ans =
   1/(b + s)
  
ans =
   w/(s^2 + w^2)
  
ans =
   s/(s^2 + w^2)

Обратное преобразование Лапласа

MATLAB позволяет нам вычислить обратное преобразование Лапласа с помощью команды ilaplace.

Например,

ilaplace(1/s^3)

MATLAB выполнит вышеуказанный оператор и отобразит результат -

ans =
   t^2/2

пример

Создайте файл сценария и введите следующий код -

syms s t a b w

ilaplace(1/s^7)
ilaplace(2/(w+s))
ilaplace(s/(s^2+4))
ilaplace(exp(-b*t))
ilaplace(w/(s^2 + w^2))
ilaplace(s/(s^2 + w^2))

Когда вы запускаете файл, он отображает следующий результат -

ans =
   t^6/720

ans =
   2*exp(-t*w)

ans =
   cos(2*t)

ans =
   ilaplace(exp(-b*t), t, x)

ans =
   sin(t*w)

ans =
   cos(t*w)

Преобразования Фурье

Преобразование Фурье обычно преобразует математическую функцию времени f (t) в новую функцию, иногда обозначаемую или F, аргументом которой является частота с единицами цикла в секунду (герц) или радиан в секунду. Тогда новая функция известна как преобразование Фурье и / или частотный спектр функции f.

пример

Создайте файл сценария и введите в него следующий код -

syms x 
f = exp(-2*x^2);     %our function
ezplot(f,[-2,2])     % plot of our function
FT = fourier(f)      % Fourier transform

Когда вы запускаете файл, MATLAB строит следующий график -

Отображается следующий результат -

FT =
   (2^(1/2)*pi^(1/2)*exp(-w^2/8))/2

Построение преобразования Фурье как -

ezplot(FT)

Дает следующий график -

Обратные преобразования Фурье

MATLAB предоставляет ifourierкоманда для вычисления обратного преобразования Фурье функции. Например,

f = ifourier(-2*exp(-abs(w)))

MATLAB выполнит вышеуказанный оператор и отобразит результат -

f =
   -2/(pi*(x^2 + 1))

GNU Octave - это язык программирования высокого уровня, такой как MATLAB, и он в основном совместим с MATLAB. Он также используется для численных расчетов.

Octave имеет следующие общие особенности с MATLAB -

  • матрицы - это фундаментальный тип данных
  • имеет встроенную поддержку комплексных чисел
  • он имеет встроенные математические функции и библиотеки
  • поддерживает пользовательские функции

GNU Octave также является свободно распространяемым программным обеспечением. Вы можете распространять и / или изменять его в соответствии с условиями Стандартной общественной лицензии GNU (GPL), опубликованной Free Software Foundation.

MATLAB против Octave

Большинство программ MATLAB работают в Octave, но некоторые из программ Octave могут не работать в MATLAB, потому что Octave допускает некоторый синтаксис, которого нет в MATLAB.

Например, MATLAB поддерживает только одинарные кавычки, но Octave поддерживает как одинарные, так и двойные кавычки для определения строк. Если вы ищете учебное пособие по Octave, то просмотрите его с самого начала, которое охватывает как MATLAB, так и Octave.

Совместимые примеры

Почти все примеры, описанные в этом руководстве, совместимы с MATLAB, а также с Octave. Давайте попробуем следующий пример в MATLAB и Octave, который дает тот же результат без каких-либо изменений синтаксиса:

В этом примере создается трехмерная карта поверхности для функции g = xe - (x 2 + y 2 ) . Создайте файл сценария и введите следующий код -

[x,y] = meshgrid(-2:.2:2);
g = x .* exp(-x.^2 - y.^2);
surf(x, y, g)
print -deps graph.eps

Когда вы запускаете файл, MATLAB отображает следующую трехмерную карту -

Несовместимые примеры

Хотя все основные функции MATLAB доступны в Octave, есть некоторые функции, например, дифференциальное и интеграционное исчисление, которые не совпадают в точности на обоих языках. В этом руководстве мы попытались привести примеры обоих типов, различающиеся по синтаксису.

Рассмотрим следующий пример, где MATLAB и Octave используют разные функции для получения площади кривой: f (x) = x 2 cos (x) для −4 ≤ x ≤ 9. Ниже приводится версия кода MATLAB -

f = x^2*cos(x);
ezplot(f, [-4,9])
a = int(f, -4, 9)
disp('Area: '), disp(double(a));

Когда вы запускаете файл, MATLAB строит график -

Отображается следующий результат

a =
8*cos(4) + 18*cos(9) + 14*sin(4) + 79*sin(9)
 
Area: 
   0.3326

Но чтобы получить площадь той же кривой в октаве, вам нужно будет использовать symbolic пакет следующим образом -

pkg load symbolic
symbols

x = sym("x");
f = inline("x^2*cos(x)");

ezplot(f, [-4,9])
print -deps graph.eps

[a, ierror, nfneval] = quad(f, -4, 9);
display('Area: '), disp(double(a));

Simulink - это среда моделирования и проектирования на основе моделей для динамических и встроенных систем, интегрированная с MATLAB. Simulink, также разработанный MathWorks, представляет собой инструмент на языке графического программирования потоков данных для моделирования, моделирования и анализа многодоменных динамических систем. По сути, это графический инструмент для построения блок-схем с настраиваемым набором библиотек блоков.

Это позволяет вам включать алгоритмы MATLAB в модели, а также экспортировать результаты моделирования в MATLAB для дальнейшего анализа.

Simulink поддерживает -

  • системный уровень
  • simulation
  • автоматическая генерация кода
  • тестирование и проверка встроенных систем

Есть несколько других дополнительных продуктов, предоставляемых MathWorks и сторонними аппаратными и программными продуктами, которые доступны для использования с Simulink.

В следующем списке дается краткое описание некоторых из них -

  • Stateflow позволяет разрабатывать конечные автоматы и блок-схемы.

  • Simulink Coder позволяет автоматически генерировать исходный код C для реализации систем в реальном времени.

  • xPC Target вместе с x86-based real-time systems предоставить среду для моделирования и тестирования моделей Simulink и Stateflow в реальном времени в физической системе.

  • Embedded Coder поддерживает определенные встроенные цели.

  • HDL Coder позволяет автоматически генерировать синтезируемые VHDL и Verilog.

  • SimEvents предоставляет библиотеку графических строительных блоков для моделирования систем массового обслуживания.

Simulink может проводить систематическую проверку и валидацию моделей посредством проверки стиля моделирования, отслеживания требований и анализа покрытия модели.

Simulink Design Verifier позволяет выявлять ошибки проектирования и создавать сценарии тестовых примеров для проверки модели.

Использование Simulink

Чтобы открыть Simulink, введите в рабочее пространство MATLAB -

simulink

Simulink открывается с Library Browser. Обозреватель библиотеки используется для построения имитационных моделей.

На левой панели окна вы найдете несколько библиотек, сгруппированных по различным системам, щелчок по каждой из них отобразит блоки дизайна на правой панели окна.

Строительные модели

Чтобы создать новую модель, щелкните значок Newна панели инструментов браузера библиотеки. Откроется новое окно модели без названия.

Модель Simulink - это блок-схема.

Элементы модели добавляются путем выбора соответствующих элементов в браузере библиотеки и перетаскивания их в окно модели.

Как вариант, вы можете скопировать элементы модели и вставить их в окно модели.

Примеры

Перетащите элементы из библиотеки Simulink, чтобы сделать свой проект.

В этом примере для моделирования будут использоваться два блока - A Source (сигнал) и Sink(область применения). Генератор сигналов (источник) генерирует аналоговый сигнал, который затем будет графически визуализирован осциллографом (приемником).

Начните с перетаскивания необходимых блоков из библиотеки в окно проекта. Затем соедините блоки вместе, что можно сделать, перетащив соединители из точек соединения одного блока в точки другого.

Перетащим в модель блок «Синусоидальная волна».

Выберите «Sinks» из библиотеки и перетащите блок «Scope» в модель.

Перетащите сигнальную линию с выхода блока Sine Wave на вход блока Scope.

Запустите симуляцию, нажав кнопку 'Run', сохраняя все параметры по умолчанию (вы можете изменить их из меню Simulation)

Вы должны получить приведенный ниже график из области видимости.