8433

Основы работы с MATLAB. Изучение простейших операций и приемов работы в среде пакета Matlab

Лабораторная работа

Информатика, кибернетика и программирование

Основы работы с MATLAB. Изучение простейших операций и приемов работы в среде пакета Matlab. Цель работы: Ознакомление с простейшими операциями и приемами работы в среде пакета MATLAB. Организация самостоятельной работы При подготовке к...

Русский

2013-02-11

263 KB

149 чел.

Основы работы с MATLAB. Изучение простейших операций и приемов работы в среде пакета Matlab 

1.1 Цель работы:

Ознакомление с простейшими операциями и приемами работы в среде пакета MATLAB.

1.2 Оpганизация самостоятельной работы

При подготовке к лабораторной работе необходимо изучить лекционные материалы по теме “ Основы работы с MATLAB”.

Предисловие

MATLAB - система многоцелевого назначения, которая вышла на рынок программных продуктов почти двадцать лет назад и с тех пор непрерывно совершенствовалась. Но первоначально ее основу составляли алгоритмы решения систем линейных уравнений и задач на собственные значения, откуда и произошло ее название «матричная лаборатория». Теперь она представляется наиболее эффективной при проведении прикидочных расчетов и при разработке новых алгоритмов. Сейчас уже существует несколько десятков специальных приложений к MATLAB'у, посвященных более узким проблемам. Это обработка сигналов и изображений, инженерное программирование в виде блок-схем, решение экономических задач и многое другое. Но любое из этих приложений можно изучать только после первоначального освоения MATLAB'а.

При выполнении первой лабораторной работы студенты осваивают стандартные программные структуры и команды MATLAB'а: числа, матрицы, функции, графическое представление функций, действия с массивами.


Основы работы с MATLAB

Среда MATLAB включает интерпретатор команд на языке высокого уровня, графическую систему, пакеты расширений и реализована на языке C. Вся работа организуется через командное окно (Command Window), которое появляется при запуске программы matlab.exe. В процессе работы данные располагаются в памяти (Workspace), для изображения кривых, поверхностей и других графиков создаются графические окна.

В командном окне в режиме диалога проводятся вычисления. Пользователь вводит команды или запускает на выполнение файлы с текстами на языке MATLAB. Интерпретатор обрабатывает введенное и выдает результаты: числовые и строковые данные, предупреждения и сообщения об ошибках. Строка ввода помечена знаком >>. В командном окне показываются вводимые с клавиатуры числа, переменные, а также результаты вычислений. Имена переменных должны начинаться с буквы. Знак = соответствует операции присваивания. Нажатие клавиши Enter заставляет систему вычислить выражение и показать результат. Наберите с клавиатуры в строке ввода:

» a=2+51-37

Нажмите клавишу Enter, на экране в зоне просмотра появится результат вычисления:

а = 16

Все значения переменных, вычисленные в течение текущего сеанса работы, сохраняются в специально зарезервированной области памяти компьютера, называемой рабочим пространством системы MATLAB (Workspace). Командой clc можно стереть содержимое командного окна, однако это не затронет содержимого рабочего пространства. Когда исчезает необходимость в хранении ряда переменных в текущем сеансе работы, их можно стереть из памяти компьютера командой clear или clear(имя1, имя2, ...). Первая команда удаляет из памяти все переменные, а вторая - переменные с именами имя1 и имя2. Командой who можно вывести список всех переменных, входящих в данный момент в рабочее пространство системы. Для просмотра значения любой переменной из текущего рабочего пространства системы достаточно набрать ее имя и нажать клавишу Enter.

После окончания сеанса работы с системой MATLAB все ранее вычисленные переменные теряются. Чтобы сохранить в файле на диске компьютера содержимое рабочего пространства системы MATLAB, нужно выполнить команду меню File I Save Workspace As ... .По умолчанию расширение имени файла mat, поэтому такие файлы принято называть МАТ-файлами. Для загрузки в память компьютера ранее сохраненного на диске рабочего пространства нужно выполнить команду меню:

File I Load Workspace ....

Вещественные числа и тип данных double

Система MATLAB представляет на машинном уровне все действительные числа заданные мантиссой и показателем степени, например, 2.85093Е+11, где буквой Е обозначается основание степени равное 10. Этот основной тип данных носит название double. MATLAB по умолчанию использует формат short для вывода вещественных чисел, при котором показываются только четыре десятичных цифры после запятой.

Введите с клавиатуры пример:

» res=5.345*2.868/3.14-99.455+1.274

Получите результат вычисления:

res = -93.2990

Если требуется полное представление вещественного числа res, введите с клавиатуры команду:

» format long

и далее наберите имя переменной

» res

нажмите клавишу Enter и получите более подробную информацию:

res = -93.29900636942675

Теперь все результаты вычислений будут показываться с такой высокой точностью в течение данного сеанса работы в среде системы MATLAB. Если требуется до прекращения текущего сеанса работы вернуться к старой точности визуального представления вещественных чисел в командном окне, нужно ввести и исполнить (нажав клавишу Enter) команду:

» format short

Целые числа показываются системой в командном окне в виде целых чисел.

Над вещественными числами и переменными типа double производятся арифметические операции: сложения +, вычитания -, умножения *, деления / и возведения в степень . Приоритет в выполнении арифметических операций обычный. Операции одинакового приоритета выполняются в порядке слева направо, но круглые скобки могут изменить этот порядок.

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

В системе MATLAB присутствуют все основные элементарные функции для вычислений с вещественными числами. Любая функция характеризуется своим именем, списком входных аргументов (перечисляются через запятую и стоят внутри круглых скобок, следующих за именем функции) и вычисляемым (возвращаемым) значением. Список всех имеющихся в системе элементарных математических функций может быть получен по команде help elfun. В Приложении 1 перечислены стандартные функции вещественного аргумента.

Вычислите выражение, включающее вычисление функции арксинус:

» 2*asin(1)

Убедитесь, что получился следующий результат:

ans = 3.1416,

соответствующее числу «пи». В системе MATLAB для вычисления числа «пи» есть специальное обозначение: pi. (Список системных переменных MATLAB находится в Приложении 2).

MATLAB имеет также логические функции, функции, связанные с целочисленной арифметикой (округления до ближайшего целого: round, усечение дробной части числа: fix). Есть еще функция mod - остаток от деления с учетом знака, sign - знак числа, lcm - наименьшее общее кратное, perms - вычисление числа перестановок и nchoosek - числа сочетаний и много других. Многие из функций имеют область определения, отличную от множества всех действительных чисел.

Помимо арифметических операций над операндами типа double выполняются еще операции отношения и логические операции. Операции отношения сравнивают между собой два операнда по величине. Эти операции записываются следующими знаками или комбинациями знаков (Таблица 1):

Символьные обозначения операций отношения

Таблица 1

<

<=

>

>=

~=

==

Меньше

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

Больше

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

Не равно

Равно

В случае истинности операции отношения ее величина равна 1, а в случае ложности - 0. Операции отношения имеют более низкий приоритет, чем арифметические операции.

Наберите с клавиатуры выражение с операциями отношения и вычислите его:

» a=1; b=2; c=3;

» res=(a<b)+(c~=b)+(b==a)

Вы получите следующий результат: res = 2

Логические операции над вещественными числами обозначаются знаками, перечисленными в таблице 2:

Символьные обозначения логических операций

Таблица 2

&

|

~

и

или

НЕ

Первые две из этих операций являются бинарными (двухоперандными), а последняя - унарной (однооперандной). Логические операции трактуют свои операнды как «истинные» (не равные нулю) или «ложные» (равные нулю). Если оба операнда операции «И» истинны (не равны нулю), то результат этой операции равен 1 («истина»); во всех остальных случаях операция «И» вырабатывает значение 0 («ложь»). Операция «ИЛИ» вырабатывает 0 («ложь») только в случае, когда являются ложными (равными нулю) оба операнда. Операция «НЕ» инвертирует «ложь» на «истину». Логические операции имеют самый низкий приоритет.

Комплексные числа и комплексные функции

Комплексные переменные, как и вещественные автоматически имеют тип double и не требуют никакого предварительного описания. Для записи мнимой единицы зарезервированы буквы i или j. В случае, когда коэффициентом перед мнимой единицей является не число, а переменная, между ними следует обязательно использовать знак умножения. Итак, комплексные числа можно записывать следующим образом:

» 2+3i; -6.789+0.834e-2*i; 4-2j; x+y*i;

Почти все элементарные функции допускают вычисления с комплексными аргументами. Вычислите выражение:

» res=sin(2+3i)*atan(4i)/(1-6i)

Получится результат:

-1.8009 - 1.9190i

Специально для работы с комплексными числами предназначены следующие функции: abs (абсолютное значение комплексного числа), conj (комплексно сопряженное число), imag (мнимая часть комплексного числа), real (действительная часть комплексного числа), angle (аргумент комплексного числа), isreal («истина», если число действительное). Функции комплексного переменного перечислены в Приложении 1.

В отношении арифметических операций ничего нового для комплексных чисел (по сравнению с вещественными) сказать невозможно. То же самое относится и к операциям отношения «равно» и «не равно». Остальные операции отношения вырабатывают результат исходя только из действительных частей этих операндов.

Введите выражение, получите результат и объясните его:

» c=2+3i; d=2i;

» c>d

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

Числовые массивы

Для создания одномерного массива можно использовать операцию конкатенации, которая обозначается с помощью квадратных скобок [ ]. Элементы массива помещаются между скобками и отделяются друг от друга пробелом или запятой:

» al=[1 2 3]; d=[1+2i,2+3i,3-7i];

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

Можно изменять элементы уже сформированного массива путем применения операций индексации и присваивания. Например, введя:

» al(3)=789;

мы изменим третий элемент массива. Или, после введения:

» al(2)= (al(1)+al(3))/2;

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

» al(4)=7;

Применяя после выполнения этой операции к массиву а1 функцию length, находим, что количество элементов в массиве возросло до четырех:

» length(al)

ans = 4

Тоже самое действие - «удлинение массива а1» - можно выполнить и с помощью операции конкатенации:

» al=[al 7];

Можно задать массив, прописывая все его элементы по отдельности:

» al(1)=67; al(2)=7.8; al(3)=0.017;

Однако этот способ создания не является эффективным.

Еще один способ создания одномерного массива основан на применении специальной функции, обозначаемой двоеточием (операция формирования диапазона числовых значений). Через двоеточие следует набрать первое число диапазона, шаг (приращение) и конечное число диапазона. Например:

» diap=3.7:0.3:8.974;

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

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

Введите с клавиатуры:

» a=[1 2; 3 4; 5 6]

Нажмите ENTER, получим:

а =

1 2

3 4

5 6

Полученную матрицу а размером 3x2 (первым указывается число строк, вторым - число столбцов) можно сформировать также вертикальной конкатенацией вектор-строк:

» a=[[1 2];[3 4];[5 6]];

или горизонтальной конкатенацией вектор-столбцов:

» a=[[1;3;5],[2;4;6]];

Структуру созданных массивов можно узнать с помощью команды whos(имя массива), размерность массива - функцией ndims, а размер массива -size.

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

» a(1,1)=1; a(1,2)=2; a(2,1)=3;

» a(2,2)=4; a(3,1)=5; a(3,2)=6;

Однако будет намного эффективнее, если до начала прописывания элементов массива, создать массив нужного размера функциями ones (m,n) или zeros(m,n), заполненный единицами или нулями (m - число строк, n - число столбцов). При вызове этих функций предварительно выделяется память под заданный размер массива, после этого постепенное прописывание элементов нужными значениями не требует перестройки структуры памяти, отведенной под массив. Использование этих функций возможно и при задании массивов других размерностей.

Если после формирования массива Х потребуется, не изменяя элементов массива, изменить его размеры, можно воспользоваться функцией reshape (Х, М, N), где M и N - новые размеры массива Х

Объяснить работу этой функции можно, только исходя из способа, каким система MATLAB хранит элементы массивов в памяти компьютера. Она хранит их в непрерывной области памяти упорядоченно по столбцам: сначала располагаются элементы первого столбца, вслед за ними расположены элементы второго столбца и т.д. Помимо собственно данных (элементов массива) в памяти компьютера хранится также управляющая информация: тип массива (например, double), размерность и размер массива, другая служебная информация. Этой информации достаточно для определения границ столбцов. Отсюда следует, что для переформирования матрицы функцией reshape достаточно изменить только служебную информацию и не трогать собственные данные.

Поменять местами строки матрицы с ее столбцам можно операцией транспортирования, которая обозначается знаком .' (точка и апостроф). Например,

» A=[1 1 1; 2 2 2; 3 3 3];

» B=A'

В =

1 2 3

1 2 3

1 2 3

Операция ' (апостроф) выполняет транспонирование для вещественных матриц и транспонирование с одновременным комплексным сопряжением для комплексных матриц.

Объекты, с которыми работает MATLAB, являются массивами!!! Даже одно заданное число во внутреннем представлении MATLAB является массивом, состоящим из одного элемента. MATLAB позволяет делать вычисления с огромными массивами чисел также легко как и с одиночными числами, и это является одним из самых заметных и важных преимуществ системы MATLAB над другими программными пакетами, ориентированными на вычисления и программирование. Помимо памяти, необходимой для хранения числовых элементов (по 8 байт на каждый в случае вещественных чисел и по 16 байт в случае комплексных чисел), MATLAB автоматически при создании массивов выделяет еще и память для управляющей информации.

Вычисления с массивами

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

Операции сложения и вычитания матриц (знакомые вам из линейной алгебры) обозначаются стандартными знаками + и -.

Задайте матрицы А и В и выполните операцию сложения матриц:

» A=[1 1 1; 2 2 2; 3 3 3]; B=[0 0 0; 7 7 7; 1 2 3];

» A+B

Если используются операнды разных размеров, выдается сообщение об ошибке, за исключением случая, когда один из операндов является скаляром. При выполнении операции А + скаляр (А - матрица) система расширит скаляр до массива размера А, который и складывается далее поэлементно с А.

» A+5

ans = 6 6 6

7 7  7

8 8 8

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

Кроме операции ./, называемой операцией правого поэлементного деления,

есть еще операция левого поэлементного деления .\. Объясним разницу между

этими операциями. Выражение А ./ В приводит к матрице с элементами А (k, m) /В (k, m), а выражение А.\ В приводит к матрице с элементами В (k, m) /А (k, m).

Знак * закреплен за перемножением матриц и векторов в смысле линейной алгебры.

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

Ау = b,

где А - заданная квадратная матрица размера N x N, b - заданный вектор-столбец длины N, то для нахождения неизвестного вектор-столбца у достаточно вычислить выражение А\b (это равносильно операции: А-1 ∙В).

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

» u=[1 2 3]; v=[3 2 1];

» cross(u,v)

ans =

-4  8 -4

Скалярное произведение векторов можно вычислить с помощью функции общего назначения sum, вычисляющей сумму всех элементов векторов (для матриц эта функция вычисляет суммы для всех столбцов). Скалярное произведение, как известно, равно сумме произведений соответствующих координат (элементов) векторов. Таким образом, выражение:

» sum(u.*v)

вычисляет скалярное произведение двух векторов u и v. Скалярное произведение можно также вычислить как: u*v.

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

» sqrt(sum(u.*u))

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

Среди функций, генерирующих матрицы с заданными свойствами, упомянем здесь функцию eye, производящую единичные квадратные матрицы, а также широко применяемую на практике функцию rand, генерирующую массив со случайными элементами, равномерно распределенными на интервале от 0 до 1. Например, выражение

» F=rand(3)

порождает массив случайных чисел размером 3х3 с элементами, равномерно распределенными на интервале от 0 до 1.

Если вызвать эту функцию с двумя аргументами, например R=rand(2,3), то получится матрица R случайных элементов размером 23. При вызове функции rand с тремя и более скалярными аргументами производятся многомерные массивы случайных чисел.

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

Среди функций, производящих простейшие вычисления над массивами, помимо рассмотренной выше функции sum, упомянем еще функцию prod, которая во всем аналогична функции sum, только вычисляет она не сумму элементов, а их произведение. Функции max и min ищут соответственно максимальный и минимальный элементы массивов. Для векторов они возвращают единственное числовое значение, а для матриц они порождают набор экстремальных элементов, вычисленных для каждого столбца. Функция sort сортирует в возрастающем порядке элементы одномерных массивов, а для матриц она производит такую сортировку для каждого столбца отдельно.

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

» x=0:0.01:pi/2; y=sin(x);

вычисляют значения функции sin сразу в 158 точках, формируя два вектора x и у со 158 элементами каждый.

Построение графиков функции

Графические возможности системы MATLAB являются мощными и разнообразными. Изучим наиболее простые в использовании возможности (высокоуровневую графику).

Сформируйте два вектора х и y:

» x=0:0.01:2; y=sin(x);

Вызовите функцию:

» plot(x,y)

и вы получите на экране график функции (рис. 1).

Рис. 1. График функции y=sin(x)

MATLAB показывает графические объекты в специальных графических окнах, имеющих в заголовке слово Figure.

Не убирая с экрана дисплея первое графическое окно, введите с клавиатуры выражения

» z=cos(x);

» plot(x,z)

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

Если нужно второй график провести «поверх первого графика», то перед вторичным вызовом графической функции plot нужно выполнить команду hold on, которая предназначена для удержания текущего графического окна:

» x=0:0.01:2; y=sin(x);

» plot(x,y)

» z=cos(x);

» hold on

» plot(x,z)

Практически тоже самое получится (рис. 2), если набрать:

» x=0:0.01:2; y=sin(x); z=cos(x);

» plot(x,y,x,z)

Рис. 2. Графики функций y=sin(x), z=cos(x), построенные в одном графическом окне

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

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

Например, для ранее выполненных вычислений с функциями sin и cos постройте графики этих двух функций в первой подобласти, а график функции exp(х) - во второй подобласти одного и того же графического окна (рис. 3):

» w=exp(x);

» subplot(1,2,1); plot(x,y,x,z)

» subplot(1,2,2); plot(x,w)

Рис. 3. Графики функций y=sin(x), z=cos(x) и w=exp(x), построенные в двух подобластях одного графического окна

Диапазоны изменения переменных на осях координат этих подобластей независимы друг от друга. Функция subplot принимает три числовых аргумента, первый из которых равен числу рядов подобластей, второй равен числу колонок подобластей, а третий аргумент - номеру подобласти (номер отсчитывается вдоль рядов с переходом на новый ряд по исчерпании). Снять действие функции subplot можно командой:

» subplot(1,1,1)

Если для одиночного графика диапазоны изменения переменных вдоль одной или обеих осей координат слишком велик, то можно воспользоваться функциями построения графиков в логарифмических масштабах. Для этого предназначены функции semilogx, semilogy и loglog.

Построить график функции в полярных координатах (рис. 4) можно с помощью графической функции polar.

» phi=0:0.01:2*pi; r=sin(3*phi);

» polar(phi,r)

Рис. 4. График функции r=sin(3*phi) в полярных координатах

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

» x=0:0.1:3; y=sin(x);

» plot(x,y,'r-',x,y,'ko')

позволяют придать графику вид красной сплошной линии (рис. 5), на которой в дискретных вычисляемых точках проставляют черные окружности. Здесь функция plot дважды строит график одной и той же функции, но в двух разных стилях. Первый из этих стилей отмечен как 'r-', что означает проведение линии красным цветом (буква r), а штрих означает проведение сплошной линии. Второй стиль, помечен как 'ko', означает проведение черным цветом (буква k) окружностей (буква o) на месте вычисляемых точек.

Рис. 5. Построение графика функции y=sin(x) в двух разных стилях

В общем случае функция plot (x1, y1, s1, x2, y2, s2, ... ) позволяет объединить в одном графическом окне несколько графиков функций y1(x1), y2(x2), ... проведя их со стилями s1, s2, ... и т. д.

Стили s1, s2,... задаются в виде набора трех символьных маркеров, заключенных в одиночные кавычки (апострофы). Один из этих маркеров задает тип линии (Таблица 3). Другой маркер задает цвет (Таблица 4). Последний маркер задает тип проставляемых «точек» (Таблица 5). Можно указывать не все три маркера. Тогда используются маркеры, установленные по умолчанию. Порядок, в котором указывают маркеры, не является существенным, то есть 'r+-' и '-+r' приводит к одинаковому результату.

Маркеры, задающие тип линии

Таблица 3

Маркер

-

--

:

-.

Тип линии

Непрерывная

Штриховая

Пунктирная

Штрихпунктирная

Маркеры, задающие цвет линии

Таблица 4

Маркер

Цвет линии

Маркер

Цвет линии

c

Голубой

g

Зеленый

m

Фиолетовый

b

Синий

y

Желтый

w

Белый

r

Красный

k

Черный


Маркеры, задающие тип точки

Таблица 5

Маркер

+

*

о

X

Тип точки

Точка

Плюс

Звездочка

Кружок

Крестик

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

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

axis ([ xmin, xmax, ymin, ymax ])

Для проставления различных надписей на полученном рисунке применяют функции xlabеl, ylabеl, title и text. Функция xlabеl создает подпись у горизонтальной оси, функция ylabеl - тоже для вертикальной оси (причем эти надписи ориентированы вдоль осей координат). Если требуется разместить надпись в произвольном месте рисунка, применяем функцию text. Общий заголовок для графика создается функцией title. Кроме того, используя команду grid on, можно нанести измерительную сетку на всю область построения графика. Например (рис. 6):

Рис. 6. График функции y=sin(x), построенный в двух стилях, с надписями на координатных осях и на рисунке

» x=0:0.1:3; y=sin(x);

» plot(x,y,'r-',x,y,'ko')

» title('Function sin(x) graph');

» xlabel('xcoordinate'); ylabel('sin(x)');

» text(2.1, 0.9, '\leftarrowsin(x)'); grid on

Надпись функцией text помещается начиная от точки с координатами, указанными первыми двумя аргументами. По умолчанию координаты задаются в тех же единицах измерения, что и координаты, указанные на горизонтальной и вертикальной осях. Специальные управляющие символы вводятся внутри текста после символа \ (обратная косая черта).

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

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

Каждая точка в пространстве характеризуется тремя координатами. Набор точек, принадлежащих некоторой линии в пространстве, нужно задать в виде трех векторов, первый из которых содержит первые координаты этих точек, второй вектор - вторые их координаты, ну а третий вектор - третьи координаты. После чего эти три вектора можно подать на вход функции plot3, которая и осуществит проектирование соответствующей трехмерной линии на плоскость и построит результирующее изображение (рис. 7). Введите с клавиатуры:

» t=0:pi/50:10*pi;

» x=sin(t);

» y=cos(t); plot3(x,y,t); grid on

Убедитесь, что получилась винтовая линия.

Рис. 7. График винтовой линии, построенный с помощью функции plot3

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

» u=-2:0.1:2; v=-1:0.1:1;

» [X,Y]=meshgrid(u,v);

» z=exp(-X.2-Y.2);

» plot3(X,Y,z)

Получите трехмерное изображение графика функции (рис. 8).

Рис. 8. График поверхности в пространстве, построенный с помощью функции plot3

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

Сценарии и m-файлы.

Для простых операций удобен интерактивный режим, но если вычисления нужно многократно выполнять или необходимо реализовывать сложные алгоритмы, то следует использовать m-файлы MATLAB (расширение файла состоит из одной буквы m). Познакомимся со script-m-файлами (или сценариями) - текстовыми файлами, содержащими инструкции на языке MATLAB, подлежащими исполнению в автоматическом пакетном режиме. Создать такой файл удобнее с помощью редактора системы MATLAB. Он вызывается из командного окна системы MATLAB командой меню File/New/M-file (или самой левой кнопкой на полосе инструментов, на которой изображен чистый белый лист бумаги). Записанные в script-файлы команды будут выполнены, если в командной строке ввести имя script-файла (без расширения). Переменные, определяемые в командном окне и переменные, определяемые в сценариях, составляют единое рабочее пространство системы MATLAB, причем переменные, определяемые в сценариях, являются глобальными, их значения заместят значения таких же переменных, которые были использованы до вызова данного script-файла.

После создания текста сценария его надо сохранить на диске в удобном для вас каталоге. Путь к этому каталогу обязательно должен быть известен системе MATLAB. Командой File/Set Path вызывается диалоговое окно просмотрщика путей доступа к каталогам. Для добавления нового каталога в список путей доступа необходимо выполнить далее команду меню Path/Add to path.

Самостоятельные задания для лабораторной работы 1

Задание 1. 

Задать матрицу А с помощью операции конкатенации:

Задание 2. 

Сгенерируйте массив В размером 3х3 со случайными элементами, равномерно распределенными на интервале от 0 до 1.

Задание 3. 

Выполните действия:

A + 10∙B, AT, ВT,

почленно умножить А на В,

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

Задание 4. 

Задать массив С, используя операцию индексации и одну из функций: ones или zeros:

Задание 5. 

Решить систему алгебраических линейных уравнений:

AX=C.

Задание 6. 

Определить массив D:

Задание 7. 

Для двух векторов:

и

определите: ; ; .

Задание 8. 

Постройте два графика в рамках одних осей координат:

.

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

Задание 9. 

Построить графики функций y(x) и z(x) из Задания 8 в разных подобластях одного графического окна. Интервалы изменения для х определите самостоятельно.

Задание 10. 

Постройте поверхность:

,

.

Контрольные вопросы к теме «Основы работы в MATLAB»

  1.  Как изменить на экране формат вывода числа?
  2.  Как можно просмотреть в MATLAB список всех элементарных математических функций?
  3.  Какие виды функций в MATLAB Вам известны?
  4.  Опишите способы создания одномерных массивов в MATLAB.
  5.  Опишите способы создания двумерных массивов в MATLAB.
  6.  Перечислите и объясните действие операторов, используемых при вычислениях с массивами.
  7.  Опишите действие операций отношения.
  8.  Опишите действие логических операций.
  9.  Как построить декартовый и полярный графики функции одной перемен
    ной?
  10.  Как построить несколько графиков в одной системе координат?
  11.  Как построить графики в разных подобластях одного графического окна?
  12.  Как изменить цвет и стиль линий на графиках?
  13.  Как сделать надписи на осях, на полученном рисунке? Как сделать заголо
    вок для графика?
  14.  Как построить график функции двух переменных? Как построить график
    поверхности?
  15.  Что такое m-файлы? Как создать, сохранить и вызвать m-файл?

Содержание отчета

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

В отчет необходимо включить:

цель лабораторной работы;

условия и ход выполнения самостоятельных заданий в порядке их следования;

графики и screenshot’ы, отображающие и иллюстрирующие полученные результаты, появляющиеся в рабочем окне MATLAB;

выводы.


 

А также другие работы, которые могут Вас заинтересовать

29430. Основные концепции возникновения и сохранения безработицы 12.72 KB
  Если придердиваться традиционной модели взаимодействия спроса и предложениято ситуацию безработицывозникающую на нац.При определении причин обратим внимание на 2 исходных обстоятвазавышенный объем предложения труда и заниженный объем спроса на раб.Сторонники рассматривают рынок труда как стандартный рынок одного из факторов првагде все должно подчиняться взаимодю спроса и предя.Линия спроса.
29431. Социально-экономические последствия безработицы 14.69 KB
  Социальноэкономические последствия безработицы.Возникновение безработицы означает открытое недоиспользование раб.Наращивание безработицы всегда сопровождается подрывом психологического здоровья нации. экономические издержки безработицы:1 недоиспользование рабочей силы а значит и недопроизводство валового внутреннего продукта;2 отставание реально произведенного ВВП от потенциального ВВП который мог бы быть создан при отсутствии циклической безработицы т.
29433. Основные теоретические модели экономического роста 14.47 KB
  Основные теоретические модели экономического роста АнеокейнсианскиеБ НеоклассическиеВСоциальноинституциональные Неок. согласно теории Домара существует равновесный тип прироста реального дохода в экономике при котором полностью используются имеющиеся производственные мощности. Такое динамическое равновесие может оказаться неустойчивым как только темп роста плановых инвестиций частного сектора отклоняется от уровня заданного моделью. Харрод построил специальную модель экономического роста 1939г.
29435. Валютная система :понятие, эволюция, режимы обменных курсов. Валютная политика 20.29 KB
  В период между войнами до Бреттонвудской системы статус резервной валюты особой категории конвертируемой валюты не был официально закреплен ни за одной валютой а английский фунт стерлингов и американский доллар оспаривали лидерство в ходе острой конкурентной борьбы. Причем впервые статус резервной валюты был юридически закреплен за долларом и фунтом стерлингов. Обычно валютный курс национальной валюты фиксируется по отношению к основным мировым валютам таким как доллар евро йена или к корзине валют. Для поддержания курса национальной...
29438. Структурные изменения национальной экономики. Основные показатели 14.48 KB
  Основные показатели Промышленность является самой главной отраслью материального производства несмотря на то что с началом перехода к постиндустриальному обществу доля промышленности в мировом ВВП и занятости экономически активного населения стала уменьшаться. Большие сдвиги происходят в отраслевой структуре мировой промышленности. В странах Запада доля добывающих отраслей во всем промышленном производстве в среднем составляет 2 а в развивающихся странах 14 Изменения коснулись и внутренних пропорций в добывающей и обрабатывающей...