====== Math 445 lab 5: programming basics ====== Matlab vocabulary for this lab for fprintf function mean std * length size rand randn **Problem 1:** Write a **for** loop that will print statements of the form 1 times pi is 3.1416 2 times pi is 6.2832 for the numbers 1 through 10. ---- **Problem 2:** If $F$ is a temperature in Farenheit, then $C = \frac{5}{9}(F-32)$ is the same temperature in Celsius. Write a function ''farenheit2celsius'' that takes a Farenheit temperature as input, converts it to Celsius, prints a statement of the form ''20 Farenheit is -6.6667 Celsius.'', and returns the Celsius value as its output. ---- **Problem 3:** Write a **for** loop that uses the above function to print a list of statements -10 Farenheit is -23.3333 Celsius. 0 Farenheit is -17.7778 Celsius. for Farenheit temperatures from -10 to 100, in steps of 10. Challenge: Get the text to line up nicely using field-width specifiers in fprintf! ---- **Problem 4:** Write a function ''average'' that takes an input vector $x$ and returns as output the average (mean) value of its elements, according to the formula \begin{equation*} \text{average}(x) = \frac{1}{N} \sum_{i=1}^N x_i \end{equation*} where $N$ is the number of elements in $x$. Test your function by comparing its output to the output of the built-in Matlab function **mean** on a random vector of length 100 whose elements are uniformly distributed between 0 and 1. ---- **Problem 5:** Write a function ''deviation'' that takes an input vector $x$ and returns the standard deviation of its elements, according to the formula \begin{equation*} \text{deviation}(x) = \sqrt{\frac{1}{N-1} \sum_{i=1}^N (x_i - \bar{X})^2} \end{equation*} where $\bar{x}$ is the average the elements of $x$, and $N$ is the number of elements in $x$. Test your function by comparing its output to the output of the built-in Matlab function **std** on a random vector of length 100 whose elements are in a normal (Gaussian) distribution about $x=0$. ---- **Problem 6:** The formula for matrix-vector multiplication $y = Ax$ is y_i = \sum_{j=1}^n A_{ij} x_j In this formula, $A$ is an $m \times n$ matrix, $x$ is an $n$-dimensional column vector, and $y$ is an $m$-dimensional column vector. Write a function ''matvecmult'' that takes a matrix $A$ and a vector $x$ as inputs, computes $y = Ax$ according to that formula, and returns the vector $y$. Compare your ''matvecmult'' to Matlab's built-in matrix-vector multiplication operator ''*'' on a random $4 \times 4$ matrix and a random 4d column vector. ---- **Problem 7:** The formula for matrix-matrix multiplication $C = AB$ of an $m \times n$ matrix $A$ and an, $n \times p$ matrix $B$ is C_{i,j} = \sum_{k=1}^n A_{ik} B_{k,j} \quad \text{ for } i = 1,\dots,m, \text{ and } j = 1,\dots,p, The product $C = AB$ is an $m \times p$ matrix. Write a function ''matmatmult'' that takes a matrix $A$ and a vector $x$ as inputs, computes $C = AB$ according to that formula, and returns the matrix $C$. Compare your ''matmatmult'' to Matlab's built-in matrix-vector multiplication operator ''*'' on a random $4 \times 3$ matrix $A$ and a random $3 \times 5$ matrix B.