chapter 4 matlab programming combining loops and logic copyright © the mcgraw-hill companies, inc....

Post on 11-Jan-2016

216 Views

Category:

Documents

3 Downloads

Preview:

Click to see full reader

TRANSCRIPT

Chapter 4MATLAB Programming

Combining Loops and Logic

Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Combining Loops and Logic

• Complex programs usually contain a both loops and logical statements to control the sequence of calculations

• As an example, let’s consider this example: We want to create an identity matrix (a square array with all ones as diagonal elements, zeros as off-diagonal elements) for a given size. For size = 3, our matrix would be:

Engineering Computation: An Introduction Using MATLAB and Excel

1 0 0 0 1 0 0 0 1

Example

• There is a built-in MATLAB command “eye” that creates an identity matrix, but we will ignore that for this example

• We will call the matrix A, so we need to define each element A(m,n) where m and n both range from 1 to the specified size

• This will require two nested for loops• For each element, a conditional statement is

required: if m = n, then A(m,n) = 1, else A(m,n) = 0

Engineering Computation: An Introduction Using MATLAB and Excel

Example

• Can you de-scramble these lines of code to create an identity matrix and print it to the screen?

Engineering Computation: An Introduction Using MATLAB and Excel

A(m,n) = 0;for m = 1:SizeendSize = 10;AA(m,n) = 1;elseendif m == nendfor n = 1:Size

Flow Chart

Engineering Computation: An Introduction Using MATLAB and Excel

No

Yes

Define Size

for m = 1: Size

m = n ?

for n = 1: Size

A(m,n) = 1 A(m,n) = 0

Output A

Solution

Engineering Computation: An Introduction Using MATLAB and Excel

Size = 10;for m = 1:Size for n = 1: Size if m == n A(m,n) = 1; else A(m,n) = 0; end endendA

Example

Engineering Computation: An Introduction Using MATLAB and Excel

Example

• Let’s set the Size to 3 and repeat:

• No change! What happened?

Engineering Computation: An Introduction Using MATLAB and Excel

Example

• A was stored as a a 10 X 10 matrix in memory before the m-file was modified

• When the new file was executed, the elements of A up to (3,3) were overwritten; the rest were unchanged

• Good practice to clear your variables (especially arrays) at the beginning of an m-file:

Engineering Computation: An Introduction Using MATLAB and Excel

Example

• Now it works:

Engineering Computation: An Introduction Using MATLAB and Excel

Example (Example 4.2)

• In many textbook problems, a 3-4-5 triangle is encountered:

• Note that the hypotenuse (5) is a perfect square: an integer that is the square root of another integer (25)

• Many calculations are made simple for this configuration: cosθ = 4/5; sinθ = 3/5, etc.

θ 3

4

5

Problem Description

• Can we find the other perfect squares for integer side lengths x and y from 1 to 25?

• h = hypotenuse

Engineering Computation: An Introduction Using MATLAB and Excel

θy

x

h

Program Planning

• We will need to use two nested loops, since we have two independent variables: x and y

• Things to consider:– How will we identify perfect squares mathematically?– Do we want to store the perfect squares that we find,

and/or do we want to print them to the screen or a file?– Do we want to count the number of perfect square

combinations found?

Engineering Computation: An Introduction Using MATLAB and Excel

Begin Flow Chart with Loop Statements

• How do we determine if h is an integer? Consider the MATLAB function floor:

>> help floor

FLOOR Round towards minus infinity.

FLOOR(X) rounds the elements of X to the nearest integers towards minus infinity.

Engineering Computation: An Introduction Using MATLAB and Excel

for x = 1:25

for y = 1:25

h = sqrt(x^2 + y^2)

Check for Perfect Square

• We can compare h and floor(h) directly in an if statement:

if h == floor(h)

• If this statement is true, then we will print the values of x, y, and h to the screen

• If it is false, then we will do nothing

Engineering Computation: An Introduction Using MATLAB and Excel

Engineering Computation: An Introduction Using MATLAB and Excel

for x = 1:25

Is h an integer?

Print m

No

Yes m = m + 1Print x, y, h

for y = 1:25

h = sqrt(x^2 + y^2)

m = 0

MATLAB Code

for x = 1:25

for y = 1:25

h = sqrt(x^2 + y^2);

• What type of conditional statement do we need?• if• if-else• if-elseif

Engineering Computation: An Introduction Using MATLAB and Excel

MATLAB Code

• A simple if statement works here – we either do the next steps or we skip them

for x = 1:25

for y = 1:25

h = sqrt(x^2 + y^2);

if h == floor(h)

x

y

h

end

Engineering Computation: An Introduction Using MATLAB and Excel

MATLAB Code

• Close both loops with end statementsfor x = 1:25 for y = 1:25 h = sqrt(x^2 + y^2); if h == floor(h) x y h end endend

Engineering Computation: An Introduction Using MATLAB and Excel

Results

• Save file as “PerSquares” and run:>> PerSquares

x =

3

y =

4

h =

5

x =

4

y =

3

h =

5

(Screen output continues for many lines)

Engineering Computation: An Introduction Using MATLAB and Excel

Add Formatting to Output

for x = 1:25

for y = 1:25

h = sqrt(x^2 + y^2);

if h == floor(h)

fprintf('%10i %10i %10i\n',x,y,h)

end

end

end

More about the fprintf command later

Engineering Computation: An Introduction Using MATLAB and Excel

Results

>> PerSquares 3 4 5 4 3 5 5 12 13 6 8 10 7 24 25 8 6 10 8 15 17 9 12 15 10 24 26 12 5 13 12 9 15 12 16 20 15 8 17 15 20 25 16 12 20 18 24 30 20 15 25 20 21 29 21 20 29 24 7 25 24 10 26 24 18 30>>

• How would we add a counter to report the number of combinations found?

• How do we eliminate duplicates? (such as 3, 4, 5; 4, 3, 5)

Engineering Computation: An Introduction Using MATLAB and Excel

Counter Added

m = 0;

for x = 1:25

for y = 1:25

h = sqrt(x^2 + y^2);

if h == floor(h)

fprintf('%10i %10i %10i\n',x,y,h)

m = m + 1;

end

end

end

fprintf('\n Combinations found = %i\n',m)

Engineering Computation: An Introduction Using MATLAB and Excel

Eliminating Duplicates

• The first time though the x-loop, x = 1 and y = 1:25:

x = 1

y = 1,2,3,4….25• The second time though the x-loop, x = 2 and y = 1:25:

x = 2

y = 1,2,3,4….25• But since we have already looked at the combination

x = 1, y = 2, we do not want to look at x = 2, y = 1

Engineering Computation: An Introduction Using MATLAB and Excel

Eliminating Duplicates

• If we start the y-loop at 2 when x = 2:

x = 2

y = 2,3,4,5….25• And start the y-loop at 3 when x = 3:

x = 3

y = 3,4,5,6….25• And similar for the other values of x, then we have

eliminated duplicate combinations

Engineering Computation: An Introduction Using MATLAB and Excel

y-Loop Adjusted

m = 0;

for x = 1:25

for y = x:25

h = sqrt(x^2 + y^2);

if h == floor(h)

fprintf('%10i %10i %10i\n',x,y,h)

m = m + 1;

end

end

end

fprintf('\n Combinations found = %i\n',m)

Engineering Computation: An Introduction Using MATLAB and Excel

Results

>> PerSquares

3 4 5

5 12 13

6 8 10

7 24 25

8 15 17

9 12 15

10 24 26

12 16 20

15 20 25

18 24 30

20 21 29

Combinations found = 11

>>

• For you to think about:

• How would we eliminate combinations that are multiples of other combinations?

(Example: 6, 8, 10 is a multiple of 3, 4, 5 – forms a similar triangle)

Engineering Computation: An Introduction Using MATLAB and Excel

The fprintf Command

• This command writes formatted output to the screen• The format of the command is:

fprintf(fid, ’Text to be written, including conversion

specifications for any variables to be printed’, variables)

• The file ID (fid) is omitted for output to the screen• Conversion specifications are instructions for how the

variables are to be formatted, inserted at the points where the variables are to be written

Engineering Computation: An Introduction Using MATLAB and Excel

Conversion Specifications

• Conversion specifications begin with a % symbol• Next comes the number of digits and decimal

places• Last is designator of format type. Most common

are:• f = fixed number of decimal places• E or e = exponential notation• i = integer

Engineering Computation: An Introduction Using MATLAB and Excel

Examples

• >> fprintf('Pi = %8.3f',pi)

Pi = 3.142

Engineering Computation: An Introduction Using MATLAB and Excel

Text to be written to the screen, including the conversion specification for the variable (pi)

pi is output over 8 spaces, including 3 decimal places

Examples

• >> fprintf('Pi = %e',pi)

Pi = 3.141593e+000

Engineering Computation: An Introduction Using MATLAB and Excel

Note that the number of digits and the number of decimal places are optional

pi is output in exponential notation, with the number of digits corresponding to the default “short” format

Examples

• >> fprintf('\nPi = %.4f\n',pi)

Pi = 3.1416

>>

Engineering Computation: An Introduction Using MATLAB and Excel

The characters \n within the output string start a new line

pi is output to 4 decimal places

Examples

• >> m = 12;

>> fprintf('\n\nThe value of m is %i\n\n',m)

The value of m is 12

>>

Engineering Computation: An Introduction Using MATLAB and Excel

m is output as an integer

Writing to a File

• Before writing to a file, you must first open a file and assign it to “fid” (file ID):

• Example: fid = fopen('amtable','wt');• 'wt' indicates write access; text file format. If the

file does not exist, it will be created. If it already exists, its contents will be overwritten

• 'at' instead of 'wt' indicates that an existing file will be appended – the new results will be added to the end of an existing file

Engineering Computation: An Introduction Using MATLAB and Excel

Modifications to “PerSquares” File:

m = 0;fid = fopen('output.txt','wt');fprintf(fid,' x y h\n');fprintf(fid,' === === ===\n');for x = 1:25 for y = x:25 h = sqrt(x^2 + y^2); if h == floor(h) fprintf(fid,'%5i %5i %5i\n',x,y,h); m = m + 1; end endendfprintf('\n Combinations found = %i\n',m)

Engineering Computation: An Introduction Using MATLAB and Excel

New file “output.txt” opened for write access

Column headers written to file

Integer triangles written to file

Number of triangles found written to screen

Output

• The table is now printed to the file “output,” which can be opened in Word or Notepad, or imported into Excel

Engineering Computation: An Introduction Using MATLAB and Excel

top related