{ "nbformat": 4, "nbformat_minor": 0, "metadata": { "colab": { "provenance": [] }, "kernelspec": { "name": "python3", "display_name": "Python 3" }, "language_info": { "name": "python" } }, "cells": [ { "cell_type": "markdown", "source": [ "#**Lab 3**\n", "\n", "**Name: (your name)**\n", "\n" ], "metadata": { "id": "6VpZ01tyznHo" } }, { "cell_type": "markdown", "source": [ "Some remarks before you start:\n", "* Import the Python packages below each time you start a session.\n", "* Before submitting your report, remove all ouputs by clicking on **Edit🠦Clear all ouputs**. Then download your report by clicking on **File🠦Download🠦.ipynb**. This is the file you will submit on Canvas.\n", "\n", "In this lab, you will practice:\n", "* define and graph functions\n", "* use Bisection method and Newton-Raphson method to find roots\n", "* use Gradient Descent/Ascent method to find local min/max\n", "* solve problems of projectile motion and mortgage rate\n", "\n", "\\begin{array}{|c| c|}\n", " \\hline\n", " \\text{Problems} & \\text{Points}\\\\\n", " \\hline\\hline\n", " 1, 3, 5, 7 & 3 \\\\\n", " \\hline\n", " 2, 4, 6, 8, 9 & 4 \\\\\n", " \\hline\n", " \\text{Readability of your report} & 3 \\\\\n", " \\hline\n", " \\text{Total: 9} & \\text{Total: 35} \\\\\n", " \\hline\n", "\\end{array}\n", "\n" ], "metadata": { "id": "3cVoL2qvzufn" } }, { "cell_type": "markdown", "source": [ "##**I. Import necessary Python packages**\n", "Execute the following code each time you start a session." ], "metadata": { "id": "bQagzUIHzzb_" } }, { "cell_type": "code", "source": [ "from matplotlib.pyplot import*\n", "from autograd.numpy import*\n", "from autograd import elementwise_grad as diff" ], "metadata": { "id": "sGBvQoGSzoih" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "## **II. Define and graph functions**\n", "\n", "To define a function on Python, you will use the keyword **def**. For example, the code below defines the function $$f(x)=\\cos^2(x)-\\cos(x^2)$$" ], "metadata": { "id": "yGFzT_PXz431" } }, { "cell_type": "code", "source": [ "def f(x):\n", " return cos(x)**2-cos(x**2)" ], "metadata": { "id": "kxIif3jP1xeP" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "To graph the function, you first need to generate an array of $x$-values using the command **linspace**. For example," ], "metadata": { "id": "QqnmIFJyDe1-" } }, { "cell_type": "code", "source": [ "x=linspace(0,6,16) # Generates 16 evenly-spaced points between 0 and 6\n", "print(x)" ], "metadata": { "id": "_fLg6iO5z5sG" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "*Note that 16 is the number of points, not the number of subintervals. The number of subintervals in this case is 15.*\n", "\n", "At these values of $x$, the command **plot** will connect the points $(x,f(x))$ together by straight lines." ], "metadata": { "id": "PZSxjPbZFM2L" } }, { "cell_type": "code", "source": [ "plot(x,f(x))" ], "metadata": { "id": "ndThAdz3nzYV" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "You can label the axes and give a title to the plot as follows." ], "metadata": { "id": "los8m4Es9GA6" } }, { "cell_type": "code", "source": [ "plot(x, f(x))\n", "xlabel(\"x\")\n", "ylabel(\"f(x)\")\n", "title(\"Plot of $f(x) = \\cos(x)^2 - \\cos(x^2)$\")" ], "metadata": { "id": "3Bti5ooH8P4i" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "You can graph two or more functions on the same graph. For example\n", "\n", "$$f(x)=x^2,\\ \\ g(x)=1-x$$" ], "metadata": { "id": "bZzavLFJEyhG" } }, { "cell_type": "code", "source": [ "plot(x, x**2, label=\"graph of $f(x)=x^2$\")\n", "plot(x, 1-x, label=\"graph of $g(x)=1-x$\")\n", "xlabel(\"x\")\n", "legend()\n", "title(\"two functions\")" ], "metadata": { "id": "rp9vTVKqBVC_" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "###**Exercise 1**\n", "Graph the function $g(x)=\\cos(x)-\\cos(\\sqrt{2}x)+\\frac{1}{3}\\sin(3x)$ on the interval $[0,12]$. In your **plot** command, use 100 equal *subintervals* (therefore, the number of equally-spaced points is 101). Give your plot a title." ], "metadata": { "id": "DIQOwXFQHl-b" } }, { "cell_type": "markdown", "source": [ "###**Exercise 2**\n", "To find the derivative of f, use the command **diff**. For example," ], "metadata": { "id": "Go2IWVSOKeW_" } }, { "cell_type": "code", "source": [ "df = diff(f)\n", "x=linspace(0,6,16)\n", "plot(x,df(x))" ], "metadata": { "id": "TVtBstKMCF-c" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "To evaluate the derivative of $f$ at $x=1$, namely $f'(1)$, just run the command **df(1.0)** or **df(1.)**. If you run **df(1)**, Python will give an error message because it wants a float-point number for its argument instead of an integer." ], "metadata": { "id": "jz1WNU_pCyuf" } }, { "cell_type": "markdown", "source": [ "* With the function $g$ in [Exercise 1](#graph), evaluate $g'(0)$, $g'(\\pi)$, and $g''(1)$. *Hint: $g''$ is the derivative of $g'$.*\n", "* Graph $g$, $g'$, $g''$ together on the same plot on the interval $[0,12]$. In your **plot** command, use 100 equal subintervals." ], "metadata": { "id": "9OfTiqaLF-bl" } }, { "cell_type": "markdown", "source": [ "##**III. Bisection method**\n", "Suppose a continuous function $f$ has different signs at $x=a$ and at $x=b$. *Intermediate Value Theorem* guarantees that $f$ must have a root between $a$ and $b$. You can find approximately this root using the Bisection method, i.e. by the process of halfing the search interval until a certain number of divisions is reached or until a desirable precision is reached. If the original search interval $[a,b]$ is divided $n$ times, the Python code is as follows." ], "metadata": { "id": "Z_m2zyE8PBDJ" } }, { "cell_type": "code", "source": [ "def bisection(f,a,b,n):\n", " for i in range(n):\n", " c = (a+b)/2\n", " if f(c)*f(a)<0: b = c\n", " else: a = c\n", " print(i, c)\n", " return (a+b)/2" ], "metadata": { "id": "0x6z6B0_XHkG" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "###**Exercise 3**\n", "* Explain what each line of the code above does.\n", "* Use this code, with $a$ and $b$ of your choice, to find approximately $\\sqrt{2}$ (root of $f(x)=x^2-2$). How large must $n$ be to get 4 correct decimal places?" ], "metadata": { "id": "F_ezhh0EZjX_" } }, { "cell_type": "markdown", "source": [ "###**Exercise 4**\n", "* Graph two curves $y=xe^{-x}$ and $y=\\frac{1}{x^2+1}$ on the same plot.\n", "* From the graph, how many intersection points do you see? Give rough estimates for the coordinates of those intersection points.\n", "* Use the Bisection method to find the coordinates of those points. The $x$-coordinates must be correct with an allowable error of $0.001$." ], "metadata": { "id": "J9xAgbPfOvHc" } }, { "cell_type": "markdown", "source": [ "##**IV. Newton-Raphson method**\n", "In the Newton-Raphson method to solve $f(x)=0$, you start with an initial guess $x_0$. Then successively update this guess by $x_1,x_2,x_3,...$ using the recursive formula\n", "\n", "$$x_{n+1}=x_n-\\frac{f(x_n)}{f'(x_n)}$$\n", "\n", "You stop when a certain number of iterations is reached or when a certain precision is reached, i.e. $|x_{n+1}-x_n|$ is less than some prescribed $\\epsilon$. The Python code for doing $n$ iterations is as follows." ], "metadata": { "id": "yTs3lEbvc53r" } }, { "cell_type": "code", "source": [ "def newton(f,x0,n):\n", " df = diff(f)\n", " x = float(x0)\n", " for i in range(n):\n", " x = x - f(x)/df(x)\n", " print(i, x)\n", " return x" ], "metadata": { "id": "ZXYoR04oWWHT" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "###**Exercise 5**\n", "* Explain what each line of the code does.\n", "* Find $\\sqrt{2}$ by finding the root of $f(x)=x^2-2$. Use initial guess $x_0=2$. How large is $n$ in order to obtain a precision of $0.00001$ ? In other words, how large is $n$ such that $|x_{n+1}-x_n|<0.00001$ ?" ], "metadata": { "id": "PoZ9vnh11OPp" } }, { "cell_type": "markdown", "source": [ "###**Exercise 6**\n", "In projectile motion, the horizontal $x$ and the vertical $y$ positions are functions of time. From Newton's Second Law of Motion:\n", "\n", "$$x=v_0\\cos(\\theta)t,\\ \\ \\ y=h+v_0\\sin(\\theta) t-\\frac{1}{2}gt^2$$\n", "\n", "where:\n", "\n", "$x$ = horizontal displacement\n", "\n", "$y$ = vertical displacement\n", "\n", "$h$ = initial height\n", "\n", "$v_0$ = initial velocity\n", "\n", "$\\theta$ = angle of projection\n", "\n", "$g$ = $9.81$ m/s$^2$ = acceleration due to gravity\n", "\n", "From the first equation, one can extract $t$ in terms of $x$ and then substitute $t$ into the second equation. One arrives at the formula:\n", "\n", "$$y=h+x\\tan(\\theta)-\\frac{gx^2}{2v_0^2\\cos^2(\\theta)}$$\n", "\n", "The *horizontal range* is the value of $x$ such that $y=0$." ], "metadata": { "id": "tUzvkc6u3MWQ" } }, { "cell_type": "markdown", "source": [ "![shooting.png]()" ], "metadata": { "id": "tIyVetMUZ8XX" } }, { "cell_type": "markdown", "source": [ "With an initial velocity of $50$ m/s and an initial height of $10$ meters, what is the angle $\\theta$ to obtain a horizontal range of $225$ meters? Give your answer in degree (not radian), correct to 4 decimal places." ], "metadata": { "id": "BrKsivKMeLGg" } }, { "cell_type": "markdown", "source": [ "##**V. Gradient Descent/Ascent methods**\n", "The *Gradient Descent method* is a simple algorithm to find a local minimum of a function $f$. You start with an initial guess $x_0$ and successively update it using the recursion\n", "\n", "$$x_{n+1}=x_n-\\alpha f'(x_n)$$\n", "\n", "The *Gradient Ascent method* is to find a local maximum. It uses the same recursion formula above, except that the minus sign is changed to plus sign. The Python code to compute $x_1$, $x_2$,..., $x_n$ in the Gradient Descent method is as follows." ], "metadata": { "id": "RUrzT4qp7Ytx" } }, { "cell_type": "code", "source": [ "def gradd(f,x0,alpha,n):\n", " df = diff(f)\n", " x = float(x0)\n", " for i in range(n):\n", " x = x - alpha*df(x)\n", " print(i, x, df(x))\n", " return x" ], "metadata": { "id": "UUfoQ-PVjoW_" }, "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "source": [ "###**Exercise 7**\n", "* Explain what each line in the code above does.\n", "* Use the code to find the minimum value of $f(x)=x^2$ with initial guess $x_0=1$. Stop when $|f'(x_n)|<0.01$. Give a value of the learning rate $\\alpha$ for which the sequence $(x_n)$ converges quickly to the minimum. Give a value of $\\alpha$ for which the sequence $(x_n)$ fails to converge." ], "metadata": { "id": "lv3_kr_4jmgu" } }, { "cell_type": "markdown", "source": [ "###**Exercise 8**\n", "* Graph the function $2x^4-9x^3+18x-4$ on the interval $[-2,4]$.\n", "* Use the Gradient Ascent method to find its local maximum. Choose your own initial guess and learning rate. Stop when $|f'(x_n)|<0.005$." ], "metadata": { "id": "4SX6-2mUntYO" } }, { "cell_type": "markdown", "source": [ "###**Exercise 9**\n", "If you take a loan of $P$ (dollars) at a mortgage rate APR$=r$ and if the loan term is $n$ months, then your monthly payment is\n", "\n", "$$q=\\frac{Pr/12}{1-(1+r/12)^{-n}}$$\n", "\n", "You might have seen this formula if you took Math 107. Imagine that you have found your dream house that is listed for \\\\$400,000. You can only afford \\\\$2,000 per month. Suppose the loan term is 30 years. How low must the mortgage rate be (in percentage) for you to afford this house?\n", "\n", "*Hint: you can model this problem as an optimization problem or as a root-finding problem.*" ], "metadata": { "id": "WlszgpYxpTQH" } } ] }