Matlab - Introduction Slides

Download as pdf or txt
Download as pdf or txt
You are on page 1of 52

Introduction to Matlab

By: İ.Yücel Özbek


Outline:
 What is Matlab?
 Matlab Screen
 Variables, array, matrix, indexing
 Operators (Arithmetic, relational, logical )
 Display Facilities
 Flow Control
 Using of M-File
 Writing User Defined Functions
 Conclusion
What is Matlab?
 Matlab MATLAB (Matrix laboratory) is
basically a high level language which has
many specialized toolboxes for making things
easier for us

Matlab

High Level
Languages such as
C, Pascal etc.

Assembly
What are we interested in?
 Matlab (C++ and LabView) are required in
almost every research position.
 Advantage: Good toolbox library
 Disavantage:
 Longer processing time
 Price
Free Clones
 Octave
 Scilab
Matlab Screen
 Command Window
 type commands

 Current Directory
 View folders and m-files

 Workspace
 View program variables
 Double click on a variable
to see it in the Array Editor

 Command History
 view past commands
 save a whole session
using diary
Variables
 No need for types. i.e.,

int a;
double b;
float c;

 All variables are created with double precision unless


specified and they are matrices.
Example:
>>x=5;
>>x1=2;

 After these statements, the variables are 1x1 matrices


with double precision
Getting help
 The help command >> help
 The help window >> helpwin
 The lookfor command >> lookfor
 CANCEL >>CTR C
 GOOGLE: Matlab...
» lookfor scholes
BLSLAMBDA Black-Scholes elasticity.
BLSPRICE Black-Scholes put and call pricing.
BLSRHO Black-Scholes sensitivity to interest rate change.
....
» help blsprice
BLSPRICE Black-Scholes put and call pricing.
[CALL,PUT] = BLSPRICE(SO,X,R,T,SIG,Q) returns the value of
call and put options using the Black-Scholes pricing formula.SO is
the current asset price, X is the exercise price, R is the risk-
free
....
Array, Matrix
 a vector x = [1 2 5 1]

x =
1 2 5 1

 a matrix x = [1 2 3; 5 1 4; 3 2 -1]

x =
1 2 3
5 1 4
3 2 -1

 transpose y = x’ y =
1
2
5
1
Long Array, Matrix
 t =1:10

t =
1 2 3 4 5 6 7 8 9 10
 k =2:-0.5:-1

k =
2 1.5 1 0.5 0 -0.5 -1

 B = [1:4; 5:8]

x =
1 2 3 4
5 6 7 8
Generating Vectors from functions
 zeros(M,N) MxN matrix of zeros x = zeros(1,3)
x =
0 0 0

 ones(M,N) MxN matrix of ones


x = ones(1,3)
x =
1 1 1
 rand(M,N) MxN matrix of uniformly
distributed random x = rand(1,3)
numbers on (0,1) x =
0.9501 0.2311 0.6068
Matrix Index
 The matrix indices begin from 1 (not 0 (as in C))
 The matrix indices must be positive integer
Given:

A(-2), A(0)

Error: ??? Subscript indices must either be real positive integers or logicals.

A(4,2)
Error: ??? Index exceeds matrix dimensions.
Concatenation of Matrices
 x = [1 2], y = [4 5], z=[ 0 0]

A = [ x y]

1 2 4 5

B = [x ; y]

1 2
4 5

C = [x y ;z]
Error:
??? Error using ==> vertcat CAT arguments dimensions are not consistent.
Operators (arithmetic)
+ addition
- subtraction
* multiplication
/ division
^ power
‘ complex conjugate transpose
Matrices Operations

Given A and B:

Addition Subtraction Product Transpose


Operators
Element by Element
.* element-by-element multiplication
./ element-by-element division
.^ element-by-element power

FIND fuction
X = [1 0 4 -3 0 0 0 8 6];

find(X > 2)
ans =

3 8 9
The use of “.” – “Element” Operation
A = [1 2 3; 5 1 4; 3 2 1]
A=
1 2 3
5 1 4
3 2 -1

b = x .* y c=x./y d = x .^2
x = A(1,:) y = A(:,3)
b= c= d=
x= y= 3 8 -3 0.33 0.5 -3 1 4 9
1 2 3 3 4 -1
K= x^2
Erorr:
??? Error using ==> mpower Matrix must be square.
B=x*y
Erorr:
??? Error using ==> mtimes Inner matrix dimensions must agree.
Math Functions
Basic Task: Plot the function sin(x)
between 0≤x≤4π
 Create an x-array of 100 samples between 0
and 4π.

>>x=linspace(0,4*pi,100);

 Calculate sin(.) of the x-array


1

0.8

0.6

>>y=sin(x); 0.4

0.2

 Plot the y-array -0.2

-0.4

-0.6

>>plot(y) -0.8

-1
0 10 20 30 40 50 60 70 80 90 100
Plot the function e-x/3sin(x) between
0≤x≤4π
 Create an x-array of 100 samples between 0
and 4π.
>>x=linspace(0,4*pi,100);

 Calculate sin(.) of the x-array


>>y=sin(x);

 Calculate e-x/3 of the x-array


>>y1=exp(-x/3);

 Multiply the arrays y and y1


>>y2=y*y1;
Plot the function e-x/3sin(x) between
0≤x≤4π
 Multiply the arrays y and y1 correctly
>>y2=y.*y1;

 Plot the y2-array


0.7

>>plot(y2) 0.6

0.5

0.4

0.3

0.2

0.1

-0.1

-0.2

-0.3
0 10 20 30 40 50 60 70 80 90 100
Display Facilities 0.7

0.6

0.5

 plot(.) 0.4

0.3

Example:
0.2

0.1
>>x=linspace(0,4*pi,100); 0

>>y=sin(x); -0.1

>>plot(y) -0.2

>>plot(x,y) -0.3
0 10 20 30 40 50 60 70 80 90 100

stem(.)
0.7

 0.6

0.5

0.4

0.3

Example:
0.2

0.1

>>stem(y) 0

>>stem(x,y) -0.1

-0.2

-0.3
0 10 20 30 40 50 60 70 80 90 100
Display Facilities

 title(.)
This is the sinus function
>>title(‘This is the sinus function’) 1

0.8

 xlabel(.) 0.6

0.4

>>xlabel(‘x (secs)’) 0.2

sin(x)
0

 ylabel(.) -0.2

-0.4

-0.6

-0.8
>>ylabel(‘sin(x)’) -1
0 10 20 30 40 50 60 70 80 90 100
x (secs)
Display Facilities

 HOLD ON holds the current plot


 HOLD OFF releases hold on current plot
 HOLD toggles the hold state
 SUBPLOT- display multiple axes

subplot(#rows, #cols, index)


Alternative Scales for Axes

LOGLOG SEMILOGY
Both axes log Y
logarithmic linear X

SEMILOGX PLOTYY
log X 2 sets of
linear Y linear axes

»other_axes
Surface Plot Example
» t = 0.001:0.001:0.03;
» s = 90:0.2:100;
» [gt, gs] = meshgrid(t,s);
» r = 0.1;
» k = 95;
» [call, put] =
blsprice(gs,k,r,gt,0.3);
» surf(t,s,call)
» xlabel('Time to Maturity')
» ylabel('Spot Price’);

»surface_ex
3-D Surface Plotting

»surf_3d
Specialized Plotting Routines

»spec_plots
Operators (relational, logical)

 == Equal to
 ~= Not equal to
 < Strictly smaller
 > Strictly greater
 <= Smaller than or equal to
 >= Greater than equal to
 & And operator
 | Or operator
Flow Control

 if
 for
 while
 break
 ….
Control Structures
Some Dummy Examples
 If Statement Syntax
if ((a>3) & (b==5))
Some Matlab Commands;
if (Condition_1) end
Matlab Commands
if (a<3)
elseif (Condition_2) Some Matlab Commands;
Matlab Commands elseif (b~=5)
Some Matlab Commands;
elseif (Condition_3) end
Matlab Commands
if (a<3)
else Some Matlab Commands;
Matlab Commands else
end Some Matlab Commands;
end
Control Structures
Some Dummy Examples
 For loop syntax for i=1:100
Some Matlab Commands;
end

for i=Index_Array for j=1:3:200


Some Matlab Commands;
Matlab Commands end

end for m=13:-0.2:-21


Some Matlab Commands;
end

for k=[0.1 0.3 -13 12 7 -9.3]


Some Matlab Commands;
end
Control Structures

 While Loop Syntax

Dummy Example
while (condition)
Matlab Commands while ((a>3) & (b==5))
Some Matlab Commands;
end end
Use of M-File
Click to create
a new M-File

• Extension “.m”
• A text file containing script or function or program to run
Use of M-File Save file as Denem430.m

If you include “;” at the


end of each statement,
result will not be shown
immediately
Use of M-File
Writing User Defined Functions

 Functions are m-files which can be executed by


specifying some inputs and supply some desired outputs.
 The code telling the Matlab that an m-file is actually a
function is
function out1=functionname(in1)
function out1=functionname(in1,in2,in3)
function [out1,out2]=functionname(in1,in2)

 You should write this command at the beginning of the m-


file and you should save the m-file with a file name same
as the function name
Writing User Defined Functions
 Examples
 Write a function : out=squarer (A, ind)

 Which takes the square of the input matrix if the input


indicator is equal to 1
 And takes the element by element square of the input
matrix if the input indicator is equal to 2

Same Name
Writing User Defined Functions
 Another function which takes an input array and returns the sum and product
of its elements as outputs

 The function sumprod(.) can be called from command window or an m-file as


Notes:
 “%” is the neglect sign for Matlab (equaivalent
of “//” in C). Anything after it on the same line
is neglected by Matlab compiler.
 Sometimes slowing down the execution is
done deliberately for observation purposes.
You can use the command “pause” for this
purpose
pause %wait until any key
pause(3) %wait 3 seconds
Complex Numbers
 Another function which takes an input array and returns the sum and product
of its elements as outputs

 ≫ z = 2+1.5*1j, real(z)
 to get the result

 z=
 2.000+1.500i

 ans =
 2
Variables

>>I = int8(zeros(100)); % Creates an intermediate array


String Arrays:
 Created using single quote delimiter (')
» str = 'Hi there,'
str =
Hi there,
» str2 = 'Isn''t MATLAB great?'
str2 =
Isn't MATLAB great?

 Each character is a separate matrix element


 (16 bits of memory per character)
str = H i t h e r e , 1x9 vector

 Indexing same as for numeric arrays


»string_array
String Arrays:
Using [ ] operator: » str ='Hi there,';
1x9 vectors
Each row must be » str1='Everyone!';
same length » new_str=[str, ' ', str1]
new_str =
Row separator:
Hi there, Everyone! vectors
1x19 vector
semicolon (;)
» str2 = 'Isn''t MATLAB great?';

Column separator: » new_str2=[new_str; str2]


new_str2 =
space / comma (,)
Hi there, Everyone!
Isn't MATLAB great? 2x19 matrix

For strings of different length:


• STRVCAT » new_str3 = strvcat(str, str2)
• STR2MAT new_str3 =
Hi there, 2x19 matrix
Isn't MATLAB great? (zero padded)

»string_cat
String Arrays:
 String Comparisons
 STRCMP - compare whole strings

 STRNCMP - compare first ‘N’ characters

 FINDSTR - finds substring within a larger


string

 Converting between numeric & string arrays:


 NUM2STR - convert from numeric to string
array
 STR2NUM - convert from string to numeric
array
File I/O : High-level routines:
Use wildcard (*) for
 SAVE & LOAD similar variables
save fname
save fname x y z
save fname data* load fname
save fname -ascii load fname x y z
save fname -v4 load fname -ascii
load fname -mat
load fname*
 Other file formats:
 csvread - comma-separated ASCII
files
 dlmread - general ASCII delimited
files
 textread - read formatted data
Low-level text file I/O:
Writing data to text file:
» fid = fopen('magic5.txt', 'wt');
» fprintf(fid, '%s\n', 'This is a magic matrix');
» fprintf(fid, '%i\t%i\t%i\t%i\t%i\n', magic(5));
» fclose(fid);

ASCII text file: magic5.txt


This is a magic matrix
17 23 4 10 11
24 5 6 12 18
1 7 13 19 25
8 14 20 21 2
15 16 22 3 9

Reading data from text file: » fid=fopen('magic5.txt', 'rt');


» title = fgetl(fid);
» [data,count]=fscanf(fid, '%i');
» data = reshape(data, 5, 5);
»help fprintf
» fclose(fid);
Basic Matlab Operations

% This is a comment, it starts with a “%”


clc % Clear command window
clear all % Clear variables in MatLab
y = 5*3 + 2^2; % simple arithmetic
x = [1 2 4 5 6]; % create the vector “x”
x1 = x.^2; % square each element in x
E = sum(abs(x).^2); % Calculate signal energy
P = E/length(x); % Calculate av signal
Basic Matlab Operations

% Calculate av signal power


x2 = x(1:3); % Select first 3 elements in x
z = 1+2*1j; % Create a complex number
a = real(z); % Pick off real part
b = imag(z); % Pick off imaginary part
plot(x); % Plot the vector as a signal
t = 0:0.1:100; % Generate sampled time
x3=exp(-t).*cos(t); % Generate a discrete signal
plot(t, x3, ‘x’);% Plot points
Basic Matlab Operations

%This shows how to save a table in Excel


columnHeader = {'t', 'x3'};
xlswrite('Table_1.xls',columnHeader,'Sheet1','A1');
%Saves the heather in Excel
xlswrite('Table_1.xls',[t; x3]','Sheet1','A2');
%Saves the variables in Excel

%This reads the same table in Excel


excel_data = xlsread('Table_1.xls',);
Questions
Thank You…

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy