15 lines
111 KiB
JSON
15 lines
111 KiB
JSON
{
|
||
"hash": "1217baf1c6e6a0c25f21cf66177ddedd",
|
||
"result": {
|
||
"markdown": "# Curve Sketching\n\n\n\nThis section uses the following add-on packages:\n\n``` {.julia .cell-code}\nusing CalculusWithJulia\nusing Plots\nusing SymPy\nusing Roots\nusing Polynomials # some name clash with SymPy\n```\n\n\n\n\n---\n\n\nThe figure illustrates a means to *sketch* a sine curve - identify as many of the following values as you can:\n\n\n * asymptotic behaviour (as $x \\rightarrow \\pm \\infty$),\n * periodic behaviour,\n * vertical asymptotes,\n * the $y$ intercept,\n * any $x$ intercept(s),\n * local peaks and valleys (relative extrema).\n * concavity\n\n\nWith these, a sketch fills in between the points/lines associated with these values.\n\n::: {.cell cache='true' hold='true' execution_count=4}\n\n::: {.cell-output .cell-output-display execution_count=5}\n```{=html}\n<div class=\"d-flex justify-content-center\"> <figure> <img src=\"\" class=\"card-img-top\" alt=\"A Figure\">\n <figcaption><div class=\"markdown\"><p>After identifying asymptotic behaviours, a curve sketch involves identifying the \\(y\\) intercept, if applicable; the \\(x\\) intercepts, if possible; the local extrema; and changes in concavity. From there a sketch fills in between the points. In this example, the periodic function \\(f(x) = 10\\cdot\\sin(\\pi/2\\cdot x)\\) is sketched over \\([0,4]\\).</p>\n</div> </figcaption>\n </figure>\n</div>\n```\n:::\n:::\n\n\nThough this approach is most useful for hand-sketches, the underlying concepts are important for properly framing graphs made with the computer.\n\n\nWe can easily make a graph of a function over a specified interval. What is not always so easy is to pick an interval that shows off the features of interest. In the section on [rational](../precalc/rational_functions.html) functions there was a discussion about how to draw graphs for rational functions so that horizontal and vertical asymptotes can be seen. These are properties of the \"large.\" In this section, we build on this, but concentrate now on more local properties of a function.\n\n\n##### Example\n\n\nProduce a graph of the function $f(x) = x^4 -13x^3 + 56x^2-92x + 48$.\n\n\nWe identify this as a fourth-degree polynomial with postive leading coefficient. Hence it will eventually look $U$-shaped. If we graph over a too-wide interval, that is all we will see. Rather, we do some work to produce a graph that shows the zeros, peaks, and valleys of $f(x)$. To do so, we need to know the extent of the zeros. We can try some theory, but instead we just guess and if that fails, will work harder:\n\n::: {.cell execution_count=5}\n``` {.julia .cell-code}\nf(x) = x^4 - 13x^3 + 56x^2 -92x + 48\nrts = find_zeros(f, -10, 10)\n```\n\n::: {.cell-output .cell-output-display execution_count=6}\n```\n4-element Vector{Float64}:\n 0.9999999999999999\n 2.000000000000005\n 4.000000000000004\n 6.000000000000003\n```\n:::\n:::\n\n\nAs we found $4$ roots, we know by the fundamental theorem of algebra we have them all. This means, our graph need not focus on values much larger than $6$ or much smaller than $1$.\n\n\nTo know where the peaks and valleys are, we look for the critical points:\n\n::: {.cell execution_count=6}\n``` {.julia .cell-code}\ncps = find_zeros(f', 1, 6)\n```\n\n::: {.cell-output .cell-output-display execution_count=7}\n```\n3-element Vector{Float64}:\n 1.4257862014364733\n 3.0704645527012464\n 5.253749245862282\n```\n:::\n:::\n\n\nBecause we have the $4$ distinct zeros, we must have the peaks and valleys appear in an interleaving manner, so a search over $[1,6]$ finds all three critical points and without checking, they must correspond to relative extrema.\n\n\nNext we identify the *inflection points* which are among the zeros of the second derivative (when defined):\n\n::: {.cell execution_count=7}\n``` {.julia .cell-code}\nips = find_zeros(f'', 1, 6)\n```\n\n::: {.cell-output .cell-output-display execution_count=8}\n```\n2-element Vector{Float64}:\n 2.1413221086958276\n 4.358677891304171\n```\n:::\n:::\n\n\nIf there is no sign change for either $f'$ or $f''$ over $[a,b]$ then the sketch of $f$ on this interval must be one of:\n\n\n * increasing and concave up (if $f' > 0$ and $f'' > 0$)\n * increasing and concave down (if $f' > 0$ and $f'' < 0$)\n * decreasing and concave up (if $f' < 0$ and $f'' > 0$)\n * decreasing and concave down (if $f' < 0$ and $f'' < 0$)\n\n\nThis aids in sketching the graph between the critical points and inflection points.\n\n\nWe finally check that if we were to just use $[0,7]$ as a domain to plot over that the function doesn't get too large to mask the oscillations. This could happen if the $y$ values at the end points are too much larger than the $y$ values at the peaks and valleys, as only so many pixels can be used within a graph. For this we have:\n\n::: {.cell execution_count=8}\n``` {.julia .cell-code}\nf.([0, cps..., 7])\n```\n\n::: {.cell-output .cell-output-display execution_count=9}\n```\n5-element Vector{Float64}:\n 48.0\n -2.8788980209096167\n 6.035382559783841\n -12.949453288874281\n 90.0\n```\n:::\n:::\n\n\nThe values at $0$ and at $7$ are a bit large, as compared to the relative extrema, and since we know the graph is eventually $U$-shaped, this offers no insight. So we narrow the range a bit for the graph:\n\n::: {.cell execution_count=9}\n``` {.julia .cell-code}\nplot(f, 0.5, 6.5)\n```\n\n::: {.cell-output .cell-output-display execution_count=10}\n{}\n:::\n:::\n\n\n---\n\nThis sort of analysis can be automated. The plot \"recipe\" for polynomials from the `Polynomials` package does similar considerations to choose a viewing window:\n\n::: {.cell execution_count=10}\n``` {.julia .cell-code}\nxₚ = variable(Polynomial)\nplot(f(xₚ)) # f(xₚ) of Polynomial type\n```\n\n::: {.cell-output .cell-output-display execution_count=11}\n{}\n:::\n:::\n\n\n##### Example\n\n\nGraph the function\n\n\n\n$$\nf(x) = \\frac{(x-1)\\cdot(x-3)^2}{x \\cdot (x-2)}.\n$$\n\n\nNot much to do here if you are satisfied with a graph that only gives insight into the asymptotes of this rational function:\n\n::: {.cell execution_count=11}\n``` {.julia .cell-code}\n𝒇(x) = ( (x-1)*(x-3)^2 ) / (x * (x-2) )\nplot(𝒇, -50, 50)\n```\n\n::: {.cell-output .cell-output-display execution_count=12}\n{}\n:::\n:::\n\n\nWe can see the slant asymptote and hints of vertical asymptotes, but, we'd like to see more of the basic features of the graph.\n\n\nPreviously, we have discussed rational functions and their asymptotes. This function has numerator of degree $3$ and denominator of degree $2$, so will have a slant asymptote. As well, the zeros of the denominator, $0$ and $-2$, will lead to vertical asymptotes.\n\n\nTo identify how wide a viewing window should be, for the rational function the asymptotic behaviour is determined after the concavity is done changing and we are past all relative extrema, so we should take an interval that includes all potential inflection points and critical points:\n\n::: {.cell execution_count=12}\n``` {.julia .cell-code}\n𝒇cps = find_zeros(𝒇', -10, 10)\nposs_ips = find_zero(𝒇'', (-10, 10))\nextrema(union(𝒇cps, poss_ips))\n```\n\n::: {.cell-output .cell-output-display execution_count=13}\n```\n(-2.1527576020103956, 3.0)\n```\n:::\n:::\n\n\nSo a range over $[-5,5]$ should display the key features including the slant asymptote.\n\n\nPreviously we used the `rangeclamp` function defined in `CalculusWithJulia` to avoid the distortion that vertical asymptotes can have:\n\n::: {.cell execution_count=13}\n``` {.julia .cell-code}\nplot(rangeclamp(𝒇), -5, 5)\n```\n\n::: {.cell-output .cell-output-display execution_count=14}\n{}\n:::\n:::\n\n\nWith this graphic, we can now clearly see in the graph the two zeros at $x=1$ and $x=3$, the vertical asymptotes at $x=0$ and $x=2$, and the slant asymptote.\n\n---\n\n\nAgain, this sort of analysis can be systematized. The rational function type in the `Polynomials` package takes a stab at that, but isn't quite so good at capturing the slant asymptote:\n\n::: {.cell execution_count=14}\n``` {.julia .cell-code}\nxᵣ = variable(RationalFunction)\nplot(𝒇(xᵣ)) # f(x) of RationalFunction type\n```\n\n::: {.cell-output .cell-output-display execution_count=15}\n{}\n:::\n:::\n\n\n##### Example\n\n\nConsider the function $V(t) = 170 \\sin(2\\pi\\cdot 60 \\cdot t)$, a model for the alternating current waveform for an outlet in the United States. Create a graph.\n\n\nBlindly trying to graph this, we will see immediate issues:\n\n::: {.cell execution_count=15}\n``` {.julia .cell-code}\nV(t) = 170 * sin(2*pi*60*t)\nplot(V, -2pi, 2pi)\n```\n\n::: {.cell-output .cell-output-display execution_count=16}\n{}\n:::\n:::\n\n\nAhh, this periodic function is *too* rapidly oscillating to be plotted without care. We recognize this as being of the form $V(t) = a\\cdot\\sin(c\\cdot t)$, so where the sine function has a period of $2\\pi$, this will have a period of $2\\pi/c$, or $1/60$. So instead of using $(-2\\pi, 2\\pi)$ as the interval to plot over, we need something much smaller:\n\n::: {.cell execution_count=16}\n``` {.julia .cell-code}\nplot(V, -1/60, 1/60)\n```\n\n::: {.cell-output .cell-output-display execution_count=17}\n{}\n:::\n:::\n\n\n##### Example\n\n\nPlot the function $f(x) = \\ln(x/100)/x$.\n\n\nWe guess that this function has a *vertical* asymptote at $x=0+$ and a horizontal asymptote as $x \\rightarrow \\infty$, we verify through:\n\n::: {.cell execution_count=17}\n``` {.julia .cell-code}\n@syms x\nex = log(x/100)/x\nlimit(ex, x=>0, dir=\"+\"), limit(ex, x=>oo)\n```\n\n::: {.cell-output .cell-output-display execution_count=18}\n```\n(-oo, 0)\n```\n:::\n:::\n\n\nThe $\\ln(x/100)$ part of $f$ goes $-\\infty$ as $x \\rightarrow 0+$; yet $f(x)$ is eventually positive as $x \\rightarrow 0$. So a graph should\n\n\n * not show too much of the vertical asymptote\n * capture the point where $f(x)$ must cross $0$\n * capture the point where $f(x)$ has a relative maximum\n * show enough past this maximum to indicate to the reader the eventual horizontal asyptote.\n\n\nFor that, we need to get the $x$ intercepts and the critical points. The $x/100$ means this graph has some scaling to it, so we first look between $0$ and $200$:\n\n::: {.cell execution_count=18}\n``` {.julia .cell-code}\nfind_zeros(ex, 0, 200) # domain is (0, oo)\n```\n\n::: {.cell-output .cell-output-display execution_count=19}\n```\n1-element Vector{Float64}:\n 100.0\n```\n:::\n:::\n\n\nTrying the same for the critical points comes up empty. We know there is one, but it is past $200$. Scanning wider, we see:\n\n::: {.cell execution_count=19}\n``` {.julia .cell-code}\nfind_zeros(diff(ex,x), 0, 500)\n```\n\n::: {.cell-output .cell-output-display execution_count=20}\n```\n1-element Vector{Float64}:\n 271.8281828459045\n```\n:::\n:::\n\n\nSo maybe graphing over $[50, 300]$ will be a good start:\n\n::: {.cell execution_count=20}\n``` {.julia .cell-code}\nplot(ex, 50, 300)\n```\n\n::: {.cell-output .cell-output-display execution_count=21}\n{}\n:::\n:::\n\n\nBut it isn't! The function takes its time getting back towards $0$. We know that there must be a change of concavity as $x \\rightarrow \\infty$, as there is a horizontal asymptote. We looks for the anticipated inflection point to ensure our graph includes that:\n\n::: {.cell execution_count=21}\n``` {.julia .cell-code}\nfind_zeros(diff(ex, x, x), 1, 5000)\n```\n\n::: {.cell-output .cell-output-display execution_count=22}\n```\n1-element Vector{Float64}:\n 448.1689070338064\n```\n:::\n:::\n\n\nSo a better plot is found by going well beyond that inflection point:\n\n::: {.cell execution_count=22}\n``` {.julia .cell-code}\nplot(ex, 75, 1500)\n```\n\n::: {.cell-output .cell-output-display execution_count=23}\n{}\n:::\n:::\n\n\n## Questions\n\n\n###### Question\n\n\nConsider this graph\n\n::: {.cell hold='true' execution_count=23}\n\n::: {.cell-output .cell-output-display execution_count=24}\n{}\n:::\n:::\n\n\nWhat kind of *asymptotes* does it appear to have?\n\n::: {.cell hold='true' execution_count=24}\n\n::: {.cell-output .cell-output-display execution_count=25}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='15960807797932062823' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_15960807797932062823\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15960807797932062823_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15960807797932062823\"\n id=\"radio_15960807797932062823_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n Just a horizontal asymptote, \\(y=0\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15960807797932062823_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15960807797932062823\"\n id=\"radio_15960807797932062823_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n Just vertical asymptotes at \\(x=-1\\) and \\(x=1\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15960807797932062823_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15960807797932062823\"\n id=\"radio_15960807797932062823_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n Vertical asymptotes at \\(x=-1\\) and \\(x=1\\) and a horizontal asymptote \\(y=1\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15960807797932062823_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15960807797932062823\"\n id=\"radio_15960807797932062823_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n Vertical asymptotes at \\(x=-1\\) and \\(x=1\\) and a slant asymptote\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='15960807797932062823_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_15960807797932062823\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 4;\n var msgBox = document.getElementById('15960807797932062823_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_15960807797932062823\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_15960807797932062823\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n###### Question\n\n\nConsider the function $p(x) = x + 2x^3 + 3x^3 + 4x^4 + 5x^5 +6x^6$. Which interval shows more than a $U$-shaped graph that dominates for large $x$ due to the leading term being $6x^6$?\n\n\n(Find an interval that contains the zeros, critical points, and inflection points.)\n\n::: {.cell hold='true' execution_count=25}\n\n::: {.cell-output .cell-output-display execution_count=26}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='16652237429635016138' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_16652237429635016138\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16652237429635016138_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16652237429635016138\"\n id=\"radio_16652237429635016138_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n \\((-5,5)\\), the default bounds of a calculator\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16652237429635016138_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16652237429635016138\"\n id=\"radio_16652237429635016138_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n \\((-3.5, 3.5)\\), the bounds given by Cauchy for the real roots of \\(p\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16652237429635016138_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16652237429635016138\"\n id=\"radio_16652237429635016138_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n \\((-1, 1)\\), as many special polynomials have their roots in this interval\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16652237429635016138_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16652237429635016138\"\n id=\"radio_16652237429635016138_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n \\((-1.1, .25)\\), as this constains all the roots, the critical points, and inflection points and just a bit more\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='16652237429635016138_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_16652237429635016138\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 4;\n var msgBox = document.getElementById('16652237429635016138_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_16652237429635016138\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_16652237429635016138\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n###### Question\n\n\nLet $f(x) = x^3/(9-x^2)$.\n\n\nWhat points are *not* in the domain of $f$?\n\n::: {.cell execution_count=26}\n\n::: {.cell-output .cell-output-display execution_count=27}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='342412158759621938' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_342412158759621938\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_342412158759621938_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_342412158759621938\"\n id=\"radio_342412158759621938_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='342412158759621938_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_342412158759621938\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 5;\n var msgBox = document.getElementById('342412158759621938_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_342412158759621938\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_342412158759621938\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThe $x$-intercepts are:\n\n::: {.cell hold='true' execution_count=27}\n\n::: {.cell-output .cell-output-display execution_count=28}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='16734935305345779169' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_16734935305345779169\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_16734935305345779169_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_16734935305345779169\"\n id=\"radio_16734935305345779169_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='16734935305345779169_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_16734935305345779169\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 4;\n var msgBox = document.getElementById('16734935305345779169_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_16734935305345779169\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_16734935305345779169\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThe $y$-intercept is:\n\n::: {.cell hold='true' execution_count=28}\n\n::: {.cell-output .cell-output-display execution_count=29}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='4379146410226921356' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_4379146410226921356\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_4379146410226921356_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_4379146410226921356\"\n id=\"radio_4379146410226921356_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='4379146410226921356_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_4379146410226921356\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 6;\n var msgBox = document.getElementById('4379146410226921356_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_4379146410226921356\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_4379146410226921356\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThere are *vertical asymptotes* at $x=\\dots$?\n\n::: {.cell hold='true' execution_count=29}\n\n::: {.cell-output .cell-output-display execution_count=30}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='10833813170044518280' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_10833813170044518280\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_10833813170044518280_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_10833813170044518280\"\n id=\"radio_10833813170044518280_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='10833813170044518280_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_10833813170044518280\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 5;\n var msgBox = document.getElementById('10833813170044518280_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_10833813170044518280\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_10833813170044518280\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThe *slant* asymptote has slope?\n\n::: {.cell hold='true' execution_count=30}\n\n::: {.cell-output .cell-output-display execution_count=31}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='13028554335859461168' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_13028554335859461168\">\n <div style=\"padding-top: 5px\">\n </br>\n<div class=\"input-group\">\n <input id=\"13028554335859461168\" type=\"number\" class=\"form-control\" placeholder=\"Numeric answer\">\n</div>\n\n \n </div>\n </div>\n <div id='13028554335859461168_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.getElementById(\"13028554335859461168\").addEventListener(\"change\", function() {\n var correct = (Math.abs(this.value - 1) <= 0);\n var msgBox = document.getElementById('13028554335859461168_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_13028554335859461168\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_13028554335859461168\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n});\n\n</script>\n```\n:::\n:::\n\n\nThe function has critical points at\n\n::: {.cell hold='true,echo' execution_count=31}\n``` {.julia .cell-code}\nradioq(qchoices, 2, keep_order=true)\n```\n\n::: {.cell-output .cell-output-display execution_count=32}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='17545144651571496111' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_17545144651571496111\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_17545144651571496111_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_17545144651571496111\"\n id=\"radio_17545144651571496111_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='17545144651571496111_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_17545144651571496111\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 2;\n var msgBox = document.getElementById('17545144651571496111_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_17545144651571496111\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_17545144651571496111\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThe function has relative extrema at\n\n::: {.cell hold='true' execution_count=32}\n\n::: {.cell-output .cell-output-display execution_count=33}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='11388292424505177996' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_11388292424505177996\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_11388292424505177996_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_11388292424505177996\"\n id=\"radio_11388292424505177996_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='11388292424505177996_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_11388292424505177996\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 7;\n var msgBox = document.getElementById('11388292424505177996_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_11388292424505177996\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_11388292424505177996\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nThe function has inflection points at\n\n::: {.cell hold='true' execution_count=33}\n\n::: {.cell-output .cell-output-display execution_count=34}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='12339552066780780167' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_12339552066780780167\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f, -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f', -10, 10)</code>: <code>[-5.19615, 0, 5.19615]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The values of <code>find_zeros(f'', -10, 10)</code>: <code>[-3, 0, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_4\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_4\" value=\"4\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the numerator: <code>[0]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_5\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_5\" value=\"5\">\n </input>\n <span class=\"label-body px-1\">\n The zeros of the denominator: <code>[-3, 3]</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_6\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_6\" value=\"6\">\n </input>\n <span class=\"label-body px-1\">\n The value of <code>f(0)</code>: <code>0</code>\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_12339552066780780167_7\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_12339552066780780167\"\n id=\"radio_12339552066780780167_7\" value=\"7\">\n </input>\n <span class=\"label-body px-1\">\n None of these choices\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='12339552066780780167_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_12339552066780780167\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 7;\n var msgBox = document.getElementById('12339552066780780167_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_12339552066780780167\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_12339552066780780167\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n###### Question\n\n\nA function $f$ has\n\n\n * zeros of $\\{-0.7548\\dots, 2.0\\}$,\n * critical points at $\\{-0.17539\\dots, 1.0, 1.42539\\dots\\}$,\n * inflection points at $\\{0.2712\\dots,1.2287\\}$.\n\n\nIs this a possible graph of $f$?\n\n::: {.cell hold='true' execution_count=34}\n\n::: {.cell-output .cell-output-display execution_count=35}\n{}\n:::\n:::\n\n\n::: {.cell hold='true' execution_count=35}\n\n::: {.cell-output .cell-output-display execution_count=36}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='7897674602405631850' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_7897674602405631850\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_7897674602405631850_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_7897674602405631850\"\n id=\"radio_7897674602405631850_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n Yes\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_7897674602405631850_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_7897674602405631850\"\n id=\"radio_7897674602405631850_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n No\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='7897674602405631850_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_7897674602405631850\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 1;\n var msgBox = document.getElementById('7897674602405631850_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_7897674602405631850\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_7897674602405631850\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n###### Question\n\n\nTwo models for population growth are *exponential* growth: $P(t) = P_0 a^t$ and [logistic growth](https://en.wikipedia.org/wiki/Logistic_function#In_ecology:_modeling_population_growth): $P(t) = K P_0 a^t / (K + P_0(a^t - 1))$. The exponential growth model has growth rate proportional to the current population. The logistic model has growth rate depending on the current population *and* the available resources (which can limit growth).\n\n\nLetting $K=10$, $P_0=5$, and $a= e^{1/4}$. A plot over $[0,5]$ shows somewhat similar behaviour:\n\n::: {.cell execution_count=36}\n``` {.julia .cell-code}\nK, P0, a = 50, 5, exp(1/4)\nexponential_growth(t) = P0 * a^t\nlogistic_growth(t) = K * P0 * a^t / (K + P0*(a^t-1))\n\nplot(exponential_growth, 0, 5)\nplot!(logistic_growth)\n```\n\n::: {.cell-output .cell-output-display execution_count=37}\n{}\n:::\n:::\n\n\nDoes a plot over $[0,50]$ show qualitatively\t similar behaviour?\n\n::: {.cell hold='true' execution_count=37}\n\n::: {.cell-output .cell-output-display execution_count=38}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='6001833693634372227' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_6001833693634372227\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6001833693634372227_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6001833693634372227\"\n id=\"radio_6001833693634372227_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n Yes\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6001833693634372227_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6001833693634372227\"\n id=\"radio_6001833693634372227_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n No\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='6001833693634372227_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_6001833693634372227\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 1;\n var msgBox = document.getElementById('6001833693634372227_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_6001833693634372227\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_6001833693634372227\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nExponential growth has $P''(t) = P_0 a^t \\log(a)^2 > 0$, so has no inflection point. By plotting over a sufficiently wide interval, can you answer: does the logistic growth model have an inflection point?\n\n::: {.cell hold='true' execution_count=38}\n\n::: {.cell-output .cell-output-display execution_count=39}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='15739806424610812285' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_15739806424610812285\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15739806424610812285_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15739806424610812285\"\n id=\"radio_15739806424610812285_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n Yes\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_15739806424610812285_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_15739806424610812285\"\n id=\"radio_15739806424610812285_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n No\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='15739806424610812285_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_15739806424610812285\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 1;\n var msgBox = document.getElementById('15739806424610812285_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_15739806424610812285\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_15739806424610812285\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nIf yes, find it numerically:\n\n::: {.cell hold='true' execution_count=39}\n\n::: {.cell-output .cell-output-display execution_count=40}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='240560649080445891' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_240560649080445891\">\n <div style=\"padding-top: 5px\">\n </br>\n<div class=\"input-group\">\n <input id=\"240560649080445891\" type=\"number\" class=\"form-control\" placeholder=\"Numeric answer\">\n</div>\n\n \n </div>\n </div>\n <div id='240560649080445891_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.getElementById(\"240560649080445891\").addEventListener(\"change\", function() {\n var correct = (Math.abs(this.value - 8.78889830934488) <= 0.001);\n var msgBox = document.getElementById('240560649080445891_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_240560649080445891\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_240560649080445891\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n});\n\n</script>\n```\n:::\n:::\n\n\nThe available resources are quantified by $K$. As $K \\rightarrow \\infty$ what is the limit of the logistic growth model:\n\n::: {.cell hold='true' execution_count=40}\n\n::: {.cell-output .cell-output-display execution_count=41}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='173924680422992361' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_173924680422992361\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_173924680422992361_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_173924680422992361\"\n id=\"radio_173924680422992361_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The limit is \\(P_0\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_173924680422992361_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_173924680422992361\"\n id=\"radio_173924680422992361_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The exponential growth model\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_173924680422992361_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_173924680422992361\"\n id=\"radio_173924680422992361_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The limit does not exist\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='173924680422992361_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_173924680422992361\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 2;\n var msgBox = document.getElementById('173924680422992361_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_173924680422992361\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_173924680422992361\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n##### Question\n\n\nThe plotting algorithm for plotting functions starts with a small initial set of points over the specified interval ($21$) and then refines those sub-intervals where the second derivative is determined to be large.\n\n\nWhy are sub-intervals where the second derivative is large different than those where the second derivative is small?\n\n::: {.cell hold='true' execution_count=41}\n\n::: {.cell-output .cell-output-display execution_count=42}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='6518824058241194571' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_6518824058241194571\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6518824058241194571_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6518824058241194571\"\n id=\"radio_6518824058241194571_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n The function will be much larger (in absolute value) when the second derivative is large, so there needs to be more points to capture the shape\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6518824058241194571_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6518824058241194571\"\n id=\"radio_6518824058241194571_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n The function will increase (or decrease) rapidly when the second derivative is large, so there needs to be more points to capture the shape\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6518824058241194571_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6518824058241194571\"\n id=\"radio_6518824058241194571_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n The function will have more curvature when the second derivative is large, so there needs to be more points to capture the shape\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='6518824058241194571_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_6518824058241194571\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 3;\n var msgBox = document.getElementById('6518824058241194571_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_6518824058241194571\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_6518824058241194571\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n##### Question\n\n\nIs there a nice algorithm to identify what domain a function should be plotted over to produce an informative graph? [Wilkinson](https://www.cs.uic.edu/~wilkinson/Publications/plotfunc.pdf) has some suggestions. (Wilkinson is well known to the `R` community as the specifier of the grammar of graphics.) It is mentioned that \"finding an informative domain for a given function depends on at least three features: periodicity, asymptotics, and monotonicity.\"\n\n\nWhy would periodicity matter?\n\n::: {.cell hold='true' execution_count=42}\n\n::: {.cell-output .cell-output-display execution_count=43}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='8519221984698905431' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_8519221984698905431\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_8519221984698905431_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_8519221984698905431\"\n id=\"radio_8519221984698905431_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n An informative graph only needs to show one or two periods, as others can be inferred.\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_8519221984698905431_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_8519221984698905431\"\n id=\"radio_8519221984698905431_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n An informative graph need only show a part of the period, as the rest can be inferred.\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_8519221984698905431_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_8519221984698905431\"\n id=\"radio_8519221984698905431_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n An informative graph needs to show several periods, as that will allow proper computation for the \\(y\\) axis range.\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='8519221984698905431_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_8519221984698905431\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 1;\n var msgBox = document.getElementById('8519221984698905431_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_8519221984698905431\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_8519221984698905431\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nWhy should asymptotics matter?\n\n::: {.cell hold='true' execution_count=43}\n\n::: {.cell-output .cell-output-display execution_count=44}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='1006581434455490418' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_1006581434455490418\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_1006581434455490418_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_1006581434455490418\"\n id=\"radio_1006581434455490418_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n A horizontal asymptote must be plotted from \\(-\\infty\\) to \\(\\infty\\)\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_1006581434455490418_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_1006581434455490418\"\n id=\"radio_1006581434455490418_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n A slant asymptote must be plotted over a very wide domain so that it can be identified.\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_1006581434455490418_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_1006581434455490418\"\n id=\"radio_1006581434455490418_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n A vertical asymptote can distory the \\(y\\) range, so it is important to avoid too-large values\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='1006581434455490418_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_1006581434455490418\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 3;\n var msgBox = document.getElementById('1006581434455490418_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_1006581434455490418\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_1006581434455490418\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\nMonotonicity means increasing or decreasing. This is important for what reason?\n\n::: {.cell hold='true' execution_count=44}\n\n::: {.cell-output .cell-output-display execution_count=45}\n```{=html}\n<form class=\"mx-2 my-3 mw-100\" name='WeaveQuestion' data-id='6417558088215178209' data-controltype=''>\n <div class='form-group '>\n <div class='controls'>\n <div class=\"form\" id=\"controls_6417558088215178209\">\n <div style=\"padding-top: 5px\">\n <div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6417558088215178209_1\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6417558088215178209\"\n id=\"radio_6417558088215178209_1\" value=\"1\">\n </input>\n <span class=\"label-body px-1\">\n For monotonic regions, the function will have a vertical asymptote, so the region should not be plotted\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6417558088215178209_2\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6417558088215178209\"\n id=\"radio_6417558088215178209_2\" value=\"2\">\n </input>\n <span class=\"label-body px-1\">\n For monotonic regions, a large slope or very concave function might require more care to plot\n </span>\n </label>\n</div>\n<div class=\"form-check\">\n <label class=\"form-check-label\" for=\"radio_6417558088215178209_3\">\n <input class=\"form-check-input\" type=\"radio\" name=\"radio_6417558088215178209\"\n id=\"radio_6417558088215178209_3\" value=\"3\">\n </input>\n <span class=\"label-body px-1\">\n For monotonic regions, a function is basically a straight line\n </span>\n </label>\n</div>\n\n \n </div>\n </div>\n <div id='6417558088215178209_message' style=\"padding-bottom: 15px\"></div>\n </div>\n </div>\n</form>\n\n<script text='text/javascript'>\ndocument.querySelectorAll('input[name=\"radio_6417558088215178209\"]').forEach(function(rb) {\nrb.addEventListener(\"change\", function() {\n var correct = rb.value == 2;\n var msgBox = document.getElementById('6417558088215178209_message');\n if(correct) {\n msgBox.innerHTML = \"<div class='pluto-output admonition note alert alert-success'><span> 👍 Correct </span></div>\";\n var explanation = document.getElementById(\"explanation_6417558088215178209\")\n if (explanation != null) {\n explanation.style.display = \"none\";\n }\n } else {\n msgBox.innerHTML = \"<div class='pluto-output admonition alert alert-danger'><span>👎 Incorrect </span></div>\";\n var explanation = document.getElementById(\"explanation_6417558088215178209\")\n if (explanation != null) {\n explanation.style.display = \"block\";\n }\n }\n\n})});\n\n</script>\n```\n:::\n:::\n\n\n",
|
||
"supporting": [
|
||
"curve_sketching_files"
|
||
],
|
||
"filters": [],
|
||
"includes": {
|
||
"include-in-header": [
|
||
"<script src=\"https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.6/require.min.js\" integrity=\"sha512-c3Nl8+7g4LMSTdrm621y7kf9v3SDPnhxLNhcjFJbKECVnmZHTdo+IRO05sNLTH/D3vA6u1X32ehoLC7WFVdheg==\" crossorigin=\"anonymous\"></script>\n<script src=\"https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js\" integrity=\"sha512-bLT0Qm9VnAYZDflyKcBaQ2gg0hSYNQrJ8RilYldYQ1FxQYoCLtUjuuRuZo+fjqhx/qtq/1itJ0C2ejDxltZVFg==\" crossorigin=\"anonymous\"></script>\n<script type=\"application/javascript\">define('jquery', [],function() {return window.jQuery;})</script>\n"
|
||
]
|
||
}
|
||
}
|
||
} |