diff --git a/HW4/README.md b/HW4/README.md new file mode 100644 index 0000000..7f04a9a --- /dev/null +++ b/HW4/README.md @@ -0,0 +1,37 @@ +# Homework #3 +## due 3/1/17 by 11:59pm + + +1. Use your repository 'roots_and_optimization'. Document all the HW4 work under the +heading `# Homework #4` in your `README.md` file + + a. Create a function called 'collar_potential_energy' that computes the total + potential energy of a collar connected to a spring and sliding on a rod. As shown in + the figure given a position, xc, and angle, theta: + +  + + The spring is unstretched when x_C=0.5 m. The potential energy due to gravity is: + + PE_g=m x_C\*g\*sin(theta) + + where m=0.5 kg, and g is the acceleration due to gravity, + + and the potential energy due to the spring is: + + PE_s=1/2\*K \*(DL)^2 + + where DL = 0.5 - sqrt(0.5^2+(0.5-x_C)^2) and K=30 N/m. + + b. Use the `goldmin.m` function to solve for the minimum potential energy at xc when + theta=0. *create an anonymous function with `@(x) collar_potential_energy(x,theta)` in + the input for goldmin. Be sure to include the script that solves for xc* + + c. Create a for-loop that solves for the minimum potential energy position, xc, at a + given angle, theta, for theta = 0..90 degrees. + + d. Include a plot of xc vs theta. `plot(theta,xc)` with + + `` + +3. Commit your changes to your repository. Sync your local repository with github. diff --git a/HW4/collar_mass.png b/HW4/collar_mass.png new file mode 100644 index 0000000..f9b2836 Binary files /dev/null and b/HW4/collar_mass.png differ diff --git a/HW4/collar_mass.svg b/HW4/collar_mass.svg new file mode 100644 index 0000000..cc18c3d --- /dev/null +++ b/HW4/collar_mass.svg @@ -0,0 +1,270 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!-- Created with Inkscape (http://www.inkscape.org/) --> + +<svg + xmlns:dc="http://purl.org/dc/elements/1.1/" + xmlns:cc="http://creativecommons.org/ns#" + xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" + xmlns:svg="http://www.w3.org/2000/svg" + xmlns="http://www.w3.org/2000/svg" + xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" + xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" + width="3in" + height="2in" + viewBox="0 0 270 180" + id="svg4226" + version="1.1" + inkscape:version="0.91 r13725" + sodipodi:docname="collar_mass.svg"> + <defs + id="defs4228"> + <marker + inkscape:stockid="Arrow2Mend" + orient="auto" + refY="0.0" + refX="0.0" + id="Arrow2Mend" + style="overflow:visible;" + inkscape:isstock="true"> + <path + id="path4186" + style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round;stroke:#000000;stroke-opacity:1;fill:#000000;fill-opacity:1" + d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z " + transform="scale(0.6) rotate(180) translate(0,0)" /> + </marker> + <marker + inkscape:stockid="Arrow1Mend" + orient="auto" + refY="0.0" + refX="0.0" + id="marker4761" + style="overflow:visible;" + inkscape:isstock="true"> + <path + id="path4763" + d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z " + style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;stroke-opacity:1;fill:#000000;fill-opacity:1" + transform="scale(0.4) rotate(180) translate(10,0)" /> + </marker> + <marker + inkscape:isstock="true" + style="overflow:visible;" + id="marker4709" + refX="0.0" + refY="0.0" + orient="auto" + inkscape:stockid="Arrow1Mend"> + <path + transform="scale(0.4) rotate(180) translate(10,0)" + style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;stroke-opacity:1;fill:#000000;fill-opacity:1" + d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z " + id="path4711" /> + </marker> + <marker + inkscape:isstock="true" + style="overflow:visible;" + id="marker4651" + refX="0.0" + refY="0.0" + orient="auto" + inkscape:stockid="Arrow1Mend"> + <path + transform="scale(0.4) rotate(180) translate(10,0)" + style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;stroke-opacity:1;fill:#000000;fill-opacity:1" + d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z " + id="path4653" /> + </marker> + <marker + inkscape:isstock="true" + style="overflow:visible;" + id="marker4599" + refX="0.0" + refY="0.0" + orient="auto" + inkscape:stockid="Arrow1Mend"> + <path + transform="scale(0.4) rotate(180) translate(10,0)" + style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;stroke-opacity:1;fill:#000000;fill-opacity:1" + d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z " + id="path4601" /> + </marker> + <marker + inkscape:stockid="Arrow2Mstart" + orient="auto" + refY="0.0" + refX="0.0" + id="Arrow2Mstart" + style="overflow:visible" + inkscape:isstock="true"> + <path + id="path4183" + style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round;stroke:#000000;stroke-opacity:1;fill:#000000;fill-opacity:1" + d="M 8.7185878,4.0337352 L -2.2072895,0.016013256 L 8.7185884,-4.0017078 C 6.9730900,-1.6296469 6.9831476,1.6157441 8.7185878,4.0337352 z " + transform="scale(0.6) translate(0,0)" /> + </marker> + <marker + inkscape:stockid="Arrow1Mend" + orient="auto" + refY="0.0" + refX="0.0" + id="Arrow1Mend" + style="overflow:visible;" + inkscape:isstock="true" + inkscape:collect="always"> + <path + id="path4168" + d="M 0.0,0.0 L 5.0,-5.0 L -12.5,0.0 L 5.0,5.0 L 0.0,0.0 z " + style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;stroke-opacity:1;fill:#000000;fill-opacity:1" + transform="scale(0.4) rotate(180) translate(10,0)" /> + </marker> + </defs> + <sodipodi:namedview + id="base" + pagecolor="#ffffff" + bordercolor="#666666" + borderopacity="1.0" + inkscape:pageopacity="0.0" + inkscape:pageshadow="2" + inkscape:zoom="3.3611111" + inkscape:cx="120.9995" + inkscape:cy="105.14521" + inkscape:document-units="px" + inkscape:current-layer="layer1" + showgrid="false" + units="in" + inkscape:window-width="2560" + inkscape:window-height="1379" + inkscape:window-x="1920" + inkscape:window-y="27" + inkscape:window-maximized="1" /> + <metadata + id="metadata4231"> + <rdf:RDF> + <cc:Work + rdf:about=""> + <dc:format>image/svg+xml</dc:format> + <dc:type + rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> + <dc:title></dc:title> + </cc:Work> + </rdf:RDF> + </metadata> + <g + inkscape:label="Layer 1" + inkscape:groupmode="layer" + id="layer1" + transform="translate(0,-872.36215)"> + <rect + style="opacity:1;fill:#878787;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect4151" + width="252.7438" + height="10.413223" + x="-489.34341" + y="916.44434" + rx="0" + ry="0" + transform="matrix(0.86525768,-0.50132739,0.50132739,0.86525768,0,0)" /> + <rect + style="opacity:1;fill:#878787;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect4149" + width="36.743797" + height="20.975229" + x="334.47769" + y="-935.25085" + ry="1.9338843" + rx="3.8677685" + transform="matrix(-0.87030691,0.49250978,-0.49250978,-0.87030691,0,0)" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow1Mend)" + d="M 38.380165,1042.6927 131.20661,989.13901" + id="path4153" + inkscape:connector-curvature="0" + sodipodi:nodetypes="cc" /> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="100.26447" + y="1023.6514" + id="text4501" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan4503" + x="100.26447" + y="1023.6514" + style="font-size:17.5px">x<tspan + style="font-size:64.99999762%;baseline-shift:sub" + id="tspan4507">c</tspan></tspan></text> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 87.192722,890.41573 5.789029,6.4627 c 0,0 11.268949,1.73825 11.459939,6.05433 0.15694,3.5463 -8.939835,5.78682 -8.939835,5.78682 0,0 17.602265,1.25928 18.153375,7.82562 0.29688,3.53732 -8.93984,5.78682 -8.93984,5.78682 0,0 17.60226,1.25927 18.15336,7.82561 0.2969,3.53734 -8.93983,5.78682 -8.93983,5.78682 0,0 17.60225,1.25928 18.15337,7.82562 0.29689,3.53733 -8.93984,5.78682 -8.93984,5.78682 0,0 11.36441,-2.94841 13.5466,1.0194 1.10746,2.01365 -3.24487,6.08294 -3.24487,6.08294 l 8.94372,13.2138" + id="path4509" + inkscape:connector-curvature="0" + sodipodi:nodetypes="ccscscscscscc" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="M 77.652893,895.71752 100.41322,881.88281" + id="path4511" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 78.099174,894.97372 1.190082,-10.26446" + id="path4513" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 84.396695,891.64314 1.190082,-10.26445" + id="path4513-6" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="M 91.586777,887.19685 92.776859,876.9324" + id="path4513-2" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 99.586777,883.19685 1.190083,-10.26444" + id="path4513-2-9" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 129.12397,996.87455 c 7.50466,13.72735 7.9919,31.61045 -0.29752,45.83475" + id="path4551" + inkscape:connector-curvature="0" + sodipodi:nodetypes="cc" /> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="141.0248" + y="1029.7505" + id="text4553" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan4555" + x="141.0248" + y="1029.7505" + style="font-size:17.5px">𝝷</tspan></text> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 38.082645,1042.6927 190.710745,0" + id="path4557" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#Arrow2Mstart);marker-end:url(#Arrow2Mend)" + d="m 99.966942,883.51918 51.619838,80.62809" + id="path4559" + inkscape:connector-curvature="0" /> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:17.5px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="136.41322" + y="916.69275" + id="text4881" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan4883" + x="136.41322" + y="916.69275">L<tspan + style="font-size:65%;baseline-shift:sub" + id="tspan4885">0</tspan>=0.5m</tspan></text> + </g> +</svg> diff --git a/README.md b/README.md index 73ca14a..c7011f5 100644 --- a/README.md +++ b/README.md @@ -79,10 +79,10 @@ general, I will not post homework solutions. | |2/16|8|Linear Algebra| |6|2/21|9|Linear systems: Gauss elimination| | |2/23|10|Linear Systems: LU factorization| -|7|2/28||Midterm Review| -| |3/2||Midterm| -|8|3/7|11|Linear Systems: Error analysis| -| |3/9|13|Eigenvalues| +|7|2/28|11|Linear Systems: Error analysis| +| |3/2|12|Eigenvalues| +|8|3/7|1-10 |Midterm Review| +| |3/9|1-10|Midterm| |9|3/14| N/A |Spring Break!| | |3/16| N/A |Spring Break!| |10|3/21|12|Linear Systems: Iterative methods| diff --git a/lecture_09/mass_springs.png b/lecture_09/mass_springs.png new file mode 100644 index 0000000..d0dc65c Binary files /dev/null and b/lecture_09/mass_springs.png differ diff --git a/lecture_09/octave-workspace b/lecture_09/octave-workspace new file mode 100644 index 0000000..f7e8b2b Binary files /dev/null and b/lecture_09/octave-workspace differ diff --git a/lecture_10/.ipynb_checkpoints/lecture_10-checkpoint.ipynb b/lecture_10/.ipynb_checkpoints/lecture_10-checkpoint.ipynb new file mode 100644 index 0000000..2fd6442 --- /dev/null +++ b/lecture_10/.ipynb_checkpoints/lecture_10-checkpoint.ipynb @@ -0,0 +1,6 @@ +{ + "cells": [], + "metadata": {}, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_10/GaussNaive.m b/lecture_10/GaussNaive.m new file mode 100644 index 0000000..d8c60d3 --- /dev/null +++ b/lecture_10/GaussNaive.m @@ -0,0 +1,25 @@ +function [x,Aug] = GaussNaive(A,y) +% GaussNaive: naive Gauss elimination +% x = GaussNaive(A,b): Gauss elimination without pivoting. +% input: +% A = coefficient matrix +% y = right hand side vector +% output: +% x = solution vector +[m,n] = size(A); +if m~=n, error('Matrix A must be square'); end +nb = n+1; +Aug = [A y]; +% forward elimination +for k = 1:n-1 + for i = k+1:n + factor = Aug(i,k)/Aug(k,k); + Aug(i,k:nb) = Aug(i,k:nb)-factor*Aug(k,k:nb); + end +end +% back substitution +x = zeros(n,1); +x(n) = Aug(n,nb)/Aug(n,n); +for i = n-1:-1:1 + x(i) = (Aug(i,nb)-Aug(i,i+1:n)*x(i+1:n))/Aug(i,i); +end diff --git a/lecture_10/GaussPivot.m b/lecture_10/GaussPivot.m new file mode 100644 index 0000000..20df9e8 --- /dev/null +++ b/lecture_10/GaussPivot.m @@ -0,0 +1,33 @@ +function [x,Aug,npivots] = GaussPivot(A,b) +% GaussPivot: Gauss elimination pivoting +% x = GaussPivot(A,b): Gauss elimination with pivoting. +% input: +% A = coefficient matrix +% b = right hand side vector +% output: +% x = solution vector +[m,n]=size(A); +if m~=n, error('Matrix A must be square'); end +nb=n+1; +Aug=[A b]; +npivots=0; % initially no pivots used +% forward elimination +for k = 1:n-1 + % partial pivoting + [big,i]=max(abs(Aug(k:n,k))); + ipr=i+k-1; + if ipr~=k + npivots=npivots+1; % if the max is not the current index ipr, pivot count + Aug([k,ipr],:)=Aug([ipr,k],:); + end + for i = k+1:n + factor=Aug(i,k)/Aug(k,k); + Aug(i,k:nb)=Aug(i,k:nb)-factor*Aug(k,k:nb); + end +end +% back substitution +x=zeros(n,1); +x(n)=Aug(n,nb)/Aug(n,n); +for i = n-1:-1:1 + x(i)=(Aug(i,nb)-Aug(i,i+1:n)*x(i+1:n))/Aug(i,i); +end diff --git a/lecture_10/Tridiag.m b/lecture_10/Tridiag.m new file mode 100644 index 0000000..ac4ec9b --- /dev/null +++ b/lecture_10/Tridiag.m @@ -0,0 +1,22 @@ +function x = Tridiag(e,f,g,r) +% Tridiag: Tridiagonal equation solver banded system +% x = Tridiag(e,f,g,r): Tridiagonal system solver. +% input: +% e = subdiagonal vector +% f = diagonal vector +% g = superdiagonal vector +% r = right hand side vector +% output: +% x = solution vector +n=length(f); +% forward elimination +for k = 2:n + factor = e(k)/f(k-1); + f(k) = f(k) - factor*g(k-1); + r(k) = r(k) - factor*r(k-1); +end +% back substitution +x(n) = r(n)/f(n); +for k = n-1:-1:1 + x(k) = (r(k)-g(k)*x(k+1))/f(k); +end diff --git a/lecture_10/lecture_10.aux b/lecture_10/lecture_10.aux new file mode 100644 index 0000000..d8d4c62 --- /dev/null +++ b/lecture_10/lecture_10.aux @@ -0,0 +1,40 @@ +\relax +\providecommand\hyper@newdestlabel[2]{} +\providecommand\HyperFirstAtBeginDocument{\AtBeginDocument} +\HyperFirstAtBeginDocument{\ifx\hyper@anchor\@undefined +\global\let\oldcontentsline\contentsline +\gdef\contentsline#1#2#3#4{\oldcontentsline{#1}{#2}{#3}} +\global\let\oldnewlabel\newlabel +\gdef\newlabel#1#2{\newlabelxx{#1}#2} +\gdef\newlabelxx#1#2#3#4#5#6{\oldnewlabel{#1}{{#2}{#3}}} +\AtEndDocument{\ifx\hyper@anchor\@undefined +\let\contentsline\oldcontentsline +\let\newlabel\oldnewlabel +\fi} +\fi} +\global\let\hyper@last\relax +\gdef\HyperFirstAtBeginDocument#1{#1} +\providecommand\HyField@AuxAddToFields[1]{} +\providecommand\HyField@AuxAddToCoFields[2]{} +\providecommand \oddpage@label [2]{} +\@writefile{toc}{\contentsline {section}{\numberline {1}Gauss Elimination}{1}{section.1}} +\newlabel{gauss-elimination}{{1}{1}{Gauss Elimination}{section.1}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.0.1}Solving sets of equations with matrix operations}{1}{subsubsection.1.0.1}} +\newlabel{solving-sets-of-equations-with-matrix-operations}{{1.0.1}{1}{Solving sets of equations with matrix operations}{subsubsection.1.0.1}{}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.1}Gauss elimination}{4}{subsection.1.1}} +\newlabel{gauss-elimination}{{1.1}{4}{Gauss elimination}{subsection.1.1}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.1.1}Solving sets of equations systematically}{4}{subsubsection.1.1.1}} +\newlabel{solving-sets-of-equations-systematically}{{1.1.1}{4}{Solving sets of equations systematically}{subsubsection.1.1.1}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {1}{\ignorespaces Springs-masses\relax }}{4}{figure.caption.1}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.2}Automate Gauss Elimination}{6}{subsection.1.2}} +\newlabel{automate-gauss-elimination}{{1.2}{6}{Automate Gauss Elimination}{subsection.1.2}{}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.3}Problem (Diagonal element is zero)}{7}{subsection.1.3}} +\newlabel{problem-diagonal-element-is-zero}{{1.3}{7}{Problem (Diagonal element is zero)}{subsection.1.3}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.3.1}Spring-Mass System again}{9}{subsubsection.1.3.1}} +\newlabel{spring-mass-system-again}{{1.3.1}{9}{Spring-Mass System again}{subsubsection.1.3.1}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {2}{\ignorespaces Springs-masses\relax }}{9}{figure.caption.2}} +\gdef \LT@i {\LT@entry + {2}{61.69104pt}\LT@entry + {1}{261.39424pt}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.4}Tridiagonal matrix}{10}{subsection.1.4}} +\newlabel{tridiagonal-matrix}{{1.4}{10}{Tridiagonal matrix}{subsection.1.4}{}} diff --git a/lecture_10/lecture_10.bbl b/lecture_10/lecture_10.bbl new file mode 100644 index 0000000..e69de29 diff --git a/lecture_10/lecture_10.blg b/lecture_10/lecture_10.blg new file mode 100644 index 0000000..36b5e7a --- /dev/null +++ b/lecture_10/lecture_10.blg @@ -0,0 +1,48 @@ +This is BibTeX, Version 0.99d (TeX Live 2015/Debian) +Capacity: max_strings=35307, hash_size=35307, hash_prime=30011 +The top-level auxiliary file: lecture_10.aux +I found no \citation commands---while reading file lecture_10.aux +I found no \bibdata command---while reading file lecture_10.aux +I found no \bibstyle command---while reading file lecture_10.aux +You've used 0 entries, + 0 wiz_defined-function locations, + 83 strings with 494 characters, +and the built_in function-call counts, 0 in all, are: += -- 0 +> -- 0 +< -- 0 ++ -- 0 +- -- 0 +* -- 0 +:= -- 0 +add.period$ -- 0 +call.type$ -- 0 +change.case$ -- 0 +chr.to.int$ -- 0 +cite$ -- 0 +duplicate$ -- 0 +empty$ -- 0 +format.name$ -- 0 +if$ -- 0 +int.to.chr$ -- 0 +int.to.str$ -- 0 +missing$ -- 0 +newline$ -- 0 +num.names$ -- 0 +pop$ -- 0 +preamble$ -- 0 +purify$ -- 0 +quote$ -- 0 +skip$ -- 0 +stack$ -- 0 +substring$ -- 0 +swap$ -- 0 +text.length$ -- 0 +text.prefix$ -- 0 +top$ -- 0 +type$ -- 0 +warning$ -- 0 +while$ -- 0 +width$ -- 0 +write$ -- 0 +(There were 3 error messages) diff --git a/lecture_10/lecture_10.ipynb b/lecture_10/lecture_10.ipynb new file mode 100644 index 0000000..46d4f00 --- /dev/null +++ b/lecture_10/lecture_10.ipynb @@ -0,0 +1,1685 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Gauss Elimination\n", + "### Solving sets of equations with matrix operations\n", + "\n", + "The number of dimensions of a matrix indicate the degrees of freedom of the system you are solving. \n", + "\n", + "If you have a set of known output, $y_{1},~y_{2},~...y_{N}$ and a set of equations that\n", + "relate unknown inputs, $x_{1},~x_{2},~...x_{N}$, then these can be written in a vector\n", + "matrix format as:\n", + "\n", + "$y=Ax$\n", + "\n", + "Consider a problem with 2 DOF:\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "1 & 3 \\\\\n", + "2 & 1 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "The solution for $x_{1}$ and $x_{2}$ is the intersection of two lines:" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"37.3,384.0 534.9,384.0 534.9,16.8 37.3,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,384.0 L49.8,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">-4</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,310.5 L49.8,310.5 M535.0,310.5 L522.5,310.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,316.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">-2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,237.1 L49.8,237.1 M535.0,237.1 L522.5,237.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,243.1)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,163.6 L49.8,163.6 M535.0,163.6 L522.5,163.6 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,169.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,90.2 L49.8,90.2 M535.0,90.2 L522.5,90.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,96.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">4</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,16.7 L49.8,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(29.0,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">6</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,384.0 L37.3,371.5 M37.3,16.7 L37.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(37.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">-6</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M108.4,384.0 L108.4,371.5 M108.4,16.7 L108.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(108.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">-4</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M179.5,384.0 L179.5,371.5 M179.5,16.7 L179.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(179.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">-2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M250.6,384.0 L250.6,371.5 M250.6,16.7 L250.6,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(250.6,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M321.7,384.0 L321.7,371.5 M321.7,16.7 L321.7,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(321.7,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M392.8,384.0 L392.8,371.5 M392.8,16.7 L392.8,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(392.8,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">4</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M463.9,384.0 L463.9,371.5 M463.9,16.7 L463.9,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(463.9,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">6</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">8</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M37.3,16.7 L37.3,384.0 L535.0,384.0 L535.0,16.7 L37.3,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>gnuplot_plot_1a</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M499.5,310.5 L392.8,273.8 L286.2,237.1 L179.5,200.3 L72.9,163.6 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>gnuplot_plot_2a</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M179.5,53.4 L215.1,126.9 L250.6,200.3 L286.2,273.8 L321.7,347.3 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 128, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "x21=[-2:2];\n", + "x11=1-3*x21;\n", + "x21=[-2:2];\n", + "x22=1-2*x21;\n", + "plot(x11,x21,x21,x22)" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 0.40000\n", + " 0.20000\n", + "\n" + ] + } + ], + "source": [ + "A=[1,3;2,1]; y=[1;1];\n", + "A\\y % matlab's Ax=y solution for x" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "For a $3\\times3$ matrix, the solution is the intersection of the 3 planes.\n", + "\n", + "$10x_{1}+2x_{2}+x_{3}=1$\n", + "\n", + "$2x_{1}+x_{2}+x_{3}=1$\n", + "\n", + "$x_{1}+2x_{2}+10x_{3}=1$\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "10 & 2 & 1\\\\\n", + "2 & 1 & 1 \\\\\n", + "1 & 2 & 10\\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\\\\n", + "x_{3} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1 \\\\\n", + "1\\end{array}\\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L162.1,189.9 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L162.1,189.9 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L111.7,187.8 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M162.1,189.9 L162.1,49.4 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L448.3,73.8 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,187.8 L162.1,49.4 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,73.8 L162.1,49.4 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,328.2 L162.1,189.9 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L108.5,337.0 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M162.1,189.9 L165.3,181.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(106.4,355.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">-2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M147.5,331.2 L197.9,193.0 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M147.5,331.2 L144.3,340.0 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M197.9,193.0 L201.1,184.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(142.1,358.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">-1.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M183.2,334.3 L233.7,196.0 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M183.2,334.3 L180.0,343.1 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M233.7,196.0 L236.9,187.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(177.9,361.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">-1</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M219.0,337.3 L269.5,199.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M219.0,337.3 L215.8,346.1 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M269.5,199.1 L272.7,190.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(213.7,364.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">-0.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M254.8,340.4 L305.2,202.0 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M254.8,340.4 L251.6,349.2 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M305.2,202.0 L308.4,193.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(249.5,367.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M290.5,343.4 L341.0,205.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M290.5,343.4 L287.3,352.2 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M341.0,205.1 L344.2,196.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(285.2,370.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M326.3,346.5 L376.8,208.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M326.3,346.5 L323.1,355.3 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M376.8,208.1 L380.0,199.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(321.0,373.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">1</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M362.1,349.5 L412.5,211.2 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M362.1,349.5 L358.9,358.3 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M412.5,211.2 L415.7,202.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(356.8,376.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">1.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M397.9,352.6 L448.3,214.2 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M397.9,352.6 L394.7,361.4 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L451.5,205.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(392.5,379.9)\">\n", + "\t\t<text><tspan font-family=\"{}\">2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M397.9,352.6 L111.7,328.2 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M397.9,352.6 L410.3,353.6 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L99.3,327.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(418.4,361.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">-2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M404.2,335.3 L118.0,310.9 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M404.2,335.3 L416.6,336.3 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M118.0,310.9 L105.6,309.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(424.7,343.9)\">\n", + "\t\t<text><tspan font-family=\"{}\">-1.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M410.5,318.0 L124.3,293.6 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M410.5,318.0 L422.9,319.0 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M124.3,293.6 L111.9,292.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(431.1,326.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">-1</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M416.8,300.7 L130.6,276.3 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M416.8,300.7 L429.2,301.8 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M130.6,276.3 L118.2,275.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(437.4,309.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">-0.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M423.1,283.4 L136.9,259.0 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M423.1,283.4 L435.5,284.5 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M136.9,259.0 L124.5,257.9 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(443.7,292.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M429.4,266.1 L143.2,241.7 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M429.4,266.1 L441.8,267.2 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M143.2,241.7 L130.8,240.6 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(450.0,274.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M435.7,248.8 L149.5,224.4 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M435.7,248.8 L448.1,249.9 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M149.5,224.4 L137.1,223.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(456.3,257.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">1</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M442.0,231.5 L155.8,207.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.0,231.5 L454.4,232.6 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M155.8,207.1 L143.4,206.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(462.6,240.1)\">\n", + "\t\t<text><tspan font-family=\"{}\">1.5</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M448.3,214.2 L162.1,189.9 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L460.7,215.3 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M162.1,189.9 L149.7,188.9 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"start\" transform=\"translate(468.9,222.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,328.2 L162.1,189.9 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,189.9 L448.3,214.2 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L99.2,328.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,334.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">-30</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L460.8,214.2 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,304.8 L162.1,166.5 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,166.5 L448.3,190.9 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,304.8 L99.2,304.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,310.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">-20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,190.9 L460.8,190.9 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,281.4 L162.1,143.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,143.1 L448.3,167.5 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,281.4 L99.2,281.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,287.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">-10</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,167.5 L460.8,167.5 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,257.9 L162.1,119.7 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,119.7 L448.3,144.1 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,257.9 L99.2,257.9 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,263.9)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,144.1 L460.8,144.1 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,234.5 L162.1,96.3 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,96.3 L448.3,120.6 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,234.5 L99.2,234.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,240.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,120.6 L460.8,120.6 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,211.1 L162.1,72.8 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,72.8 L448.3,97.2 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,211.1 L99.2,211.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,217.1)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,97.2 L460.8,97.2 \" stroke=\"black\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M111.7,187.8 L162.1,49.4 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"gray\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path class=\"gridline\" d=\"M162.1,49.4 L448.3,73.8 \" stroke=\"gray\" stroke-dasharray=\"2,4\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,187.8 L99.2,187.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(81.1,193.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">30</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,73.8 L460.8,73.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(59.6,257.9) rotate(-90)\">\n", + "\t\t<text><tspan font-family=\"{}\">x3</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>gnuplot_plot_1a</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M162.1,79.9 L160.0,84.8 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M160.0,84.8 L157.9,89.8 L155.8,94.8 L153.7,99.8 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M153.7,99.8 L151.6,104.8 L149.5,109.8 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M149.5,109.8 L147.4,114.8 L145.3,119.7 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M145.3,119.7 L143.2,124.7 L141.1,129.7 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M141.1,129.7 L139.0,134.7 L136.9,139.7 L134.8,144.7 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M134.8,144.7 L132.7,149.6 L130.6,154.6 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M130.6,154.6 L128.5,159.6 L126.4,164.6 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M126.4,164.6 L124.3,169.6 L122.2,174.6 \" stroke=\"rgb(160, 0, 0)\"/>\t<path d=\"M122.2,174.6 L120.1,179.6 L118.0,184.5 L115.9,189.5 \" stroke=\"rgb(144, 0, 0)\"/>\t<path d=\"M115.9,189.5 L113.8,194.5 L111.7,199.5 \" stroke=\"rgb(128, 0, 0)\"/>\t<path d=\"M174.1,84.8 L172.0,89.8 L169.9,94.7 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M169.9,94.7 L167.8,99.7 L165.7,104.7 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M165.7,104.7 L163.6,109.7 L161.5,114.7 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M161.5,114.7 L159.4,119.7 L157.2,124.7 L155.1,129.6 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M155.1,129.6 L153.0,134.6 L150.9,139.6 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M150.9,139.6 L148.8,144.6 L146.7,149.6 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M146.7,149.6 L144.6,154.6 L142.5,159.5 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M142.5,159.5 L140.4,164.5 L138.3,169.5 L136.2,174.5 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M136.2,174.5 L134.1,179.5 L132.0,184.5 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M132.0,184.5 L129.9,189.5 L127.8,194.4 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M127.8,194.4 L125.7,199.4 L123.6,204.3 \" stroke=\"rgb(160, 0, 0)\"/>\t<path d=\"M186.0,89.7 L183.9,94.7 L181.8,99.7 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M181.8,99.7 L179.7,104.7 L177.6,109.6 L175.5,114.6 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M175.5,114.6 L173.4,119.6 L171.3,124.6 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M171.3,124.6 L169.2,129.6 L167.1,134.6 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M167.1,134.6 L165.0,139.5 L162.9,144.5 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M162.9,144.5 L160.8,149.5 L158.7,154.5 L156.6,159.5 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M156.6,159.5 L154.5,164.5 L152.4,169.5 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M152.4,169.5 L150.2,174.4 L148.1,179.4 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M148.1,179.4 L146.0,184.4 L143.9,189.4 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M143.9,189.4 L141.8,194.4 L139.7,199.4 L137.6,204.2 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M137.6,204.2 L135.5,209.2 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M197.9,94.6 L195.8,99.6 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M195.8,99.6 L193.7,104.6 L191.6,109.6 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M191.6,109.6 L189.5,114.6 L187.4,119.5 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M187.4,119.5 L185.3,124.5 L183.2,129.5 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M183.2,129.5 L181.1,134.5 L179.0,139.5 L176.9,144.5 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M176.9,144.5 L174.8,149.4 L172.7,154.4 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M172.7,154.4 L170.6,159.4 L168.5,164.4 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M168.5,164.4 L166.4,169.4 L164.3,174.4 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M164.3,174.4 L162.2,179.4 L160.1,184.3 L158.0,189.3 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M158.0,189.3 L155.9,194.3 L153.8,199.3 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M153.8,199.3 L151.7,204.2 L149.6,209.2 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M149.6,209.2 L147.5,214.2 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M209.9,99.5 L207.8,104.5 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M207.8,104.5 L205.7,109.5 L203.6,114.5 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M203.6,114.5 L201.4,119.5 L199.3,124.5 L197.2,129.4 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M197.2,129.4 L195.1,134.4 L193.0,139.4 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M193.0,139.4 L190.9,144.4 L188.8,149.4 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M188.8,149.4 L186.7,154.4 L184.6,159.4 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M184.6,159.4 L182.5,164.3 L180.4,169.3 L178.3,174.3 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M178.3,174.3 L176.2,179.3 L174.1,184.3 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M174.1,184.3 L172.0,189.3 L169.9,194.2 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M169.9,194.2 L167.8,199.2 L165.7,204.1 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M165.7,204.1 L163.6,209.1 L161.5,214.1 L159.4,219.1 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M221.8,104.5 L219.7,109.4 L217.6,114.4 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M217.6,114.4 L215.5,119.4 L213.4,124.4 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M213.4,124.4 L211.3,129.4 L209.2,134.4 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M209.2,134.4 L207.1,139.3 L205.0,144.3 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M205.0,144.3 L202.9,149.3 L200.8,154.3 L198.7,159.3 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M198.7,159.3 L196.6,164.3 L194.4,169.3 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M194.4,169.3 L192.3,174.2 L190.2,179.2 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M190.2,179.2 L188.1,184.2 L186.0,189.2 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M186.0,189.2 L183.9,194.2 L181.8,199.2 L179.7,204.1 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M179.7,204.1 L177.6,209.0 L175.5,214.0 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M175.5,214.0 L173.4,219.0 L171.3,224.0 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M233.7,109.4 L231.6,114.4 L229.5,119.3 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M229.5,119.3 L227.4,124.3 L225.3,129.3 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M225.3,129.3 L223.2,134.3 L221.1,139.3 L219.0,144.3 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M219.0,144.3 L216.9,149.3 L214.8,154.2 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M214.8,154.2 L212.7,159.2 L210.6,164.2 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M210.6,164.2 L208.5,169.2 L206.4,174.2 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M206.4,174.2 L204.3,179.2 L202.2,184.1 L200.1,189.1 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M200.1,189.1 L198.0,194.1 L195.9,199.1 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M195.9,199.1 L193.8,204.0 L191.7,209.0 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M191.7,209.0 L189.5,214.0 L187.4,218.9 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M187.4,218.9 L185.3,223.9 L183.2,228.9 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M245.6,114.3 L243.5,119.3 L241.4,124.3 L239.3,129.2 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M239.3,129.2 L237.2,134.2 L235.1,139.2 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M235.1,139.2 L233.0,144.2 L230.9,149.2 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M230.9,149.2 L228.8,154.2 L226.7,159.2 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M226.7,159.2 L224.6,164.1 L222.5,169.1 L220.4,174.1 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M220.4,174.1 L218.3,179.1 L216.2,184.1 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M216.2,184.1 L214.1,189.1 L212.0,194.1 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M212.0,194.1 L209.9,199.0 L207.8,203.9 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M207.8,203.9 L205.7,208.9 L203.6,213.9 L201.5,218.9 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M201.5,218.9 L199.4,223.9 L197.3,228.8 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M197.3,228.8 L195.2,233.8 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M257.6,119.2 L255.5,124.2 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M255.5,124.2 L253.4,129.2 L251.3,134.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M251.3,134.2 L249.2,139.2 L247.1,144.1 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M247.1,144.1 L245.0,149.1 L242.9,154.1 L240.7,159.1 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M240.7,159.1 L238.6,164.1 L236.5,169.1 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M236.5,169.1 L234.4,174.0 L232.3,179.0 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M232.3,179.0 L230.2,184.0 L228.1,189.0 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M228.1,189.0 L226.0,194.0 L223.9,199.0 L221.8,203.9 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M221.8,203.9 L219.7,208.8 L217.6,213.8 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M217.6,213.8 L215.5,218.8 L213.4,223.8 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M213.4,223.8 L211.3,228.8 L209.2,233.8 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M209.2,233.8 L207.1,238.7 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M269.5,124.1 L267.4,129.1 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M267.4,129.1 L265.3,134.1 L263.2,139.1 L261.1,144.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M261.1,144.1 L259.0,149.1 L256.9,154.0 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M256.9,154.0 L254.8,159.0 L252.7,164.0 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M252.7,164.0 L250.6,169.0 L248.5,174.0 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M248.5,174.0 L246.4,179.0 L244.3,184.0 L242.2,188.9 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M242.2,188.9 L240.1,193.9 L238.0,198.9 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M238.0,198.9 L235.9,203.8 L233.7,208.8 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M233.7,208.8 L231.6,213.8 L229.5,218.7 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M229.5,218.7 L227.4,223.7 L225.3,228.7 L223.2,233.7 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M223.2,233.7 L221.1,238.7 L219.0,243.7 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M281.3,129.1 L279.3,134.0 L277.2,139.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M277.2,139.0 L275.1,144.0 L273.0,149.0 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M273.0,149.0 L270.9,154.0 L268.8,159.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M268.8,159.0 L266.7,163.9 L264.6,168.9 L262.5,173.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M262.5,173.9 L260.4,178.9 L258.3,183.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M258.3,183.9 L256.2,188.9 L254.1,193.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M254.1,193.9 L252.0,198.8 L249.9,203.7 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M249.9,203.7 L247.8,208.7 L245.7,213.7 L243.6,218.7 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M243.6,218.7 L241.5,223.7 L239.4,228.6 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M239.4,228.6 L237.3,233.6 L235.2,238.6 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M235.2,238.6 L233.1,243.6 L231.0,248.6 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M293.3,134.0 L291.2,139.0 L289.1,143.9 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M289.1,143.9 L287.0,148.9 L284.8,153.9 L282.7,158.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M282.7,158.9 L280.6,163.9 L278.6,168.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M278.6,168.9 L276.5,173.8 L274.4,178.8 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M274.4,178.8 L272.3,183.8 L270.2,188.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M270.2,188.8 L268.1,193.8 L266.0,198.8 L263.9,203.7 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M263.9,203.7 L261.8,208.6 L259.7,213.6 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M259.7,213.6 L257.6,218.6 L255.5,223.6 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M255.5,223.6 L253.4,228.6 L251.3,233.6 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M251.3,233.6 L249.2,238.6 L247.1,243.5 L245.0,248.5 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M245.0,248.5 L242.9,253.5 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M305.2,138.9 L303.1,143.9 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M303.1,143.9 L301.0,148.9 L298.9,153.8 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M298.9,153.8 L296.8,158.8 L294.7,163.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M294.7,163.8 L292.6,168.8 L290.5,173.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M290.5,173.8 L288.4,178.8 L286.3,183.8 L284.2,188.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M284.2,188.7 L282.1,193.7 L280.0,198.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M280.0,198.7 L277.9,203.6 L275.8,208.6 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M275.8,208.6 L273.7,213.6 L271.6,218.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M271.6,218.5 L269.5,223.5 L267.4,228.5 L265.3,233.5 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M265.3,233.5 L263.2,238.5 L261.1,243.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M261.1,243.5 L259.0,248.5 L256.9,253.4 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M256.9,253.4 L254.8,258.4 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M317.1,143.8 L315.0,148.8 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M315.0,148.8 L312.9,153.8 L310.8,158.8 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M310.8,158.8 L308.7,163.7 L306.6,168.7 L304.5,173.7 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M304.5,173.7 L302.4,178.7 L300.3,183.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M300.3,183.7 L298.2,188.7 L296.1,193.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M296.1,193.7 L294.0,198.6 L291.9,203.5 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M291.9,203.5 L289.8,208.5 L287.7,213.5 L285.6,218.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M285.6,218.5 L283.5,223.5 L281.4,228.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M281.4,228.5 L279.4,233.4 L277.3,238.4 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M277.3,238.4 L275.2,243.4 L273.0,248.4 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M273.0,248.4 L270.9,253.4 L268.8,258.4 L266.7,263.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M329.0,148.7 L326.9,153.7 L324.8,158.7 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M324.8,158.7 L322.7,163.7 L320.6,168.7 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M320.6,168.7 L318.5,173.7 L316.4,178.6 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M316.4,178.6 L314.3,183.6 L312.2,188.6 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M312.2,188.6 L310.1,193.6 L308.0,198.6 L305.9,203.5 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M305.9,203.5 L303.8,208.4 L301.7,213.4 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M301.7,213.4 L299.6,218.4 L297.5,223.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M297.5,223.4 L295.4,228.4 L293.3,233.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M293.3,233.4 L291.2,238.4 L289.1,243.3 L287.0,248.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M287.0,248.3 L284.9,253.3 L282.8,258.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M282.8,258.3 L280.7,263.3 L278.7,268.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M341.0,153.6 L338.9,158.6 L336.8,163.6 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M336.8,163.6 L334.7,168.6 L332.6,173.6 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M332.6,173.6 L330.5,178.6 L328.4,183.6 L326.3,188.5 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M326.3,188.5 L324.1,193.5 L322.0,198.5 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M322.0,198.5 L319.9,203.4 L317.8,208.4 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M317.8,208.4 L315.7,213.4 L313.6,218.4 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M313.6,218.4 L311.5,223.3 L309.4,228.3 L307.3,233.3 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M307.3,233.3 L305.2,238.3 L303.1,243.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M303.1,243.3 L301.0,248.3 L298.9,253.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M298.9,253.2 L296.8,258.2 L294.7,263.2 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M294.7,263.2 L292.6,268.2 L290.5,273.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M352.9,158.6 L350.8,163.6 L348.7,168.5 L346.6,173.5 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M346.6,173.5 L344.5,178.5 L342.4,183.5 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M342.4,183.5 L340.3,188.5 L338.2,193.5 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M338.2,193.5 L336.1,198.4 L334.0,203.3 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M334.0,203.3 L331.9,208.3 L329.8,213.3 L327.7,218.3 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M327.7,218.3 L325.6,223.3 L323.5,228.3 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M323.5,228.3 L321.4,233.2 L319.3,238.2 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M319.3,238.2 L317.1,243.2 L315.0,248.2 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M315.0,248.2 L312.9,253.2 L310.8,258.2 L308.7,263.1 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M308.7,263.1 L306.6,268.1 L304.5,273.1 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M304.5,273.1 L302.4,278.1 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M364.8,163.5 L362.7,168.5 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M362.7,168.5 L360.6,173.5 L358.5,178.4 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M358.5,178.4 L356.4,183.4 L354.3,188.4 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M354.3,188.4 L352.2,193.4 L350.1,198.4 L348.0,203.3 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M348.0,203.3 L345.9,208.3 L343.8,213.2 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M343.8,213.2 L341.7,218.2 L339.6,223.2 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M339.6,223.2 L337.5,228.2 L335.4,233.2 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M335.4,233.2 L333.3,238.2 L331.2,243.1 L329.1,248.1 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M329.1,248.1 L327.0,253.1 L324.9,258.1 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M324.9,258.1 L322.8,263.1 L320.7,268.1 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M320.7,268.1 L318.6,273.1 L316.5,278.0 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M316.5,278.0 L314.4,283.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M376.8,168.4 L374.7,173.4 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M374.7,173.4 L372.6,178.4 L370.5,183.4 L368.3,188.3 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M368.3,188.3 L366.2,193.3 L364.1,198.3 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M364.1,198.3 L362.0,203.2 L359.9,208.2 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M359.9,208.2 L357.8,213.2 L355.7,218.2 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M355.7,218.2 L353.6,223.1 L351.5,228.1 L349.4,233.1 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M349.4,233.1 L347.3,238.1 L345.2,243.1 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M345.2,243.1 L343.1,248.1 L341.0,253.0 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M341.0,253.0 L338.9,258.0 L336.8,263.0 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M336.8,263.0 L334.7,268.0 L332.6,273.0 L330.5,278.0 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M330.5,278.0 L328.4,283.0 L326.3,287.9 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M388.7,173.3 L386.6,178.3 L384.5,183.3 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M384.5,183.3 L382.4,188.3 L380.3,193.3 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M380.3,193.3 L378.2,198.3 L376.1,203.1 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M376.1,203.1 L374.0,208.1 L371.9,213.1 L369.8,218.1 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M369.8,218.1 L367.7,223.1 L365.6,228.1 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M365.6,228.1 L363.4,233.0 L361.3,238.0 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M361.3,238.0 L359.2,243.0 L357.1,248.0 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M357.1,248.0 L355.0,253.0 L352.9,258.0 L350.8,263.0 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M350.8,263.0 L348.7,267.9 L346.6,272.9 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M346.6,272.9 L344.5,277.9 L342.4,282.9 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M342.4,282.9 L340.3,287.9 L338.2,292.9 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M400.6,178.2 L398.5,183.2 L396.4,188.2 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M396.4,188.2 L394.3,193.2 L392.2,198.2 L390.1,203.1 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M390.1,203.1 L388.0,208.1 L385.9,213.0 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M385.9,213.0 L383.8,218.0 L381.7,223.0 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M381.7,223.0 L379.6,228.0 L377.5,233.0 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M377.5,233.0 L375.4,238.0 L373.3,242.9 L371.2,247.9 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M371.2,247.9 L369.1,252.9 L367.0,257.9 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M367.0,257.9 L364.9,262.9 L362.8,267.9 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M362.8,267.9 L360.7,272.9 L358.6,277.8 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M358.6,277.8 L356.4,282.8 L354.3,287.8 L352.2,292.8 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M352.2,292.8 L350.1,297.8 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M412.5,183.2 L410.4,188.2 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M410.4,188.2 L408.3,193.1 L406.2,198.1 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M406.2,198.1 L404.1,203.0 L402.0,208.0 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M402.0,208.0 L399.9,213.0 L397.8,218.0 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M397.8,218.0 L395.7,222.9 L393.6,227.9 L391.5,232.9 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M391.5,232.9 L389.4,237.9 L387.3,242.9 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M387.3,242.9 L385.2,247.9 L383.1,252.9 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M383.1,252.9 L381.0,257.8 L378.9,262.8 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M378.9,262.8 L376.8,267.8 L374.7,272.8 L372.6,277.8 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M372.6,277.8 L370.5,282.8 L368.4,287.7 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M368.4,287.7 L366.3,292.7 L364.2,297.7 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M364.2,297.7 L362.1,302.7 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M424.5,188.1 L422.4,193.1 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M422.4,193.1 L420.3,198.1 L418.2,202.9 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M418.2,202.9 L416.1,207.9 L414.0,212.9 L411.9,217.9 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M411.9,217.9 L409.8,222.9 L407.6,227.9 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M407.6,227.9 L405.5,232.8 L403.4,237.8 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M403.4,237.8 L401.3,242.8 L399.2,247.8 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M399.2,247.8 L397.1,252.8 L395.0,257.8 L392.9,262.8 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M392.9,262.8 L390.8,267.7 L388.7,272.7 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M388.7,272.7 L386.6,277.7 L384.5,282.7 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M384.5,282.7 L382.4,287.7 L380.3,292.7 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M380.3,292.7 L378.2,297.6 L376.1,302.6 L374.0,307.6 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M436.4,193.0 L434.3,198.0 L432.2,202.9 \" stroke=\"rgb( 0, 0, 160)\"/>\t<path d=\"M432.2,202.9 L430.1,207.9 L428.0,212.8 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M428.0,212.8 L425.9,217.8 L423.8,222.8 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M423.8,222.8 L421.7,227.8 L419.6,232.8 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M419.6,232.8 L417.5,237.8 L415.4,242.8 L413.3,247.7 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M413.3,247.7 L411.2,252.7 L409.1,257.7 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M409.1,257.7 L407.0,262.7 L404.9,267.7 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M404.9,267.7 L402.8,272.7 L400.6,277.6 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M400.6,277.6 L398.5,282.6 L396.4,287.6 L394.3,292.6 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M394.3,292.6 L392.2,297.6 L390.1,302.6 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M390.1,302.6 L388.0,307.6 L385.9,312.5 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M448.3,197.9 L446.2,202.8 L444.1,207.8 \" stroke=\"rgb( 0, 0, 128)\"/>\t<path d=\"M444.1,207.8 L442.0,212.8 L439.9,217.8 \" stroke=\"rgb( 0, 0, 144)\"/>\t<path d=\"M439.9,217.8 L437.8,222.7 L435.7,227.7 L433.6,232.7 \" stroke=\"rgb( 0, 0, 160)\"/>\t<path d=\"M433.6,232.7 L431.5,237.7 L429.4,242.7 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M429.4,242.7 L427.3,247.7 L425.2,252.7 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M425.2,252.7 L423.1,257.6 L421.0,262.6 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M421.0,262.6 L418.9,267.6 L416.8,272.6 L414.7,277.6 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M414.7,277.6 L412.6,282.6 L410.5,287.5 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M410.5,287.5 L408.4,292.5 L406.3,297.5 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M406.3,297.5 L404.2,302.5 L402.1,307.5 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M402.1,307.5 L400.0,312.5 L397.9,317.5 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M162.1,79.9 L174.1,84.8 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M174.1,84.8 L186.0,89.7 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M186.0,89.7 L197.9,94.6 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M197.9,94.6 L209.9,99.5 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M209.9,99.5 L221.8,104.5 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M221.8,104.5 L233.7,109.4 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M233.7,109.4 L245.6,114.3 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M245.6,114.3 L257.6,119.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M257.6,119.2 L269.5,124.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M269.5,124.1 L281.3,129.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M281.3,129.1 L293.3,134.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M293.3,134.0 L305.2,138.9 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M305.2,138.9 L317.1,143.8 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M317.1,143.8 L329.0,148.7 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M329.0,148.7 L341.0,153.6 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M341.0,153.6 L352.9,158.6 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M352.9,158.6 L364.8,163.5 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M364.8,163.5 L376.8,168.4 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M376.8,168.4 L388.7,173.3 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M388.7,173.3 L400.6,178.2 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M400.6,178.2 L412.5,183.2 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M412.5,183.2 L424.5,188.1 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M424.5,188.1 L436.4,193.0 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M436.4,193.0 L448.3,197.9 \" stroke=\"rgb( 0, 0, 144)\"/>\t<path d=\"M160.0,84.8 L172.0,89.8 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M172.0,89.8 L183.9,94.7 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M183.9,94.7 L195.8,99.6 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M195.8,99.6 L207.8,104.5 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M207.8,104.5 L219.7,109.4 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M219.7,109.4 L231.6,114.4 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M231.6,114.4 L243.5,119.3 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M243.5,119.3 L255.5,124.2 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M255.5,124.2 L267.4,129.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M267.4,129.1 L279.3,134.0 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M279.3,134.0 L291.2,139.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M291.2,139.0 L303.1,143.9 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M303.1,143.9 L315.0,148.8 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M315.0,148.8 L326.9,153.7 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M326.9,153.7 L338.9,158.6 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M338.9,158.6 L350.8,163.6 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M350.8,163.6 L362.7,168.5 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M362.7,168.5 L374.7,173.4 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M374.7,173.4 L386.6,178.3 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M386.6,178.3 L398.5,183.2 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M398.5,183.2 L410.4,188.2 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M410.4,188.2 L422.4,193.1 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M422.4,193.1 L434.3,198.0 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M434.3,198.0 L446.2,202.8 \" stroke=\"rgb( 0, 0, 144)\"/>\t<path d=\"M157.9,89.8 L169.9,94.7 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M169.9,94.7 L181.8,99.7 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M181.8,99.7 L193.7,104.6 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M193.7,104.6 L205.7,109.5 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M205.7,109.5 L217.6,114.4 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M217.6,114.4 L229.5,119.3 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M229.5,119.3 L241.4,124.3 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M241.4,124.3 L253.4,129.2 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M253.4,129.2 L265.3,134.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M265.3,134.1 L277.2,139.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M277.2,139.0 L289.1,143.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M289.1,143.9 L301.0,148.9 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M301.0,148.9 L312.9,153.8 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M312.9,153.8 L324.8,158.7 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M324.8,158.7 L336.8,163.6 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M336.8,163.6 L348.7,168.5 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M348.7,168.5 L360.6,173.5 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M360.6,173.5 L372.6,178.4 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M372.6,178.4 L384.5,183.3 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M384.5,183.3 L396.4,188.2 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M396.4,188.2 L408.3,193.1 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M408.3,193.1 L420.3,198.1 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M420.3,198.1 L432.2,202.9 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M432.2,202.9 L444.1,207.8 \" stroke=\"rgb( 0, 0, 160)\"/>\t<path d=\"M155.8,94.8 L167.8,99.7 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M167.8,99.7 L179.7,104.7 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M179.7,104.7 L191.6,109.6 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M191.6,109.6 L203.6,114.5 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M203.6,114.5 L215.5,119.4 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M215.5,119.4 L227.4,124.3 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M227.4,124.3 L239.3,129.2 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M239.3,129.2 L251.3,134.2 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M251.3,134.2 L263.2,139.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M263.2,139.1 L275.1,144.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M275.1,144.0 L287.0,148.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M287.0,148.9 L298.9,153.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M298.9,153.8 L310.8,158.8 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M310.8,158.8 L322.7,163.7 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M322.7,163.7 L334.7,168.6 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M334.7,168.6 L346.6,173.5 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M346.6,173.5 L358.5,178.4 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M358.5,178.4 L370.5,183.4 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M370.5,183.4 L382.4,188.3 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M382.4,188.3 L394.3,193.2 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M394.3,193.2 L406.2,198.1 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M406.2,198.1 L418.2,202.9 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M418.2,202.9 L430.1,207.9 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M430.1,207.9 L442.0,212.8 \" stroke=\"rgb( 0, 0, 160)\"/>\t<path d=\"M153.7,99.8 L165.7,104.7 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M165.7,104.7 L177.6,109.6 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M177.6,109.6 L189.5,114.6 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M189.5,114.6 L201.4,119.5 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M201.4,119.5 L213.4,124.4 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M213.4,124.4 L225.3,129.3 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M225.3,129.3 L237.2,134.2 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M237.2,134.2 L249.2,139.2 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M249.2,139.2 L261.1,144.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M261.1,144.1 L273.0,149.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M273.0,149.0 L284.8,153.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M284.8,153.9 L296.8,158.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M296.8,158.8 L308.7,163.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M308.7,163.7 L320.6,168.7 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M320.6,168.7 L332.6,173.6 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M332.6,173.6 L344.5,178.5 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M344.5,178.5 L356.4,183.4 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M356.4,183.4 L368.3,188.3 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M368.3,188.3 L380.3,193.3 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M380.3,193.3 L392.2,198.2 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M392.2,198.2 L404.1,203.0 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M404.1,203.0 L416.1,207.9 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M416.1,207.9 L428.0,212.8 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M428.0,212.8 L439.9,217.8 \" stroke=\"rgb( 0, 0, 160)\"/>\t<path d=\"M151.6,104.8 L163.6,109.7 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M163.6,109.7 L175.5,114.6 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M175.5,114.6 L187.4,119.5 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M187.4,119.5 L199.3,124.5 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M199.3,124.5 L211.3,129.4 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M211.3,129.4 L223.2,134.3 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M223.2,134.3 L235.1,139.2 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M235.1,139.2 L247.1,144.1 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M247.1,144.1 L259.0,149.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M259.0,149.1 L270.9,154.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M270.9,154.0 L282.7,158.9 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M282.7,158.9 L294.7,163.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M294.7,163.8 L306.6,168.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M306.6,168.7 L318.5,173.7 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M318.5,173.7 L330.5,178.6 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M330.5,178.6 L342.4,183.5 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M342.4,183.5 L354.3,188.4 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M354.3,188.4 L366.2,193.3 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M366.2,193.3 L378.2,198.3 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M378.2,198.3 L390.1,203.1 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M390.1,203.1 L402.0,208.0 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M402.0,208.0 L414.0,212.9 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M414.0,212.9 L425.9,217.8 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M425.9,217.8 L437.8,222.7 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M149.5,109.8 L161.5,114.7 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M161.5,114.7 L173.4,119.6 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M173.4,119.6 L185.3,124.5 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M185.3,124.5 L197.2,129.4 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M197.2,129.4 L209.2,134.4 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M209.2,134.4 L221.1,139.3 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M221.1,139.3 L233.0,144.2 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M233.0,144.2 L245.0,149.1 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M245.0,149.1 L256.9,154.0 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M256.9,154.0 L268.8,159.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M268.8,159.0 L280.6,163.9 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M280.6,163.9 L292.6,168.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M292.6,168.8 L304.5,173.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M304.5,173.7 L316.4,178.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M316.4,178.6 L328.4,183.6 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M328.4,183.6 L340.3,188.5 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M340.3,188.5 L352.2,193.4 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M352.2,193.4 L364.1,198.3 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M364.1,198.3 L376.1,203.1 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M376.1,203.1 L388.0,208.1 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M388.0,208.1 L399.9,213.0 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M399.9,213.0 L411.9,217.9 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M411.9,217.9 L423.8,222.8 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M423.8,222.8 L435.7,227.7 \" stroke=\"rgb( 0, 0, 176)\"/>\t<path d=\"M147.4,114.8 L159.4,119.7 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M159.4,119.7 L171.3,124.6 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M171.3,124.6 L183.2,129.5 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M183.2,129.5 L195.1,134.4 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M195.1,134.4 L207.1,139.3 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M207.1,139.3 L219.0,144.3 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M219.0,144.3 L230.9,149.2 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M230.9,149.2 L242.9,154.1 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M242.9,154.1 L254.8,159.0 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M254.8,159.0 L266.7,163.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M266.7,163.9 L278.6,168.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M278.6,168.9 L290.5,173.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M290.5,173.8 L302.4,178.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M302.4,178.7 L314.3,183.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M314.3,183.6 L326.3,188.5 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M326.3,188.5 L338.2,193.5 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M338.2,193.5 L350.1,198.4 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M350.1,198.4 L362.0,203.2 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M362.0,203.2 L374.0,208.1 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M374.0,208.1 L385.9,213.0 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M385.9,213.0 L397.8,218.0 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M397.8,218.0 L409.8,222.9 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M409.8,222.9 L421.7,227.8 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M421.7,227.8 L433.6,232.7 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M145.3,119.7 L157.2,124.7 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M157.2,124.7 L169.2,129.6 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M169.2,129.6 L181.1,134.5 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M181.1,134.5 L193.0,139.4 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M193.0,139.4 L205.0,144.3 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M205.0,144.3 L216.9,149.3 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M216.9,149.3 L228.8,154.2 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M228.8,154.2 L240.7,159.1 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M240.7,159.1 L252.7,164.0 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M252.7,164.0 L264.6,168.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M264.6,168.9 L276.5,173.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M276.5,173.8 L288.4,178.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M288.4,178.8 L300.3,183.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M300.3,183.7 L312.2,188.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M312.2,188.6 L324.1,193.5 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M324.1,193.5 L336.1,198.4 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M336.1,198.4 L348.0,203.3 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M348.0,203.3 L359.9,208.2 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M359.9,208.2 L371.9,213.1 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M371.9,213.1 L383.8,218.0 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M383.8,218.0 L395.7,222.9 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M395.7,222.9 L407.6,227.9 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M407.6,227.9 L419.6,232.8 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M419.6,232.8 L431.5,237.7 \" stroke=\"rgb( 0, 0, 192)\"/>\t<path d=\"M143.2,124.7 L155.1,129.6 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M155.1,129.6 L167.1,134.6 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M167.1,134.6 L179.0,139.5 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M179.0,139.5 L190.9,144.4 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M190.9,144.4 L202.9,149.3 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M202.9,149.3 L214.8,154.2 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M214.8,154.2 L226.7,159.2 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M226.7,159.2 L238.6,164.1 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M238.6,164.1 L250.6,169.0 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M250.6,169.0 L262.5,173.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M262.5,173.9 L274.4,178.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M274.4,178.8 L286.3,183.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M286.3,183.8 L298.2,188.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M298.2,188.7 L310.1,193.6 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M310.1,193.6 L322.0,198.5 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M322.0,198.5 L334.0,203.3 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M334.0,203.3 L345.9,208.3 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M345.9,208.3 L357.8,213.2 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M357.8,213.2 L369.8,218.1 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M369.8,218.1 L381.7,223.0 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M381.7,223.0 L393.6,227.9 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M393.6,227.9 L405.5,232.8 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M405.5,232.8 L417.5,237.8 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M417.5,237.8 L429.4,242.7 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M141.1,129.7 L153.0,134.6 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M153.0,134.6 L165.0,139.5 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M165.0,139.5 L176.9,144.5 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M176.9,144.5 L188.8,149.4 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M188.8,149.4 L200.8,154.3 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M200.8,154.3 L212.7,159.2 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M212.7,159.2 L224.6,164.1 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M224.6,164.1 L236.5,169.1 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M236.5,169.1 L248.5,174.0 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M248.5,174.0 L260.4,178.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M260.4,178.9 L272.3,183.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M272.3,183.8 L284.2,188.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M284.2,188.7 L296.1,193.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M296.1,193.7 L308.0,198.6 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M308.0,198.6 L319.9,203.4 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M319.9,203.4 L331.9,208.3 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M331.9,208.3 L343.8,213.2 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M343.8,213.2 L355.7,218.2 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M355.7,218.2 L367.7,223.1 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M367.7,223.1 L379.6,228.0 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M379.6,228.0 L391.5,232.9 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M391.5,232.9 L403.4,237.8 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M403.4,237.8 L415.4,242.8 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M415.4,242.8 L427.3,247.7 \" stroke=\"rgb( 0, 0, 208)\"/>\t<path d=\"M139.0,134.7 L150.9,139.6 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M150.9,139.6 L162.9,144.5 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M162.9,144.5 L174.8,149.4 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M174.8,149.4 L186.7,154.4 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M186.7,154.4 L198.7,159.3 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M198.7,159.3 L210.6,164.2 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M210.6,164.2 L222.5,169.1 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M222.5,169.1 L234.4,174.0 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M234.4,174.0 L246.4,179.0 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M246.4,179.0 L258.3,183.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M258.3,183.9 L270.2,188.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M270.2,188.8 L282.1,193.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M282.1,193.7 L294.0,198.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M294.0,198.6 L305.9,203.5 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M305.9,203.5 L317.8,208.4 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M317.8,208.4 L329.8,213.3 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M329.8,213.3 L341.7,218.2 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M341.7,218.2 L353.6,223.1 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M353.6,223.1 L365.6,228.1 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M365.6,228.1 L377.5,233.0 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M377.5,233.0 L389.4,237.9 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M389.4,237.9 L401.3,242.8 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M401.3,242.8 L413.3,247.7 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M413.3,247.7 L425.2,252.7 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M136.9,139.7 L148.8,144.6 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M148.8,144.6 L160.8,149.5 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M160.8,149.5 L172.7,154.4 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M172.7,154.4 L184.6,159.4 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M184.6,159.4 L196.6,164.3 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M196.6,164.3 L208.5,169.2 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M208.5,169.2 L220.4,174.1 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M220.4,174.1 L232.3,179.0 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M232.3,179.0 L244.3,184.0 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M244.3,184.0 L256.2,188.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M256.2,188.9 L268.1,193.8 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M268.1,193.8 L280.0,198.7 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M280.0,198.7 L291.9,203.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M291.9,203.5 L303.8,208.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M303.8,208.4 L315.7,213.4 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M315.7,213.4 L327.7,218.3 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M327.7,218.3 L339.6,223.2 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M339.6,223.2 L351.5,228.1 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M351.5,228.1 L363.4,233.0 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M363.4,233.0 L375.4,238.0 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M375.4,238.0 L387.3,242.9 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M387.3,242.9 L399.2,247.8 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M399.2,247.8 L411.2,252.7 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M411.2,252.7 L423.1,257.6 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M134.8,144.7 L146.7,149.6 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M146.7,149.6 L158.7,154.5 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M158.7,154.5 L170.6,159.4 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M170.6,159.4 L182.5,164.3 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M182.5,164.3 L194.4,169.3 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M194.4,169.3 L206.4,174.2 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M206.4,174.2 L218.3,179.1 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M218.3,179.1 L230.2,184.0 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M230.2,184.0 L242.2,188.9 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M242.2,188.9 L254.1,193.9 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M254.1,193.9 L266.0,198.8 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M266.0,198.8 L277.9,203.6 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M277.9,203.6 L289.8,208.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M289.8,208.5 L301.7,213.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M301.7,213.4 L313.6,218.4 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M313.6,218.4 L325.6,223.3 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M325.6,223.3 L337.5,228.2 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M337.5,228.2 L349.4,233.1 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M349.4,233.1 L361.3,238.0 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M361.3,238.0 L373.3,242.9 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M373.3,242.9 L385.2,247.9 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M385.2,247.9 L397.1,252.8 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M397.1,252.8 L409.1,257.7 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M409.1,257.7 L421.0,262.6 \" stroke=\"rgb( 0, 0, 225)\"/>\t<path d=\"M132.7,149.6 L144.6,154.6 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M144.6,154.6 L156.6,159.5 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M156.6,159.5 L168.5,164.4 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M168.5,164.4 L180.4,169.3 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M180.4,169.3 L192.3,174.2 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M192.3,174.2 L204.3,179.2 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M204.3,179.2 L216.2,184.1 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M216.2,184.1 L228.1,189.0 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M228.1,189.0 L240.1,193.9 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M240.1,193.9 L252.0,198.8 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M252.0,198.8 L263.9,203.7 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M263.9,203.7 L275.8,208.6 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M275.8,208.6 L287.7,213.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M287.7,213.5 L299.6,218.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M299.6,218.4 L311.5,223.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M311.5,223.3 L323.5,228.3 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M323.5,228.3 L335.4,233.2 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M335.4,233.2 L347.3,238.1 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M347.3,238.1 L359.2,243.0 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M359.2,243.0 L371.2,247.9 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M371.2,247.9 L383.1,252.9 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M383.1,252.9 L395.0,257.8 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M395.0,257.8 L407.0,262.7 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M407.0,262.7 L418.9,267.6 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M130.6,154.6 L142.5,159.5 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M142.5,159.5 L154.5,164.5 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M154.5,164.5 L166.4,169.4 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M166.4,169.4 L178.3,174.3 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M178.3,174.3 L190.2,179.2 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M190.2,179.2 L202.2,184.1 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M202.2,184.1 L214.1,189.1 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M214.1,189.1 L226.0,194.0 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M226.0,194.0 L238.0,198.9 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M238.0,198.9 L249.9,203.7 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M249.9,203.7 L261.8,208.6 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M261.8,208.6 L273.7,213.6 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M273.7,213.6 L285.6,218.5 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M285.6,218.5 L297.5,223.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M297.5,223.4 L309.4,228.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M309.4,228.3 L321.4,233.2 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M321.4,233.2 L333.3,238.2 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M333.3,238.2 L345.2,243.1 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M345.2,243.1 L357.1,248.0 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M357.1,248.0 L369.1,252.9 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M369.1,252.9 L381.0,257.8 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M381.0,257.8 L392.9,262.8 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M392.9,262.8 L404.9,267.7 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M404.9,267.7 L416.8,272.6 \" stroke=\"rgb( 0, 0, 241)\"/>\t<path d=\"M128.5,159.6 L140.4,164.5 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M140.4,164.5 L152.4,169.5 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M152.4,169.5 L164.3,174.4 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M164.3,174.4 L176.2,179.3 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M176.2,179.3 L188.1,184.2 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M188.1,184.2 L200.1,189.1 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M200.1,189.1 L212.0,194.1 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M212.0,194.1 L223.9,199.0 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M223.9,199.0 L235.9,203.8 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M235.9,203.8 L247.8,208.7 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M247.8,208.7 L259.7,213.6 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M259.7,213.6 L271.6,218.5 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M271.6,218.5 L283.5,223.5 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M283.5,223.5 L295.4,228.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M295.4,228.4 L307.3,233.3 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M307.3,233.3 L319.3,238.2 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M319.3,238.2 L331.2,243.1 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M331.2,243.1 L343.1,248.1 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M343.1,248.1 L355.0,253.0 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M355.0,253.0 L367.0,257.9 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M367.0,257.9 L378.9,262.8 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M378.9,262.8 L390.8,267.7 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M390.8,267.7 L402.8,272.7 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M402.8,272.7 L414.7,277.6 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M126.4,164.6 L138.3,169.5 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M138.3,169.5 L150.2,174.4 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M150.2,174.4 L162.2,179.4 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M162.2,179.4 L174.1,184.3 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M174.1,184.3 L186.0,189.2 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M186.0,189.2 L198.0,194.1 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M198.0,194.1 L209.9,199.0 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M209.9,199.0 L221.8,203.9 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M221.8,203.9 L233.7,208.8 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M233.7,208.8 L245.7,213.7 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M245.7,213.7 L257.6,218.6 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M257.6,218.6 L269.5,223.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M269.5,223.5 L281.4,228.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M281.4,228.5 L293.3,233.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M293.3,233.4 L305.2,238.3 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M305.2,238.3 L317.1,243.2 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M317.1,243.2 L329.1,248.1 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M329.1,248.1 L341.0,253.0 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M341.0,253.0 L352.9,258.0 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M352.9,258.0 L364.9,262.9 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M364.9,262.9 L376.8,267.8 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M376.8,267.8 L388.7,272.7 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M388.7,272.7 L400.6,277.6 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M400.6,277.6 L412.6,282.6 \" stroke=\"rgb( 0, 2, 255)\"/>\t<path d=\"M124.3,169.6 L136.2,174.5 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M136.2,174.5 L148.1,179.4 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M148.1,179.4 L160.1,184.3 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M160.1,184.3 L172.0,189.3 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M172.0,189.3 L183.9,194.2 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M183.9,194.2 L195.9,199.1 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M195.9,199.1 L207.8,203.9 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M207.8,203.9 L219.7,208.8 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M219.7,208.8 L231.6,213.8 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M231.6,213.8 L243.6,218.7 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M243.6,218.7 L255.5,223.6 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M255.5,223.6 L267.4,228.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M267.4,228.5 L279.4,233.4 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M279.4,233.4 L291.2,238.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M291.2,238.4 L303.1,243.3 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M303.1,243.3 L315.0,248.2 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M315.0,248.2 L327.0,253.1 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M327.0,253.1 L338.9,258.0 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M338.9,258.0 L350.8,263.0 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M350.8,263.0 L362.8,267.9 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M362.8,267.9 L374.7,272.8 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M374.7,272.8 L386.6,277.7 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M386.6,277.7 L398.5,282.6 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M398.5,282.6 L410.5,287.5 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M122.2,174.6 L134.1,179.5 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M134.1,179.5 L146.0,184.4 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M146.0,184.4 L158.0,189.3 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M158.0,189.3 L169.9,194.2 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M169.9,194.2 L181.8,199.2 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M181.8,199.2 L193.8,204.0 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M193.8,204.0 L205.7,208.9 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M205.7,208.9 L217.6,213.8 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M217.6,213.8 L229.5,218.7 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M229.5,218.7 L241.5,223.7 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M241.5,223.7 L253.4,228.6 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M253.4,228.6 L265.3,233.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M265.3,233.5 L277.3,238.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M277.3,238.4 L289.1,243.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M289.1,243.3 L301.0,248.3 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M301.0,248.3 L312.9,253.2 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M312.9,253.2 L324.9,258.1 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M324.9,258.1 L336.8,263.0 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M336.8,263.0 L348.7,267.9 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M348.7,267.9 L360.7,272.9 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M360.7,272.9 L372.6,277.8 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M372.6,277.8 L384.5,282.7 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M384.5,282.7 L396.4,287.6 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M396.4,287.6 L408.4,292.5 \" stroke=\"rgb( 0, 18, 255)\"/>\t<path d=\"M120.1,179.6 L132.0,184.5 \" stroke=\"rgb(160, 0, 0)\"/>\t<path d=\"M132.0,184.5 L143.9,189.4 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M143.9,189.4 L155.9,194.3 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M155.9,194.3 L167.8,199.2 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M167.8,199.2 L179.7,204.1 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M179.7,204.1 L191.7,209.0 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M191.7,209.0 L203.6,213.9 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M203.6,213.9 L215.5,218.8 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M215.5,218.8 L227.4,223.7 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M227.4,223.7 L239.4,228.6 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M239.4,228.6 L251.3,233.6 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M251.3,233.6 L263.2,238.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M263.2,238.5 L275.2,243.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M275.2,243.4 L287.0,248.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M287.0,248.3 L298.9,253.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M298.9,253.2 L310.8,258.2 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M310.8,258.2 L322.8,263.1 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M322.8,263.1 L334.7,268.0 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M334.7,268.0 L346.6,272.9 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M346.6,272.9 L358.6,277.8 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M358.6,277.8 L370.5,282.8 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M370.5,282.8 L382.4,287.7 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M382.4,287.7 L394.3,292.6 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M394.3,292.6 L406.3,297.5 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M118.0,184.5 L129.9,189.5 \" stroke=\"rgb(160, 0, 0)\"/>\t<path d=\"M129.9,189.5 L141.8,194.4 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M141.8,194.4 L153.8,199.3 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M153.8,199.3 L165.7,204.1 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M165.7,204.1 L177.6,209.0 \" stroke=\"rgb(255, 51, 0)\"/>\t<path d=\"M177.6,209.0 L189.5,214.0 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M189.5,214.0 L201.5,218.9 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M201.5,218.9 L213.4,223.8 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M213.4,223.8 L225.3,228.7 \" stroke=\"rgb(255, 196, 0)\"/>\t<path d=\"M225.3,228.7 L237.3,233.6 \" stroke=\"rgb(255, 229, 0)\"/>\t<path d=\"M237.3,233.6 L249.2,238.6 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M249.2,238.6 L261.1,243.5 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M261.1,243.5 L273.0,248.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M273.0,248.4 L284.9,253.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M284.9,253.3 L296.8,258.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M296.8,258.2 L308.7,263.1 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M308.7,263.1 L320.7,268.1 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M320.7,268.1 L332.6,273.0 \" stroke=\"rgb( 0, 245, 255)\"/>\t<path d=\"M332.6,273.0 L344.5,277.9 \" stroke=\"rgb( 0, 212, 255)\"/>\t<path d=\"M344.5,277.9 L356.4,282.8 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M356.4,282.8 L368.4,287.7 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M368.4,287.7 L380.3,292.7 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M380.3,292.7 L392.2,297.6 \" stroke=\"rgb( 0, 67, 255)\"/>\t<path d=\"M392.2,297.6 L404.2,302.5 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M115.9,189.5 L127.8,194.4 \" stroke=\"rgb(144, 0, 0)\"/>\t<path d=\"M127.8,194.4 L139.7,199.4 \" stroke=\"rgb(192, 0, 0)\"/>\t<path d=\"M139.7,199.4 L151.7,204.2 \" stroke=\"rgb(225, 0, 0)\"/>\t<path d=\"M151.7,204.2 L163.6,209.1 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M163.6,209.1 L175.5,214.0 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M175.5,214.0 L187.4,218.9 \" stroke=\"rgb(255, 83, 0)\"/>\t<path d=\"M187.4,218.9 L199.4,223.9 \" stroke=\"rgb(255, 115, 0)\"/>\t<path d=\"M199.4,223.9 L211.3,228.8 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M211.3,228.8 L223.2,233.7 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M223.2,233.7 L235.2,238.6 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M235.2,238.6 L247.1,243.5 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M247.1,243.5 L259.0,248.5 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M259.0,248.5 L270.9,253.4 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M270.9,253.4 L282.8,258.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M282.8,258.3 L294.7,263.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M294.7,263.2 L306.6,268.1 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M306.6,268.1 L318.6,273.1 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M318.6,273.1 L330.5,278.0 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M330.5,278.0 L342.4,282.9 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M342.4,282.9 L354.3,287.8 \" stroke=\"rgb( 0, 180, 255)\"/>\t<path d=\"M354.3,287.8 L366.3,292.7 \" stroke=\"rgb( 0, 148, 255)\"/>\t<path d=\"M366.3,292.7 L378.2,297.6 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M378.2,297.6 L390.1,302.6 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M390.1,302.6 L402.1,307.5 \" stroke=\"rgb( 0, 34, 255)\"/>\t<path d=\"M113.8,194.5 L125.7,199.4 \" stroke=\"rgb(144, 0, 0)\"/>\t<path d=\"M125.7,199.4 L137.6,204.2 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M137.6,204.2 L149.6,209.2 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M149.6,209.2 L161.5,214.1 \" stroke=\"rgb(255, 2, 0)\"/>\t<path d=\"M161.5,214.1 L173.4,219.0 \" stroke=\"rgb(255, 34, 0)\"/>\t<path d=\"M173.4,219.0 L185.3,223.9 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M185.3,223.9 L197.3,228.8 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M197.3,228.8 L209.2,233.8 \" stroke=\"rgb(255, 148, 0)\"/>\t<path d=\"M209.2,233.8 L221.1,238.7 \" stroke=\"rgb(255, 180, 0)\"/>\t<path d=\"M221.1,238.7 L233.1,243.6 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M233.1,243.6 L245.0,248.5 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M245.0,248.5 L256.9,253.4 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M256.9,253.4 L268.8,258.4 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M268.8,258.4 L280.7,263.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M280.7,263.3 L292.6,268.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M292.6,268.2 L304.5,273.1 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M304.5,273.1 L316.5,278.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M316.5,278.0 L328.4,283.0 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M328.4,283.0 L340.3,287.9 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M340.3,287.9 L352.2,292.8 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M352.2,292.8 L364.2,297.7 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M364.2,297.7 L376.1,302.6 \" stroke=\"rgb( 0, 115, 255)\"/>\t<path d=\"M376.1,302.6 L388.0,307.6 \" stroke=\"rgb( 0, 83, 255)\"/>\t<path d=\"M388.0,307.6 L400.0,312.5 \" stroke=\"rgb( 0, 51, 255)\"/>\t<path d=\"M111.7,199.5 L123.6,204.3 \" stroke=\"rgb(144, 0, 0)\"/>\t<path d=\"M123.6,204.3 L135.5,209.2 \" stroke=\"rgb(176, 0, 0)\"/>\t<path d=\"M135.5,209.2 L147.5,214.2 \" stroke=\"rgb(208, 0, 0)\"/>\t<path d=\"M147.5,214.2 L159.4,219.1 \" stroke=\"rgb(241, 0, 0)\"/>\t<path d=\"M159.4,219.1 L171.3,224.0 \" stroke=\"rgb(255, 18, 0)\"/>\t<path d=\"M171.3,224.0 L183.2,228.9 \" stroke=\"rgb(255, 67, 0)\"/>\t<path d=\"M183.2,228.9 L195.2,233.8 \" stroke=\"rgb(255, 99, 0)\"/>\t<path d=\"M195.2,233.8 L207.1,238.7 \" stroke=\"rgb(255, 132, 0)\"/>\t<path d=\"M207.1,238.7 L219.0,243.7 \" stroke=\"rgb(255, 164, 0)\"/>\t<path d=\"M219.0,243.7 L231.0,248.6 \" stroke=\"rgb(255, 212, 0)\"/>\t<path d=\"M231.0,248.6 L242.9,253.5 \" stroke=\"rgb(255, 245, 0)\"/>\t<path d=\"M242.9,253.5 L254.8,258.4 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M254.8,258.4 L266.7,263.3 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M266.7,263.3 L278.7,268.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M278.7,268.3 L290.5,273.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M290.5,273.2 L302.4,278.1 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M302.4,278.1 L314.4,283.0 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M314.4,283.0 L326.3,287.9 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M326.3,287.9 L338.2,292.9 \" stroke=\"rgb( 0, 229, 255)\"/>\t<path d=\"M338.2,292.9 L350.1,297.8 \" stroke=\"rgb( 0, 196, 255)\"/>\t<path d=\"M350.1,297.8 L362.1,302.7 \" stroke=\"rgb( 0, 164, 255)\"/>\t<path d=\"M362.1,302.7 L374.0,307.6 \" stroke=\"rgb( 0, 132, 255)\"/>\t<path d=\"M374.0,307.6 L385.9,312.5 \" stroke=\"rgb( 0, 99, 255)\"/>\t<path d=\"M385.9,312.5 L397.9,317.5 \" stroke=\"rgb( 0, 51, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>gnuplot_plot_2a</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M162.1,112.6 L160.0,118.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M160.0,118.0 L157.9,123.4 L155.8,128.8 L153.7,134.1 L151.6,139.5 L149.5,144.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M149.5,144.9 L147.4,150.3 L145.3,155.6 L143.2,161.0 L141.1,166.4 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M141.1,166.4 L139.0,171.8 L136.9,177.1 L134.8,182.5 L132.7,187.9 L130.6,193.3 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M130.6,193.3 L128.5,198.6 L126.4,203.9 L124.3,209.3 L122.2,214.7 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M122.2,214.7 L120.1,220.0 L118.0,225.4 L115.9,230.8 L113.8,236.2 L111.7,241.5 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M174.1,114.4 L172.0,119.8 L169.9,125.2 L167.8,130.6 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M167.8,130.6 L165.7,135.9 L163.6,141.3 L161.5,146.7 L159.4,152.1 L157.2,157.4 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M157.2,157.4 L155.1,162.8 L153.0,168.2 L150.9,173.6 L148.8,178.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M148.8,178.9 L146.7,184.3 L144.6,189.7 L142.5,195.1 L140.4,200.4 L138.3,205.7 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M138.3,205.7 L136.2,211.1 L134.1,216.5 L132.0,221.8 L129.9,227.2 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M129.9,227.2 L127.8,232.6 L125.7,238.0 L123.6,243.3 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M186.0,116.2 L183.9,121.6 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M183.9,121.6 L181.8,127.0 L179.7,132.4 L177.6,137.7 L175.5,143.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M175.5,143.1 L173.4,148.5 L171.3,153.9 L169.2,159.2 L167.1,164.6 L165.0,170.0 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M165.0,170.0 L162.9,175.4 L160.8,180.7 L158.7,186.1 L156.6,191.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M156.6,191.5 L154.5,196.9 L152.4,202.1 L150.2,207.5 L148.1,212.9 L146.0,218.3 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M146.0,218.3 L143.9,223.6 L141.8,229.0 L139.7,234.4 L137.6,239.8 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M137.6,239.8 L135.5,245.1 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M197.9,118.0 L195.8,123.4 L193.7,128.8 L191.6,134.2 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M191.6,134.2 L189.5,139.5 L187.4,144.9 L185.3,150.3 L183.2,155.7 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M183.2,155.7 L181.1,161.0 L179.0,166.4 L176.9,171.8 L174.8,177.2 L172.7,182.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M172.7,182.5 L170.6,187.9 L168.5,193.3 L166.4,198.7 L164.3,203.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M164.3,203.9 L162.2,209.3 L160.1,214.7 L158.0,220.1 L155.9,225.4 L153.8,230.8 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M153.8,230.8 L151.7,236.2 L149.6,241.6 L147.5,246.9 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M209.9,119.8 L207.8,125.2 L205.7,130.6 L203.6,136.0 L201.4,141.3 L199.3,146.7 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M199.3,146.7 L197.2,152.1 L195.1,157.5 L193.0,162.8 L190.9,168.2 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M190.9,168.2 L188.8,173.6 L186.7,179.0 L184.6,184.3 L182.5,189.7 L180.4,195.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M180.4,195.1 L178.3,200.5 L176.2,205.7 L174.1,211.1 L172.0,216.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M172.0,216.5 L169.9,221.9 L167.8,227.2 L165.7,232.6 L163.6,238.0 L161.5,243.4 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M161.5,243.4 L159.4,248.7 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M221.8,121.6 L219.7,127.0 L217.6,132.4 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M217.6,132.4 L215.5,137.8 L213.4,143.1 L211.3,148.5 L209.2,153.9 L207.1,159.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M207.1,159.3 L205.0,164.6 L202.9,170.0 L200.8,175.4 L198.7,180.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M198.7,180.8 L196.6,186.1 L194.4,191.5 L192.3,196.9 L190.2,202.2 L188.1,207.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M188.1,207.5 L186.0,212.9 L183.9,218.3 L181.8,223.7 L179.7,229.0 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M179.7,229.0 L177.6,234.4 L175.5,239.8 L173.4,245.2 L171.3,250.5 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M233.7,123.4 L231.6,128.8 L229.5,134.2 L227.4,139.6 L225.3,144.9 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M225.3,144.9 L223.2,150.3 L221.1,155.7 L219.0,161.1 L216.9,166.4 L214.8,171.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M214.8,171.8 L212.7,177.2 L210.6,182.6 L208.5,187.9 L206.4,193.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M206.4,193.3 L204.3,198.7 L202.2,204.0 L200.1,209.3 L198.0,214.7 L195.9,220.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M195.9,220.1 L193.8,225.5 L191.7,230.8 L189.5,236.2 L187.4,241.6 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M187.4,241.6 L185.3,247.0 L183.2,252.3 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M245.6,125.2 L243.5,130.6 L241.4,136.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M241.4,136.0 L239.3,141.3 L237.2,146.7 L235.1,152.1 L233.0,157.5 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M233.0,157.5 L230.9,162.8 L228.8,168.2 L226.7,173.6 L224.6,179.0 L222.5,184.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M222.5,184.3 L220.4,189.7 L218.3,195.1 L216.2,200.5 L214.1,205.7 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M214.1,205.7 L212.0,211.1 L209.9,216.5 L207.8,221.9 L205.7,227.2 L203.6,232.6 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M203.6,232.6 L201.5,238.0 L199.4,243.4 L197.3,248.7 L195.2,254.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M257.6,127.0 L255.5,132.4 L253.4,137.8 L251.3,143.1 L249.2,148.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M249.2,148.5 L247.1,153.9 L245.0,159.3 L242.9,164.6 L240.7,170.0 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M240.7,170.0 L238.6,175.4 L236.5,180.8 L234.4,186.1 L232.3,191.5 L230.2,196.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M230.2,196.9 L228.1,202.2 L226.0,207.5 L223.9,212.9 L221.8,218.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M221.8,218.3 L219.7,223.7 L217.6,229.0 L215.5,234.4 L213.4,239.8 L211.3,245.2 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M211.3,245.2 L209.2,250.5 L207.1,255.9 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M269.5,128.8 L267.4,134.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M267.4,134.2 L265.3,139.6 L263.2,144.9 L261.1,150.3 L259.0,155.7 L256.9,161.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M256.9,161.1 L254.8,166.4 L252.7,171.8 L250.6,177.2 L248.5,182.6 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M248.5,182.6 L246.4,187.9 L244.3,193.3 L242.2,198.7 L240.1,204.0 L238.0,209.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M238.0,209.3 L235.9,214.7 L233.7,220.1 L231.6,225.5 L229.5,230.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M229.5,230.8 L227.4,236.2 L225.3,241.6 L223.2,247.0 L221.1,252.3 L219.0,257.7 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M281.3,130.6 L279.3,136.0 L277.2,141.4 L275.1,146.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M275.1,146.7 L273.0,152.1 L270.9,157.5 L268.8,162.9 L266.7,168.2 L264.6,173.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M264.6,173.6 L262.5,179.0 L260.4,184.4 L258.3,189.7 L256.2,195.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M256.2,195.1 L254.1,200.5 L252.0,205.8 L249.9,211.1 L247.8,216.5 L245.7,221.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M245.7,221.9 L243.6,227.3 L241.5,232.6 L239.4,238.0 L237.3,243.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M237.3,243.4 L235.2,248.8 L233.1,254.1 L231.0,259.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M293.3,132.4 L291.2,137.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M291.2,137.8 L289.1,143.2 L287.0,148.5 L284.8,153.9 L282.7,159.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M282.7,159.3 L280.6,164.7 L278.6,170.0 L276.5,175.4 L274.4,180.8 L272.3,186.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M272.3,186.2 L270.2,191.5 L268.1,196.9 L266.0,202.2 L263.9,207.6 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M263.9,207.6 L261.8,212.9 L259.7,218.3 L257.6,223.7 L255.5,229.1 L253.4,234.4 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M253.4,234.4 L251.3,239.8 L249.2,245.2 L247.1,250.6 L245.0,255.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M245.0,255.9 L242.9,261.3 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M305.2,134.2 L303.1,139.6 L301.0,145.0 L298.9,150.3 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M298.9,150.3 L296.8,155.7 L294.7,161.1 L292.6,166.5 L290.5,171.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M290.5,171.8 L288.4,177.2 L286.3,182.6 L284.2,188.0 L282.1,193.3 L280.0,198.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M280.0,198.7 L277.9,204.0 L275.8,209.4 L273.7,214.7 L271.6,220.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M271.6,220.1 L269.5,225.5 L267.4,230.9 L265.3,236.2 L263.2,241.6 L261.1,247.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M261.1,247.0 L259.0,252.4 L256.9,257.7 L254.8,263.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M317.1,136.0 L315.0,141.4 L312.9,146.8 L310.8,152.1 L308.7,157.5 L306.6,162.9 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M306.6,162.9 L304.5,168.3 L302.4,173.6 L300.3,179.0 L298.2,184.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M298.2,184.4 L296.1,189.8 L294.0,195.1 L291.9,200.5 L289.8,205.8 L287.7,211.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M287.7,211.2 L285.6,216.5 L283.5,221.9 L281.4,227.3 L279.4,232.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M279.4,232.7 L277.3,238.0 L275.2,243.4 L273.0,248.8 L270.9,254.2 L268.8,259.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M268.8,259.5 L266.7,264.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M329.0,137.8 L326.9,143.2 L324.8,148.6 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M324.8,148.6 L322.7,153.9 L320.6,159.3 L318.5,164.7 L316.4,170.1 L314.3,175.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M314.3,175.4 L312.2,180.8 L310.1,186.2 L308.0,191.6 L305.9,196.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M305.9,196.9 L303.8,202.2 L301.7,207.6 L299.6,213.0 L297.5,218.3 L295.4,223.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M295.4,223.7 L293.3,229.1 L291.2,234.5 L289.1,239.8 L287.0,245.2 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M287.0,245.2 L284.9,250.6 L282.8,256.0 L280.7,261.3 L278.7,266.7 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M341.0,139.6 L338.9,145.0 L336.8,150.3 L334.7,155.7 L332.6,161.1 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M332.6,161.1 L330.5,166.5 L328.4,171.8 L326.3,177.2 L324.1,182.6 L322.0,188.0 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M322.0,188.0 L319.9,193.3 L317.8,198.7 L315.7,204.0 L313.6,209.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M313.6,209.4 L311.5,214.7 L309.4,220.1 L307.3,225.5 L305.2,230.9 L303.1,236.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M303.1,236.2 L301.0,241.6 L298.9,247.0 L296.8,252.4 L294.7,257.8 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M294.7,257.8 L292.6,263.1 L290.5,268.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M352.9,141.4 L350.8,146.8 L348.7,152.1 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M348.7,152.1 L346.6,157.5 L344.5,162.9 L342.4,168.3 L340.3,173.6 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M340.3,173.6 L338.2,179.0 L336.1,184.4 L334.0,189.8 L331.9,195.1 L329.8,200.5 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M329.8,200.5 L327.7,205.8 L325.6,211.2 L323.5,216.5 L321.4,221.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M321.4,221.9 L319.3,227.3 L317.1,232.7 L315.0,238.0 L312.9,243.4 L310.8,248.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M310.8,248.8 L308.7,254.2 L306.6,259.5 L304.5,264.9 L302.4,270.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M364.8,143.2 L362.7,148.6 L360.6,153.9 L358.5,159.3 L356.4,164.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M356.4,164.7 L354.3,170.1 L352.2,175.4 L350.1,180.8 L348.0,186.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M348.0,186.2 L345.9,191.6 L343.8,196.9 L341.7,202.2 L339.6,207.6 L337.5,213.0 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M337.5,213.0 L335.4,218.3 L333.3,223.7 L331.2,229.1 L329.1,234.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M329.1,234.5 L327.0,239.8 L324.9,245.2 L322.8,250.6 L320.7,256.0 L318.6,261.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M318.6,261.3 L316.5,266.7 L314.4,272.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M376.8,145.0 L374.7,150.4 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M374.7,150.4 L372.6,155.7 L370.5,161.1 L368.3,166.5 L366.2,171.9 L364.1,177.2 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M364.1,177.2 L362.0,182.6 L359.9,188.0 L357.8,193.4 L355.7,198.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M355.7,198.7 L353.6,204.0 L351.5,209.4 L349.4,214.8 L347.3,220.1 L345.2,225.5 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M345.2,225.5 L343.1,230.9 L341.0,236.3 L338.9,241.6 L336.8,247.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M336.8,247.0 L334.7,252.4 L332.6,257.8 L330.5,263.1 L328.4,268.5 L326.3,273.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M388.7,146.8 L386.6,152.2 L384.5,157.5 L382.4,162.9 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M382.4,162.9 L380.3,168.3 L378.2,173.7 L376.1,179.0 L374.0,184.4 L371.9,189.8 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M371.9,189.8 L369.8,195.2 L367.7,200.5 L365.6,205.8 L363.4,211.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M363.4,211.2 L361.3,216.6 L359.2,221.9 L357.1,227.3 L355.0,232.7 L352.9,238.1 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M352.9,238.1 L350.8,243.4 L348.7,248.8 L346.6,254.2 L344.5,259.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M344.5,259.6 L342.4,264.9 L340.3,270.3 L338.2,275.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M400.6,148.6 L398.5,154.0 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M398.5,154.0 L396.4,159.3 L394.3,164.7 L392.2,170.1 L390.1,175.5 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M390.1,175.5 L388.0,180.8 L385.9,186.2 L383.8,191.6 L381.7,197.0 L379.6,202.2 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M379.6,202.2 L377.5,207.6 L375.4,213.0 L373.3,218.4 L371.2,223.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M371.2,223.7 L369.1,229.1 L367.0,234.5 L364.9,239.9 L362.8,245.2 L360.7,250.6 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M360.7,250.6 L358.6,256.0 L356.4,261.4 L354.3,266.7 L352.2,272.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M352.2,272.1 L350.1,277.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M412.5,150.4 L410.4,155.8 L408.3,161.1 L406.2,166.5 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M406.2,166.5 L404.1,171.9 L402.0,177.3 L399.9,182.6 L397.8,188.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M397.8,188.0 L395.7,193.4 L393.6,198.8 L391.5,204.0 L389.4,209.4 L387.3,214.8 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M387.3,214.8 L385.2,220.2 L383.1,225.5 L381.0,230.9 L378.9,236.3 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M378.9,236.3 L376.8,241.7 L374.7,247.0 L372.6,252.4 L370.5,257.8 L368.4,263.2 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M368.4,263.2 L366.3,268.5 L364.2,273.9 L362.1,279.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M424.5,152.2 L422.4,157.6 L420.3,162.9 L418.2,168.3 L416.1,173.7 L414.0,179.1 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M414.0,179.1 L411.9,184.4 L409.8,189.8 L407.6,195.2 L405.5,200.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M405.5,200.6 L403.4,205.8 L401.3,211.2 L399.2,216.6 L397.1,222.0 L395.0,227.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M395.0,227.3 L392.9,232.7 L390.8,238.1 L388.7,243.5 L386.6,248.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M386.6,248.8 L384.5,254.2 L382.4,259.6 L380.3,265.0 L378.2,270.3 L376.1,275.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M376.1,275.7 L374.0,281.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M436.4,154.0 L434.3,159.4 L432.2,164.7 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M432.2,164.7 L430.1,170.1 L428.0,175.5 L425.9,180.9 L423.8,186.2 L421.7,191.6 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M421.7,191.6 L419.6,197.0 L417.5,202.3 L415.4,207.6 L413.3,213.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M413.3,213.0 L411.2,218.4 L409.1,223.8 L407.0,229.1 L404.9,234.5 L402.8,239.9 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M402.8,239.9 L400.6,245.3 L398.5,250.6 L396.4,256.0 L394.3,261.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M394.3,261.4 L392.2,266.8 L390.1,272.1 L388.0,277.5 L385.9,282.9 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M448.3,155.8 L446.2,161.1 L444.1,166.5 L442.0,171.9 L439.9,177.3 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M439.9,177.3 L437.8,182.6 L435.7,188.0 L433.6,193.4 L431.5,198.8 L429.4,204.0 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M429.4,204.0 L427.3,209.4 L425.2,214.8 L423.1,220.2 L421.0,225.5 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M421.0,225.5 L418.9,230.9 L416.8,236.3 L414.7,241.7 L412.6,247.0 L410.5,252.4 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M410.5,252.4 L408.4,257.8 L406.3,263.2 L404.2,268.5 L402.1,273.9 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M402.1,273.9 L400.0,279.3 L397.9,284.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M162.1,112.6 L174.1,114.4 L186.0,116.2 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M186.0,116.2 L197.9,118.0 L209.9,119.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M209.9,119.8 L221.8,121.6 L233.7,123.4 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M233.7,123.4 L245.6,125.2 L257.6,127.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M257.6,127.0 L269.5,128.8 L281.3,130.6 L293.3,132.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M293.3,132.4 L305.2,134.2 L317.1,136.0 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M317.1,136.0 L329.0,137.8 L341.0,139.6 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M341.0,139.6 L352.9,141.4 L364.8,143.2 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M364.8,143.2 L376.8,145.0 L388.7,146.8 L400.6,148.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M400.6,148.6 L412.5,150.4 L424.5,152.2 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M424.5,152.2 L436.4,154.0 L448.3,155.8 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M160.0,118.0 L172.0,119.8 L183.9,121.6 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M183.9,121.6 L195.8,123.4 L207.8,125.2 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M207.8,125.2 L219.7,127.0 L231.6,128.8 L243.5,130.6 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M243.5,130.6 L255.5,132.4 L267.4,134.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M267.4,134.2 L279.3,136.0 L291.2,137.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M291.2,137.8 L303.1,139.6 L315.0,141.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M315.0,141.4 L326.9,143.2 L338.9,145.0 L350.8,146.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M350.8,146.8 L362.7,148.6 L374.7,150.4 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M374.7,150.4 L386.6,152.2 L398.5,154.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M398.5,154.0 L410.4,155.8 L422.4,157.6 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M422.4,157.6 L434.3,159.4 L446.2,161.1 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M157.9,123.4 L169.9,125.2 L181.8,127.0 L193.7,128.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M193.7,128.8 L205.7,130.6 L217.6,132.4 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M217.6,132.4 L229.5,134.2 L241.4,136.0 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M241.4,136.0 L253.4,137.8 L265.3,139.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M265.3,139.6 L277.2,141.4 L289.1,143.2 L301.0,145.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M301.0,145.0 L312.9,146.8 L324.8,148.6 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M324.8,148.6 L336.8,150.3 L348.7,152.1 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M348.7,152.1 L360.6,153.9 L372.6,155.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M372.6,155.7 L384.5,157.5 L396.4,159.3 L408.3,161.1 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M408.3,161.1 L420.3,162.9 L432.2,164.7 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M432.2,164.7 L444.1,166.5 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M155.8,128.8 L167.8,130.6 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M167.8,130.6 L179.7,132.4 L191.6,134.2 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M191.6,134.2 L203.6,136.0 L215.5,137.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M215.5,137.8 L227.4,139.6 L239.3,141.3 L251.3,143.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M251.3,143.1 L263.2,144.9 L275.1,146.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M275.1,146.7 L287.0,148.5 L298.9,150.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M298.9,150.3 L310.8,152.1 L322.7,153.9 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M322.7,153.9 L334.7,155.7 L346.6,157.5 L358.5,159.3 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M358.5,159.3 L370.5,161.1 L382.4,162.9 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M382.4,162.9 L394.3,164.7 L406.2,166.5 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M406.2,166.5 L418.2,168.3 L430.1,170.1 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M430.1,170.1 L442.0,171.9 \" stroke=\"rgb( 6, 255, 249)\"/>\t<path d=\"M153.7,134.1 L165.7,135.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M165.7,135.9 L177.6,137.7 L189.5,139.5 L201.4,141.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M201.4,141.3 L213.4,143.1 L225.3,144.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M225.3,144.9 L237.2,146.7 L249.2,148.5 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M249.2,148.5 L261.1,150.3 L273.0,152.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M273.0,152.1 L284.8,153.9 L296.8,155.7 L308.7,157.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M308.7,157.5 L320.6,159.3 L332.6,161.1 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M332.6,161.1 L344.5,162.9 L356.4,164.7 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M356.4,164.7 L368.3,166.5 L380.3,168.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M380.3,168.3 L392.2,170.1 L404.1,171.9 L416.1,173.7 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M416.1,173.7 L428.0,175.5 L439.9,177.3 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M151.6,139.5 L163.6,141.3 L175.5,143.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M175.5,143.1 L187.4,144.9 L199.3,146.7 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M199.3,146.7 L211.3,148.5 L223.2,150.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M223.2,150.3 L235.1,152.1 L247.1,153.9 L259.0,155.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M259.0,155.7 L270.9,157.5 L282.7,159.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M282.7,159.3 L294.7,161.1 L306.6,162.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M306.6,162.9 L318.5,164.7 L330.5,166.5 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M330.5,166.5 L342.4,168.3 L354.3,170.1 L366.2,171.9 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M366.2,171.9 L378.2,173.7 L390.1,175.5 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M390.1,175.5 L402.0,177.3 L414.0,179.1 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M414.0,179.1 L425.9,180.9 L437.8,182.6 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M149.5,144.9 L161.5,146.7 L173.4,148.5 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M173.4,148.5 L185.3,150.3 L197.2,152.1 L209.2,153.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M209.2,153.9 L221.1,155.7 L233.0,157.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M233.0,157.5 L245.0,159.3 L256.9,161.1 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M256.9,161.1 L268.8,162.9 L280.6,164.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M280.6,164.7 L292.6,166.5 L304.5,168.3 L316.4,170.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M316.4,170.1 L328.4,171.8 L340.3,173.6 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M340.3,173.6 L352.2,175.4 L364.1,177.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M364.1,177.2 L376.1,179.0 L388.0,180.8 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M388.0,180.8 L399.9,182.6 L411.9,184.4 L423.8,186.2 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M423.8,186.2 L435.7,188.0 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M147.4,150.3 L159.4,152.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M159.4,152.1 L171.3,153.9 L183.2,155.7 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M183.2,155.7 L195.1,157.5 L207.1,159.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M207.1,159.3 L219.0,161.1 L230.9,162.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M230.9,162.8 L242.9,164.6 L254.8,166.4 L266.7,168.2 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M266.7,168.2 L278.6,170.0 L290.5,171.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M290.5,171.8 L302.4,173.6 L314.3,175.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M314.3,175.4 L326.3,177.2 L338.2,179.0 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M338.2,179.0 L350.1,180.8 L362.0,182.6 L374.0,184.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M374.0,184.4 L385.9,186.2 L397.8,188.0 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M397.8,188.0 L409.8,189.8 L421.7,191.6 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M421.7,191.6 L433.6,193.4 \" stroke=\"rgb( 22, 255, 233)\"/>\t<path d=\"M145.3,155.6 L157.2,157.4 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M157.2,157.4 L169.2,159.2 L181.1,161.0 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M181.1,161.0 L193.0,162.8 L205.0,164.6 L216.9,166.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M216.9,166.4 L228.8,168.2 L240.7,170.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M240.7,170.0 L252.7,171.8 L264.6,173.6 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M264.6,173.6 L276.5,175.4 L288.4,177.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M288.4,177.2 L300.3,179.0 L312.2,180.8 L324.1,182.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M324.1,182.6 L336.1,184.4 L348.0,186.2 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M348.0,186.2 L359.9,188.0 L371.9,189.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M371.9,189.8 L383.8,191.6 L395.7,193.4 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M395.7,193.4 L407.6,195.2 L419.6,197.0 L431.5,198.8 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M143.2,161.0 L155.1,162.8 L167.1,164.6 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M167.1,164.6 L179.0,166.4 L190.9,168.2 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M190.9,168.2 L202.9,170.0 L214.8,171.8 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M214.8,171.8 L226.7,173.6 L238.6,175.4 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M238.6,175.4 L250.6,177.2 L262.5,179.0 L274.4,180.8 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M274.4,180.8 L286.3,182.6 L298.2,184.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M298.2,184.4 L310.1,186.2 L322.0,188.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M322.0,188.0 L334.0,189.8 L345.9,191.6 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M345.9,191.6 L357.8,193.4 L369.8,195.2 L381.7,197.0 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M381.7,197.0 L393.6,198.8 L405.5,200.6 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M405.5,200.6 L417.5,202.3 L429.4,204.0 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M141.1,166.4 L153.0,168.2 L165.0,170.0 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M165.0,170.0 L176.9,171.8 L188.8,173.6 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M188.8,173.6 L200.8,175.4 L212.7,177.2 L224.6,179.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M224.6,179.0 L236.5,180.8 L248.5,182.6 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M248.5,182.6 L260.4,184.4 L272.3,186.2 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M272.3,186.2 L284.2,188.0 L296.1,189.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M296.1,189.8 L308.0,191.6 L319.9,193.3 L331.9,195.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M331.9,195.1 L343.8,196.9 L355.7,198.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M355.7,198.7 L367.7,200.5 L379.6,202.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M379.6,202.2 L391.5,204.0 L403.4,205.8 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M403.4,205.8 L415.4,207.6 L427.3,209.4 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M139.0,171.8 L150.9,173.6 L162.9,175.4 L174.8,177.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M174.8,177.2 L186.7,179.0 L198.7,180.8 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M198.7,180.8 L210.6,182.6 L222.5,184.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M222.5,184.3 L234.4,186.1 L246.4,187.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M246.4,187.9 L258.3,189.7 L270.2,191.5 L282.1,193.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M282.1,193.3 L294.0,195.1 L305.9,196.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M305.9,196.9 L317.8,198.7 L329.8,200.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M329.8,200.5 L341.7,202.2 L353.6,204.0 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M353.6,204.0 L365.6,205.8 L377.5,207.6 L389.4,209.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M389.4,209.4 L401.3,211.2 L413.3,213.0 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M413.3,213.0 L425.2,214.8 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M136.9,177.1 L148.8,178.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M148.8,178.9 L160.8,180.7 L172.7,182.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M172.7,182.5 L184.6,184.3 L196.6,186.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M196.6,186.1 L208.5,187.9 L220.4,189.7 L232.3,191.5 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M232.3,191.5 L244.3,193.3 L256.2,195.1 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M256.2,195.1 L268.1,196.9 L280.0,198.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M280.0,198.7 L291.9,200.5 L303.8,202.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M303.8,202.2 L315.7,204.0 L327.7,205.8 L339.6,207.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M339.6,207.6 L351.5,209.4 L363.4,211.2 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M363.4,211.2 L375.4,213.0 L387.3,214.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M387.3,214.8 L399.2,216.6 L411.2,218.4 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M411.2,218.4 L423.1,220.2 \" stroke=\"rgb( 38, 255, 217)\"/>\t<path d=\"M134.8,182.5 L146.7,184.3 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M146.7,184.3 L158.7,186.1 L170.6,187.9 L182.5,189.7 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M182.5,189.7 L194.4,191.5 L206.4,193.3 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M206.4,193.3 L218.3,195.1 L230.2,196.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M230.2,196.9 L242.2,198.7 L254.1,200.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M254.1,200.5 L266.0,202.2 L277.9,204.0 L289.8,205.8 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M289.8,205.8 L301.7,207.6 L313.6,209.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M313.6,209.4 L325.6,211.2 L337.5,213.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M337.5,213.0 L349.4,214.8 L361.3,216.6 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M361.3,216.6 L373.3,218.4 L385.2,220.2 L397.1,222.0 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M397.1,222.0 L409.1,223.8 L421.0,225.5 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M132.7,187.9 L144.6,189.7 L156.6,191.5 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M156.6,191.5 L168.5,193.3 L180.4,195.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M180.4,195.1 L192.3,196.9 L204.3,198.7 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M204.3,198.7 L216.2,200.5 L228.1,202.2 L240.1,204.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M240.1,204.0 L252.0,205.8 L263.9,207.6 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M263.9,207.6 L275.8,209.4 L287.7,211.2 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M287.7,211.2 L299.6,213.0 L311.5,214.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M311.5,214.7 L323.5,216.5 L335.4,218.3 L347.3,220.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M347.3,220.1 L359.2,221.9 L371.2,223.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M371.2,223.7 L383.1,225.5 L395.0,227.3 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M395.0,227.3 L407.0,229.1 L418.9,230.9 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M130.6,193.3 L142.5,195.1 L154.5,196.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M154.5,196.9 L166.4,198.7 L178.3,200.5 L190.2,202.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M190.2,202.2 L202.2,204.0 L214.1,205.7 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M214.1,205.7 L226.0,207.5 L238.0,209.3 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M238.0,209.3 L249.9,211.1 L261.8,212.9 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M261.8,212.9 L273.7,214.7 L285.6,216.5 L297.5,218.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M297.5,218.3 L309.4,220.1 L321.4,221.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M321.4,221.9 L333.3,223.7 L345.2,225.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M345.2,225.5 L357.1,227.3 L369.1,229.1 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M369.1,229.1 L381.0,230.9 L392.9,232.7 L404.9,234.5 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M404.9,234.5 L416.8,236.3 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M128.5,198.6 L140.4,200.4 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M140.4,200.4 L152.4,202.1 L164.3,203.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M164.3,203.9 L176.2,205.7 L188.1,207.5 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M188.1,207.5 L200.1,209.3 L212.0,211.1 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M212.0,211.1 L223.9,212.9 L235.9,214.7 L247.8,216.5 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M247.8,216.5 L259.7,218.3 L271.6,220.1 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M271.6,220.1 L283.5,221.9 L295.4,223.7 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M295.4,223.7 L307.3,225.5 L319.3,227.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M319.3,227.3 L331.2,229.1 L343.1,230.9 L355.0,232.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M355.0,232.7 L367.0,234.5 L378.9,236.3 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M378.9,236.3 L390.8,238.1 L402.8,239.9 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M402.8,239.9 L414.7,241.7 \" stroke=\"rgb( 55, 255, 200)\"/>\t<path d=\"M126.4,203.9 L138.3,205.7 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M138.3,205.7 L150.2,207.5 L162.2,209.3 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M162.2,209.3 L174.1,211.1 L186.0,212.9 L198.0,214.7 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M198.0,214.7 L209.9,216.5 L221.8,218.3 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M221.8,218.3 L233.7,220.1 L245.7,221.9 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M245.7,221.9 L257.6,223.7 L269.5,225.5 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M269.5,225.5 L281.4,227.3 L293.3,229.1 L305.2,230.9 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M305.2,230.9 L317.1,232.7 L329.1,234.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M329.1,234.5 L341.0,236.3 L352.9,238.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M352.9,238.1 L364.9,239.9 L376.8,241.7 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M376.8,241.7 L388.7,243.5 L400.6,245.3 L412.6,247.0 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M124.3,209.3 L136.2,211.1 L148.1,212.9 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M148.1,212.9 L160.1,214.7 L172.0,216.5 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M172.0,216.5 L183.9,218.3 L195.9,220.1 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M195.9,220.1 L207.8,221.9 L219.7,223.7 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M219.7,223.7 L231.6,225.5 L243.6,227.3 L255.5,229.1 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M255.5,229.1 L267.4,230.9 L279.4,232.7 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M279.4,232.7 L291.2,234.5 L303.1,236.2 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M303.1,236.2 L315.0,238.0 L327.0,239.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M327.0,239.8 L338.9,241.6 L350.8,243.4 L362.8,245.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M362.8,245.2 L374.7,247.0 L386.6,248.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M386.6,248.8 L398.5,250.6 L410.5,252.4 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M122.2,214.7 L134.1,216.5 L146.0,218.3 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M146.0,218.3 L158.0,220.1 L169.9,221.9 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M169.9,221.9 L181.8,223.7 L193.8,225.5 L205.7,227.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M205.7,227.2 L217.6,229.0 L229.5,230.8 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M229.5,230.8 L241.5,232.6 L253.4,234.4 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M253.4,234.4 L265.3,236.2 L277.3,238.0 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M277.3,238.0 L289.1,239.8 L301.0,241.6 L312.9,243.4 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M312.9,243.4 L324.9,245.2 L336.8,247.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M336.8,247.0 L348.7,248.8 L360.7,250.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M360.7,250.6 L372.6,252.4 L384.5,254.2 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M384.5,254.2 L396.4,256.0 L408.4,257.8 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M120.1,220.0 L132.0,221.8 L143.9,223.6 L155.9,225.4 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M155.9,225.4 L167.8,227.2 L179.7,229.0 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M179.7,229.0 L191.7,230.8 L203.6,232.6 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M203.6,232.6 L215.5,234.4 L227.4,236.2 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M227.4,236.2 L239.4,238.0 L251.3,239.8 L263.2,241.6 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M263.2,241.6 L275.2,243.4 L287.0,245.2 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M287.0,245.2 L298.9,247.0 L310.8,248.8 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M310.8,248.8 L322.8,250.6 L334.7,252.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M334.7,252.4 L346.6,254.2 L358.6,256.0 L370.5,257.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M370.5,257.8 L382.4,259.6 L394.3,261.4 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M394.3,261.4 L406.3,263.2 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M118.0,225.4 L129.9,227.2 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M129.9,227.2 L141.8,229.0 L153.8,230.8 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M153.8,230.8 L165.7,232.6 L177.6,234.4 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M177.6,234.4 L189.5,236.2 L201.5,238.0 L213.4,239.8 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M213.4,239.8 L225.3,241.6 L237.3,243.4 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M237.3,243.4 L249.2,245.2 L261.1,247.0 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M261.1,247.0 L273.0,248.8 L284.9,250.6 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M284.9,250.6 L296.8,252.4 L308.7,254.2 L320.7,256.0 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M320.7,256.0 L332.6,257.8 L344.5,259.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M344.5,259.6 L356.4,261.4 L368.4,263.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M368.4,263.2 L380.3,265.0 L392.2,266.8 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M392.2,266.8 L404.2,268.5 \" stroke=\"rgb( 71, 255, 184)\"/>\t<path d=\"M115.9,230.8 L127.8,232.6 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M127.8,232.6 L139.7,234.4 L151.7,236.2 L163.6,238.0 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M163.6,238.0 L175.5,239.8 L187.4,241.6 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M187.4,241.6 L199.4,243.4 L211.3,245.2 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M211.3,245.2 L223.2,247.0 L235.2,248.8 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M235.2,248.8 L247.1,250.6 L259.0,252.4 L270.9,254.2 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M270.9,254.2 L282.8,256.0 L294.7,257.8 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M294.7,257.8 L306.6,259.5 L318.6,261.3 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M318.6,261.3 L330.5,263.1 L342.4,264.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M342.4,264.9 L354.3,266.7 L366.3,268.5 L378.2,270.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M378.2,270.3 L390.1,272.1 L402.1,273.9 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M113.8,236.2 L125.7,238.0 L137.6,239.8 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M137.6,239.8 L149.6,241.6 L161.5,243.4 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M161.5,243.4 L173.4,245.2 L185.3,247.0 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M185.3,247.0 L197.3,248.7 L209.2,250.5 L221.1,252.3 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M221.1,252.3 L233.1,254.1 L245.0,255.9 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M245.0,255.9 L256.9,257.7 L268.8,259.5 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M268.8,259.5 L280.7,261.3 L292.6,263.1 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M292.6,263.1 L304.5,264.9 L316.5,266.7 L328.4,268.5 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M328.4,268.5 L340.3,270.3 L352.2,272.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M352.2,272.1 L364.2,273.9 L376.1,275.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M376.1,275.7 L388.0,277.5 L400.0,279.3 \" stroke=\"rgb( 87, 255, 168)\"/>\t<path d=\"M111.7,241.5 L123.6,243.3 L135.5,245.1 \" stroke=\"rgb(249, 255, 6)\"/>\t<path d=\"M135.5,245.1 L147.5,246.9 L159.4,248.7 L171.3,250.5 \" stroke=\"rgb(233, 255, 22)\"/>\t<path d=\"M171.3,250.5 L183.2,252.3 L195.2,254.1 \" stroke=\"rgb(217, 255, 38)\"/>\t<path d=\"M195.2,254.1 L207.1,255.9 L219.0,257.7 \" stroke=\"rgb(200, 255, 55)\"/>\t<path d=\"M219.0,257.7 L231.0,259.5 L242.9,261.3 \" stroke=\"rgb(184, 255, 71)\"/>\t<path d=\"M242.9,261.3 L254.8,263.1 L266.7,264.9 L278.7,266.7 \" stroke=\"rgb(168, 255, 87)\"/>\t<path d=\"M278.7,266.7 L290.5,268.5 L302.4,270.3 \" stroke=\"rgb(152, 255, 103)\"/>\t<path d=\"M302.4,270.3 L314.4,272.1 L326.3,273.9 \" stroke=\"rgb(136, 255, 119)\"/>\t<path d=\"M326.3,273.9 L338.2,275.7 L350.1,277.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M350.1,277.5 L362.1,279.3 L374.0,281.1 L385.9,282.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M385.9,282.9 L397.9,284.7 \" stroke=\"rgb( 87, 255, 168)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_3a\"><title>gnuplot_plot_3a</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M162.1,119.9 L160.0,125.6 L157.9,131.3 L155.8,137.0 L153.7,142.7 L151.6,148.3 L149.5,154.0 L147.4,159.7 L145.3,165.4 L143.2,171.1 L141.1,176.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M141.1,176.8 L139.0,182.5 L136.9,188.1 L134.8,193.8 L132.7,199.5 L130.6,205.1 L128.5,210.8 L126.4,216.5 L124.3,222.2 L122.2,227.9 L120.1,233.5 L118.0,239.2 L115.9,244.9 L113.8,250.6 L111.7,256.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M174.1,121.0 L172.0,126.6 L169.9,132.3 L167.8,138.0 L165.7,143.7 L163.6,149.4 L161.5,155.1 L159.4,160.8 L157.2,166.5 L155.1,172.1 L153.0,177.8 L150.9,183.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M150.9,183.5 L148.8,189.2 L146.7,194.9 L144.6,200.6 L142.5,206.2 L140.4,211.9 L138.3,217.5 L136.2,223.2 L134.1,228.9 L132.0,234.6 L129.9,240.3 L127.8,246.0 L125.7,251.7 L123.6,257.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M186.0,122.0 L183.9,127.7 L181.8,133.4 L179.7,139.1 L177.6,144.8 L175.5,150.4 L173.4,156.1 L171.3,161.8 L169.2,167.5 L167.1,173.2 L165.0,178.9 L162.9,184.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M162.9,184.6 L160.8,190.3 L158.7,195.9 L156.6,201.5 L154.5,207.2 L152.4,212.9 L150.2,218.6 L148.1,224.3 L146.0,230.0 L143.9,235.7 L141.8,241.3 L139.7,247.0 L137.6,252.7 L135.5,258.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M197.9,123.1 L195.8,128.8 L193.7,134.4 L191.6,140.1 L189.5,145.8 L187.4,151.5 L185.3,157.2 L183.2,162.9 L181.1,168.6 L179.0,174.3 L176.9,179.9 L174.8,185.6 L172.7,191.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M172.7,191.3 L170.6,197.0 L168.5,202.6 L166.4,208.3 L164.3,214.0 L162.2,219.7 L160.1,225.3 L158.0,231.0 L155.9,236.7 L153.8,242.4 L151.7,248.1 L149.6,253.8 L147.5,259.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M209.9,124.1 L207.8,129.8 L205.7,135.5 L203.6,141.2 L201.4,146.9 L199.3,152.6 L197.2,158.2 L195.1,163.9 L193.0,169.6 L190.9,175.3 L188.8,181.0 L186.7,186.7 L184.6,192.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M184.6,192.4 L182.5,198.1 L180.4,203.6 L178.3,209.3 L176.2,215.0 L174.1,220.7 L172.0,226.4 L169.9,232.1 L167.8,237.8 L165.7,243.5 L163.6,249.1 L161.5,254.8 L159.4,260.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M221.8,125.2 L219.7,130.9 L217.6,136.6 L215.5,142.2 L213.4,147.9 L211.3,153.6 L209.2,159.3 L207.1,165.0 L205.0,170.7 L202.9,176.4 L200.8,182.1 L198.7,187.7 L196.6,193.4 L194.4,199.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M194.4,199.1 L192.3,204.7 L190.2,210.4 L188.1,216.1 L186.0,221.8 L183.9,227.5 L181.8,233.1 L179.7,238.8 L177.6,244.5 L175.5,250.2 L173.4,255.9 L171.3,261.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M233.7,126.2 L231.6,131.9 L229.5,137.6 L227.4,143.3 L225.3,149.0 L223.2,154.7 L221.1,160.4 L219.0,166.0 L216.9,171.7 L214.8,177.4 L212.7,183.1 L210.6,188.8 L208.5,194.5 L206.4,200.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M206.4,200.2 L204.3,205.8 L202.2,211.4 L200.1,217.1 L198.0,222.8 L195.9,228.5 L193.8,234.2 L191.7,239.9 L189.5,245.6 L187.4,251.3 L185.3,256.9 L183.2,262.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M245.6,127.3 L243.5,133.0 L241.4,138.7 L239.3,144.4 L237.2,150.0 L235.1,155.7 L233.0,161.4 L230.9,167.1 L228.8,172.8 L226.7,178.5 L224.6,184.2 L222.5,189.9 L220.4,195.5 L218.3,201.1 L216.2,206.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M216.2,206.8 L214.1,212.5 L212.0,218.2 L209.9,223.9 L207.8,229.6 L205.7,235.2 L203.6,240.9 L201.5,246.6 L199.4,252.3 L197.3,258.0 L195.2,263.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M257.6,128.3 L255.5,134.0 L253.4,139.7 L251.3,145.4 L249.2,151.1 L247.1,156.8 L245.0,162.5 L242.9,168.2 L240.7,173.8 L238.6,179.5 L236.5,185.2 L234.4,190.9 L232.3,196.6 L230.2,202.2 L228.1,207.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M228.1,207.9 L226.0,213.6 L223.9,219.2 L221.8,224.9 L219.7,230.6 L217.6,236.3 L215.5,242.0 L213.4,247.7 L211.3,253.4 L209.2,259.1 L207.1,264.7 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M269.5,129.4 L267.4,135.1 L265.3,140.8 L263.2,146.5 L261.1,152.2 L259.0,157.8 L256.9,163.5 L254.8,169.2 L252.7,174.9 L250.6,180.6 L248.5,186.3 L246.4,192.0 L244.3,197.6 L242.2,203.2 L240.1,208.9 L238.0,214.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M238.0,214.6 L235.9,220.3 L233.7,226.0 L231.6,231.7 L229.5,237.4 L227.4,243.0 L225.3,248.7 L223.2,254.4 L221.1,260.1 L219.0,265.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M281.3,130.5 L279.3,136.1 L277.2,141.8 L275.1,147.5 L273.0,153.2 L270.9,158.9 L268.8,164.6 L266.7,170.3 L264.6,176.0 L262.5,181.6 L260.4,187.3 L258.3,193.0 L256.2,198.7 L254.1,204.3 L252.0,210.0 L249.9,215.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M249.9,215.7 L247.8,221.4 L245.7,227.0 L243.6,232.7 L241.5,238.4 L239.4,244.1 L237.3,249.8 L235.2,255.5 L233.1,261.2 L231.0,266.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M293.3,131.5 L291.2,137.2 L289.1,142.9 L287.0,148.6 L284.8,154.3 L282.7,159.9 L280.6,165.6 L278.6,171.3 L276.5,177.0 L274.4,182.7 L272.3,188.4 L270.2,194.1 L268.1,199.8 L266.0,205.3 L263.9,211.0 L261.8,216.7 L259.7,222.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M259.7,222.4 L257.6,228.1 L255.5,233.8 L253.4,239.5 L251.3,245.2 L249.2,250.8 L247.1,256.5 L245.0,262.2 L242.9,267.9 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M305.2,132.6 L303.1,138.3 L301.0,143.9 L298.9,149.6 L296.8,155.3 L294.7,161.0 L292.6,166.7 L290.5,172.4 L288.4,178.1 L286.3,183.8 L284.2,189.4 L282.1,195.1 L280.0,200.8 L277.9,206.4 L275.8,212.1 L273.7,217.8 L271.6,223.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M271.6,223.5 L269.5,229.2 L267.4,234.8 L265.3,240.5 L263.2,246.2 L261.1,251.9 L259.0,257.6 L256.9,263.3 L254.8,269.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M317.1,133.6 L315.0,139.3 L312.9,145.0 L310.8,150.7 L308.7,156.4 L306.6,162.1 L304.5,167.7 L302.4,173.4 L300.3,179.1 L298.2,184.8 L296.1,190.5 L294.0,196.2 L291.9,201.8 L289.8,207.5 L287.7,213.1 L285.6,218.8 L283.5,224.5 L281.4,230.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M281.4,230.2 L279.4,235.9 L277.3,241.6 L275.2,247.3 L273.0,253.0 L270.9,258.6 L268.8,264.3 L266.7,270.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M329.0,134.7 L326.9,140.4 L324.8,146.1 L322.7,151.7 L320.6,157.4 L318.5,163.1 L316.4,168.8 L314.3,174.5 L312.2,180.2 L310.1,185.9 L308.0,191.6 L305.9,197.2 L303.8,202.8 L301.7,208.5 L299.6,214.2 L297.5,219.9 L295.4,225.6 L293.3,231.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M293.3,231.3 L291.2,237.0 L289.1,242.6 L287.0,248.3 L284.9,254.0 L282.8,259.7 L280.7,265.4 L278.7,271.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M341.0,135.7 L338.9,141.4 L336.8,147.1 L334.7,152.8 L332.6,158.5 L330.5,164.2 L328.4,169.9 L326.3,175.5 L324.1,181.2 L322.0,186.9 L319.9,192.6 L317.8,198.3 L315.7,203.9 L313.6,209.6 L311.5,215.3 L309.4,220.9 L307.3,226.6 L305.2,232.3 L303.1,238.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M303.1,238.0 L301.0,243.7 L298.9,249.4 L296.8,255.1 L294.7,260.8 L292.6,266.4 L290.5,272.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M352.9,136.8 L350.8,142.5 L348.7,148.2 L346.6,153.9 L344.5,159.5 L342.4,165.2 L340.3,170.9 L338.2,176.6 L336.1,182.3 L334.0,188.0 L331.9,193.7 L329.8,199.4 L327.7,204.9 L325.6,210.6 L323.5,216.3 L321.4,222.0 L319.3,227.7 L317.1,233.4 L315.0,239.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M315.0,239.1 L312.9,244.7 L310.8,250.4 L308.7,256.1 L306.6,261.8 L304.5,267.5 L302.4,273.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M364.8,137.8 L362.7,143.5 L360.6,149.2 L358.5,154.9 L356.4,160.6 L354.3,166.3 L352.2,172.0 L350.1,177.7 L348.0,183.3 L345.9,189.0 L343.8,194.7 L341.7,200.4 L339.6,206.0 L337.5,211.7 L335.4,217.4 L333.3,223.1 L331.2,228.7 L329.1,234.4 L327.0,240.1 L324.9,245.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M324.9,245.8 L322.8,251.5 L320.7,257.2 L318.6,262.9 L316.5,268.6 L314.4,274.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M376.8,138.9 L374.7,144.6 L372.6,150.3 L370.5,156.0 L368.3,161.7 L366.2,167.3 L364.1,173.0 L362.0,178.7 L359.9,184.4 L357.8,190.1 L355.7,195.8 L353.6,201.4 L351.5,207.0 L349.4,212.7 L347.3,218.4 L345.2,224.1 L343.1,229.8 L341.0,235.5 L338.9,241.2 L336.8,246.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M336.8,246.9 L334.7,252.5 L332.6,258.2 L330.5,263.9 L328.4,269.6 L326.3,275.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M388.7,140.0 L386.6,145.6 L384.5,151.3 L382.4,157.0 L380.3,162.7 L378.2,168.4 L376.1,174.1 L374.0,179.8 L371.9,185.5 L369.8,191.1 L367.7,196.8 L365.6,202.4 L363.4,208.1 L361.3,213.8 L359.2,219.5 L357.1,225.2 L355.0,230.9 L352.9,236.5 L350.8,242.2 L348.7,247.9 L346.6,253.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M346.6,253.6 L344.5,259.3 L342.4,265.0 L340.3,270.7 L338.2,276.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M400.6,141.0 L398.5,146.7 L396.4,152.4 L394.3,158.1 L392.2,163.8 L390.1,169.4 L388.0,175.1 L385.9,180.8 L383.8,186.5 L381.7,192.2 L379.6,197.9 L377.5,203.5 L375.4,209.2 L373.3,214.8 L371.2,220.5 L369.1,226.2 L367.0,231.9 L364.9,237.6 L362.8,243.3 L360.7,249.0 L358.6,254.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M358.6,254.7 L356.4,260.3 L354.3,266.0 L352.2,271.7 L350.1,277.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M412.5,142.1 L410.4,147.8 L408.3,153.4 L406.2,159.1 L404.1,164.8 L402.0,170.5 L399.9,176.2 L397.8,181.9 L395.7,187.6 L393.6,193.3 L391.5,198.9 L389.4,204.5 L387.3,210.2 L385.2,215.9 L383.1,221.6 L381.0,227.3 L378.9,233.0 L376.8,238.7 L374.7,244.3 L372.6,250.0 L370.5,255.7 L368.4,261.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M368.4,261.4 L366.3,267.1 L364.2,272.8 L362.1,278.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M424.5,143.1 L422.4,148.8 L420.3,154.5 L418.2,160.2 L416.1,165.9 L414.0,171.6 L411.9,177.2 L409.8,182.9 L407.6,188.6 L405.5,194.3 L403.4,200.0 L401.3,205.6 L399.2,211.3 L397.1,217.0 L395.0,222.6 L392.9,228.3 L390.8,234.0 L388.7,239.7 L386.6,245.4 L384.5,251.1 L382.4,256.8 L380.3,262.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M380.3,262.5 L378.2,268.1 L376.1,273.8 L374.0,279.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M436.4,144.2 L434.3,149.9 L432.2,155.6 L430.1,161.2 L428.0,166.9 L425.9,172.6 L423.8,178.3 L421.7,184.0 L419.6,189.7 L417.5,195.4 L415.4,201.0 L413.3,206.6 L411.2,212.3 L409.1,218.0 L407.0,223.7 L404.9,229.4 L402.8,235.1 L400.6,240.8 L398.5,246.5 L396.4,252.1 L394.3,257.8 L392.2,263.5 L390.1,269.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M390.1,269.2 L388.0,274.9 L385.9,280.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M448.3,145.2 L446.2,150.9 L444.1,156.6 L442.0,162.3 L439.9,168.0 L437.8,173.7 L435.7,179.4 L433.6,185.0 L431.5,190.7 L429.4,196.4 L427.3,202.0 L425.2,207.7 L423.1,213.4 L421.0,219.1 L418.9,224.8 L416.8,230.4 L414.7,236.1 L412.6,241.8 L410.5,247.5 L408.4,253.2 L406.3,258.9 L404.2,264.6 L402.1,270.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M402.1,270.3 L400.0,275.9 L397.9,281.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M162.1,119.9 L174.1,121.0 L186.0,122.0 L197.9,123.1 L209.9,124.1 L221.8,125.2 L233.7,126.2 L245.6,127.3 L257.6,128.3 L269.5,129.4 L281.3,130.5 L293.3,131.5 L305.2,132.6 L317.1,133.6 L329.0,134.7 L341.0,135.7 L352.9,136.8 L364.8,137.8 L376.8,138.9 L388.7,140.0 L400.6,141.0 L412.5,142.1 L424.5,143.1 L436.4,144.2 L448.3,145.2 M160.0,125.6 L172.0,126.6 L183.9,127.7 L195.8,128.8 L207.8,129.8 L219.7,130.9 L231.6,131.9 L243.5,133.0 L255.5,134.0 L267.4,135.1 L279.3,136.1 L291.2,137.2 L303.1,138.3 L315.0,139.3 L326.9,140.4 L338.9,141.4 L350.8,142.5 L362.7,143.5 L374.7,144.6 L386.6,145.6 L398.5,146.7 L410.4,147.8 L422.4,148.8 L434.3,149.9 L446.2,150.9 M157.9,131.3 L169.9,132.3 L181.8,133.4 L193.7,134.4 L205.7,135.5 L217.6,136.6 L229.5,137.6 L241.4,138.7 L253.4,139.7 L265.3,140.8 L277.2,141.8 L289.1,142.9 L301.0,143.9 L312.9,145.0 L324.8,146.1 L336.8,147.1 L348.7,148.2 L360.6,149.2 L372.6,150.3 L384.5,151.3 L396.4,152.4 L408.3,153.4 L420.3,154.5 L432.2,155.6 L444.1,156.6 M155.8,137.0 L167.8,138.0 L179.7,139.1 L191.6,140.1 L203.6,141.2 L215.5,142.2 L227.4,143.3 L239.3,144.4 L251.3,145.4 L263.2,146.5 L275.1,147.5 L287.0,148.6 L298.9,149.6 L310.8,150.7 L322.7,151.7 L334.7,152.8 L346.6,153.9 L358.5,154.9 L370.5,156.0 L382.4,157.0 L394.3,158.1 L406.2,159.1 L418.2,160.2 L430.1,161.2 L442.0,162.3 M153.7,142.7 L165.7,143.7 L177.6,144.8 L189.5,145.8 L201.4,146.9 L213.4,147.9 L225.3,149.0 L237.2,150.0 L249.2,151.1 L261.1,152.2 L273.0,153.2 L284.8,154.3 L296.8,155.3 L308.7,156.4 L320.6,157.4 L332.6,158.5 L344.5,159.5 L356.4,160.6 L368.3,161.7 L380.3,162.7 L392.2,163.8 L404.1,164.8 L416.1,165.9 L428.0,166.9 L439.9,168.0 M151.6,148.3 L163.6,149.4 L175.5,150.4 L187.4,151.5 L199.3,152.6 L211.3,153.6 L223.2,154.7 L235.1,155.7 L247.1,156.8 L259.0,157.8 L270.9,158.9 L282.7,159.9 L294.7,161.0 L306.6,162.1 L318.5,163.1 L330.5,164.2 L342.4,165.2 L354.3,166.3 L366.2,167.3 L378.2,168.4 L390.1,169.4 L402.0,170.5 L414.0,171.6 L425.9,172.6 L437.8,173.7 M149.5,154.0 L161.5,155.1 L173.4,156.1 L185.3,157.2 L197.2,158.2 L209.2,159.3 L221.1,160.4 L233.0,161.4 L245.0,162.5 L256.9,163.5 L268.8,164.6 L280.6,165.6 L292.6,166.7 L304.5,167.7 L316.4,168.8 L328.4,169.9 L340.3,170.9 L352.2,172.0 L364.1,173.0 L376.1,174.1 L388.0,175.1 L399.9,176.2 L411.9,177.2 L423.8,178.3 L435.7,179.4 M147.4,159.7 L159.4,160.8 L171.3,161.8 L183.2,162.9 L195.1,163.9 L207.1,165.0 L219.0,166.0 L230.9,167.1 L242.9,168.2 L254.8,169.2 L266.7,170.3 L278.6,171.3 L290.5,172.4 L302.4,173.4 L314.3,174.5 L326.3,175.5 L338.2,176.6 L350.1,177.7 L362.0,178.7 L374.0,179.8 L385.9,180.8 L397.8,181.9 L409.8,182.9 L421.7,184.0 L433.6,185.0 M145.3,165.4 L157.2,166.5 L169.2,167.5 L181.1,168.6 L193.0,169.6 L205.0,170.7 L216.9,171.7 L228.8,172.8 L240.7,173.8 L252.7,174.9 L264.6,176.0 L276.5,177.0 L288.4,178.1 L300.3,179.1 L312.2,180.2 L324.1,181.2 L336.1,182.3 L348.0,183.3 L359.9,184.4 L371.9,185.5 L383.8,186.5 L395.7,187.6 L407.6,188.6 L419.6,189.7 L431.5,190.7 M143.2,171.1 L155.1,172.1 L167.1,173.2 L179.0,174.3 L190.9,175.3 L202.9,176.4 L214.8,177.4 L226.7,178.5 L238.6,179.5 L250.6,180.6 L262.5,181.6 L274.4,182.7 L286.3,183.8 L298.2,184.8 L310.1,185.9 L322.0,186.9 L334.0,188.0 L345.9,189.0 L357.8,190.1 L369.8,191.1 L381.7,192.2 L393.6,193.3 L405.5,194.3 L417.5,195.4 L429.4,196.4 M141.1,176.8 L153.0,177.8 L165.0,178.9 L176.9,179.9 L188.8,181.0 L200.8,182.1 L212.7,183.1 L224.6,184.2 L236.5,185.2 L248.5,186.3 L260.4,187.3 L272.3,188.4 L284.2,189.4 L296.1,190.5 L308.0,191.6 L319.9,192.6 L331.9,193.7 L343.8,194.7 L355.7,195.8 L367.7,196.8 L379.6,197.9 L391.5,198.9 L403.4,200.0 L415.4,201.0 L427.3,202.0 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M139.0,182.5 L150.9,183.5 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M150.9,183.5 L162.9,184.6 L174.8,185.6 L186.7,186.7 L198.7,187.7 L210.6,188.8 L222.5,189.9 L234.4,190.9 L246.4,192.0 L258.3,193.0 L270.2,194.1 L282.1,195.1 L294.0,196.2 L305.9,197.2 L317.8,198.3 L329.8,199.4 L341.7,200.4 L353.6,201.4 L365.6,202.4 L377.5,203.5 L389.4,204.5 L401.3,205.6 L413.3,206.6 L425.2,207.7 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M136.9,188.1 L148.8,189.2 L160.8,190.3 L172.7,191.3 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M172.7,191.3 L184.6,192.4 L196.6,193.4 L208.5,194.5 L220.4,195.5 L232.3,196.6 L244.3,197.6 L256.2,198.7 L268.1,199.8 L280.0,200.8 L291.9,201.8 L303.8,202.8 L315.7,203.9 L327.7,204.9 L339.6,206.0 L351.5,207.0 L363.4,208.1 L375.4,209.2 L387.3,210.2 L399.2,211.3 L411.2,212.3 L423.1,213.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M134.8,193.8 L146.7,194.9 L158.7,195.9 L170.6,197.0 L182.5,198.1 L194.4,199.1 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M194.4,199.1 L206.4,200.2 L218.3,201.1 L230.2,202.2 L242.2,203.2 L254.1,204.3 L266.0,205.3 L277.9,206.4 L289.8,207.5 L301.7,208.5 L313.6,209.6 L325.6,210.6 L337.5,211.7 L349.4,212.7 L361.3,213.8 L373.3,214.8 L385.2,215.9 L397.1,217.0 L409.1,218.0 L421.0,219.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M132.7,199.5 L144.6,200.6 L156.6,201.5 L168.5,202.6 L180.4,203.6 L192.3,204.7 L204.3,205.8 L216.2,206.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M216.2,206.8 L228.1,207.9 L240.1,208.9 L252.0,210.0 L263.9,211.0 L275.8,212.1 L287.7,213.1 L299.6,214.2 L311.5,215.3 L323.5,216.3 L335.4,217.4 L347.3,218.4 L359.2,219.5 L371.2,220.5 L383.1,221.6 L395.0,222.6 L407.0,223.7 L418.9,224.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M130.6,205.1 L142.5,206.2 L154.5,207.2 L166.4,208.3 L178.3,209.3 L190.2,210.4 L202.2,211.4 L214.1,212.5 L226.0,213.6 L238.0,214.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M238.0,214.6 L249.9,215.7 L261.8,216.7 L273.7,217.8 L285.6,218.8 L297.5,219.9 L309.4,220.9 L321.4,222.0 L333.3,223.1 L345.2,224.1 L357.1,225.2 L369.1,226.2 L381.0,227.3 L392.9,228.3 L404.9,229.4 L416.8,230.4 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M128.5,210.8 L140.4,211.9 L152.4,212.9 L164.3,214.0 L176.2,215.0 L188.1,216.1 L200.1,217.1 L212.0,218.2 L223.9,219.2 L235.9,220.3 L247.8,221.4 L259.7,222.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M259.7,222.4 L271.6,223.5 L283.5,224.5 L295.4,225.6 L307.3,226.6 L319.3,227.7 L331.2,228.7 L343.1,229.8 L355.0,230.9 L367.0,231.9 L378.9,233.0 L390.8,234.0 L402.8,235.1 L414.7,236.1 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M126.4,216.5 L138.3,217.5 L150.2,218.6 L162.2,219.7 L174.1,220.7 L186.0,221.8 L198.0,222.8 L209.9,223.9 L221.8,224.9 L233.7,226.0 L245.7,227.0 L257.6,228.1 L269.5,229.2 L281.4,230.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M281.4,230.2 L293.3,231.3 L305.2,232.3 L317.1,233.4 L329.1,234.4 L341.0,235.5 L352.9,236.5 L364.9,237.6 L376.8,238.7 L388.7,239.7 L400.6,240.8 L412.6,241.8 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M124.3,222.2 L136.2,223.2 L148.1,224.3 L160.1,225.3 L172.0,226.4 L183.9,227.5 L195.9,228.5 L207.8,229.6 L219.7,230.6 L231.6,231.7 L243.6,232.7 L255.5,233.8 L267.4,234.8 L279.4,235.9 L291.2,237.0 L303.1,238.0 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M303.1,238.0 L315.0,239.1 L327.0,240.1 L338.9,241.2 L350.8,242.2 L362.8,243.3 L374.7,244.3 L386.6,245.4 L398.5,246.5 L410.5,247.5 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M122.2,227.9 L134.1,228.9 L146.0,230.0 L158.0,231.0 L169.9,232.1 L181.8,233.1 L193.8,234.2 L205.7,235.2 L217.6,236.3 L229.5,237.4 L241.5,238.4 L253.4,239.5 L265.3,240.5 L277.3,241.6 L289.1,242.6 L301.0,243.7 L312.9,244.7 L324.9,245.8 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M324.9,245.8 L336.8,246.9 L348.7,247.9 L360.7,249.0 L372.6,250.0 L384.5,251.1 L396.4,252.1 L408.4,253.2 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M120.1,233.5 L132.0,234.6 L143.9,235.7 L155.9,236.7 L167.8,237.8 L179.7,238.8 L191.7,239.9 L203.6,240.9 L215.5,242.0 L227.4,243.0 L239.4,244.1 L251.3,245.2 L263.2,246.2 L275.2,247.3 L287.0,248.3 L298.9,249.4 L310.8,250.4 L322.8,251.5 L334.7,252.5 L346.6,253.6 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M346.6,253.6 L358.6,254.7 L370.5,255.7 L382.4,256.8 L394.3,257.8 L406.3,258.9 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M118.0,239.2 L129.9,240.3 L141.8,241.3 L153.8,242.4 L165.7,243.5 L177.6,244.5 L189.5,245.6 L201.5,246.6 L213.4,247.7 L225.3,248.7 L237.3,249.8 L249.2,250.8 L261.1,251.9 L273.0,253.0 L284.9,254.0 L296.8,255.1 L308.7,256.1 L320.7,257.2 L332.6,258.2 L344.5,259.3 L356.4,260.3 L368.4,261.4 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M368.4,261.4 L380.3,262.5 L392.2,263.5 L404.2,264.6 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M115.9,244.9 L127.8,246.0 L139.7,247.0 L151.7,248.1 L163.6,249.1 L175.5,250.2 L187.4,251.3 L199.4,252.3 L211.3,253.4 L223.2,254.4 L235.2,255.5 L247.1,256.5 L259.0,257.6 L270.9,258.6 L282.8,259.7 L294.7,260.8 L306.6,261.8 L318.6,262.9 L330.5,263.9 L342.4,265.0 L354.3,266.0 L366.3,267.1 L378.2,268.1 L390.1,269.2 \" stroke=\"rgb(119, 255, 136)\"/>\t<path d=\"M390.1,269.2 L402.1,270.3 \" stroke=\"rgb(103, 255, 152)\"/>\t<path d=\"M113.8,250.6 L125.7,251.7 L137.6,252.7 L149.6,253.8 L161.5,254.8 L173.4,255.9 L185.3,256.9 L197.3,258.0 L209.2,259.1 L221.1,260.1 L233.1,261.2 L245.0,262.2 L256.9,263.3 L268.8,264.3 L280.7,265.4 L292.6,266.4 L304.5,267.5 L316.5,268.6 L328.4,269.6 L340.3,270.7 L352.2,271.7 L364.2,272.8 L376.1,273.8 L388.0,274.9 L400.0,275.9 M111.7,256.3 L123.6,257.4 L135.5,258.4 L147.5,259.5 L159.4,260.5 L171.3,261.6 L183.2,262.6 L195.2,263.7 L207.1,264.7 L219.0,265.8 L231.0,266.9 L242.9,267.9 L254.8,269.0 L266.7,270.0 L278.7,271.1 L290.5,272.1 L302.4,273.2 L314.4,274.2 L326.3,275.3 L338.2,276.4 L350.1,277.4 L362.1,278.5 L374.0,279.5 L385.9,280.6 L397.9,281.6 \" stroke=\"rgb(119, 255, 136)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_4a\"><title>gnuplot_plot_4a</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb(119, 255, 136)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<use color=\"rgb( 0, 0, 255)\" transform=\"translate(285.8,145.0) scale(9.00)\" xlink:href=\"#gpPt5\"/>\n", + "</g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 0, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M448.3,214.2 L397.9,352.6 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M111.7,328.2 L397.9,352.6 \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M397.9,352.6 L397.9,281.6 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(239.0,389.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">x1</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(507.1,296.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">x2</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(59.6,257.9) rotate(-90)\">\n", + "\t\t<text><tspan font-family=\"{}\">x3</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "N=25;\n", + "x11=linspace(-2,2,N);\n", + "x12=linspace(-2,2,N);\n", + "[X11,X12]=meshgrid(x11,x12);\n", + "X13=1-10*X11-2*X12;\n", + "\n", + "x21=linspace(-2,2,N);\n", + "x22=linspace(-2,2,N);\n", + "[X21,X22]=meshgrid(x21,x22);\n", + "X23=1-2*X11-X22;\n", + "\n", + "x31=linspace(-2,2,N);\n", + "x32=linspace(-2,2,N);\n", + "[X31,X32]=meshgrid(x31,x32);\n", + "X33=1/10*(1-X31-2*X32);\n", + "\n", + "mesh(X11,X12,X13);\n", + "hold on;\n", + "mesh(X21,X22,X23)\n", + "mesh(X31,X32,X33)\n", + "x=[10,2, 1;2,1, 1; 1, 2, 10]\\[1;1;1];\n", + "plot3(x(1),x(2),x(3),'o')\n", + "xlabel('x1')\n", + "ylabel('x2')\n", + "zlabel('x3')\n", + "view(10,45)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "After 3 DOF problems, the solutions are described as *hyperplane* intersections. Which are even harder to visualize" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Gauss elimination\n", + "### Solving sets of equations systematically\n", + "\n", + "$\\left[ \\begin{array}{ccc|c}\n", + " & A & & y \\\\\n", + "10 & 2 & 1 & 1\\\\\n", + "2 & 1 & 1 & 1 \\\\\n", + "1 & 2 & 10 & 1\\end{array} \n", + "\\right] $\n", + "\n", + "Ay(2,:)-Ay(1,:)/5 = ([2 1 1 1]-1/5[10 2 1 1])\n", + "\n", + "$\\left[ \\begin{array}{ccc|c}\n", + " & A & & y \\\\\n", + "10 & 2 & 1 & 1\\\\\n", + "0 & 3/5 & 4/5 & 4/5 \\\\\n", + "1 & 2 & 10 & 1\\end{array} \n", + "\\right] $\n", + "\n", + "Ay(3,:)-Ay(1,:)/10 = ([1 2 10 1]-1/10[10 2 1 1])\n", + "\n", + "$\\left[ \\begin{array}{ccc|c}\n", + " & A & & y \\\\\n", + "10 & 2 & 1 & 1\\\\\n", + "0 & 3/5 & 4/5 & 4/5 \\\\\n", + "0 & 1.8 & 9.9 & 0.9\\end{array} \n", + "\\right] $\n", + "\n", + "Ay(3,:)-1.8\\*5/3\\*Ay(2,:) = ([0 1.8 9.9 0.9]-3\\*[0 3/5 4/5 4/5])\n", + "\n", + "$\\left[ \\begin{array}{ccc|c}\n", + " & A & & y \\\\\n", + "10 & 2 & 1 & 1\\\\\n", + "0 & 3/5 & 4/5 & 4/5 \\\\\n", + "0 & 0 & 7.5 & -1.5\\end{array} \n", + "\\right] $\n", + "\n", + "now, $7.5x_{3}=-1.5$ so $x_{3}=-\\frac{1}{5}$\n", + "\n", + "then, $3/5x_{2}+4/5(-1/5)=1$ so $x_{2}=\\frac{8}{5}$\n", + "\n", + "finally, $10x_{1}+2(8/5)+1(-\\frac{1}{5})=1$" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$\n", + "\n", + "$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "2k & -k & 0 & 0 \\\\\n", + "-k & 2k & -k & 0 \\\\\n", + "0 & -k & 2k & -k \\\\\n", + "0 & 0 & -k & k \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k=10; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K1 =\n", + "\n", + " 20.00000 -10.00000 0.00000 0.00000 9.81000\n", + " 0.00000 15.00000 -10.00000 0.00000 24.52500\n", + " 0.00000 -10.00000 20.00000 -10.00000 29.43000\n", + " 0.00000 0.00000 -10.00000 10.00000 39.24000\n", + "\n" + ] + } + ], + "source": [ + "K1=[K y];\n", + "K1(2,:)=K1(1,:)/2+K1(2,:)" + ] + }, + { + "cell_type": "code", + "execution_count": 12, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K2 =\n", + "\n", + " 20.00000 -10.00000 0.00000 0.00000 9.81000\n", + " 0.00000 15.00000 -10.00000 0.00000 24.52500\n", + " 0.00000 0.00000 13.33333 -10.00000 45.78000\n", + " 0.00000 0.00000 -10.00000 10.00000 39.24000\n", + "\n" + ] + } + ], + "source": [ + "K2=K1;\n", + "K2(3,:)=K1(2,:)*2/3+K1(3,:)\n" + ] + }, + { + "cell_type": "code", + "execution_count": 13, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K2 =\n", + "\n", + " 20.00000 -10.00000 0.00000 0.00000 9.81000\n", + " 0.00000 15.00000 -10.00000 0.00000 24.52500\n", + " 0.00000 0.00000 13.33333 -10.00000 45.78000\n", + " 0.00000 0.00000 0.00000 2.50000 73.57500\n", + "\n" + ] + } + ], + "source": [ + "K2(4,:)=-K2(3,:)*K2(4,3)/K2(3,3)+K2(4,:)" + ] + }, + { + "cell_type": "code", + "execution_count": 14, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "x4 = 29.430\n", + "x3 = 25.506\n", + "x2 = 18.639\n", + "x1 = 9.8100\n" + ] + } + ], + "source": [ + "yp=K2(:,5);\n", + "x4=yp(4)/K2(4,4)\n", + "x3=(yp(3)+10*x4)/K2(3,3)\n", + "x2=(yp(2)+10*x3)/K2(2,2)\n", + "x1=(yp(1)+10*x2)/K2(1,1)" + ] + }, + { + "cell_type": "code", + "execution_count": 15, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 9.8100\n", + " 18.6390\n", + " 25.5060\n", + " 29.4300\n", + "\n" + ] + } + ], + "source": [ + "K\\y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Automate Gauss Elimination\n", + "\n", + "We can automate Gauss elimination with a function whose input is A and y:\n", + "\n", + "`x=GaussNaive(A,y)`" + ] + }, + { + "cell_type": "code", + "execution_count": 16, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "x =\n", + "\n", + " 9.8100\n", + " 18.6390\n", + " 25.5060\n", + " 29.4300\n", + "\n" + ] + } + ], + "source": [ + "x=GaussNaive(K,y)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Problem (Diagonal element is zero)\n", + "\n", + "If a diagonal element is 0 or very small either:\n", + "\n", + "1. no solution found\n", + "2. errors are introduced \n", + "\n", + "Therefore, we would want to pivot before applying Gauss elimination\n", + "\n", + "Consider:\n", + "\n", + "(a) $\\left[ \\begin{array}{cccc}\n", + "0 & 2 & 3 \\\\\n", + "4 & 6 & 7 \\\\\n", + "2 & -3 & 6 \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "8 \\\\\n", + "-3 \\\\\n", + "5\\end{array} \\right]$\n", + "\n", + "(b) $\\left[ \\begin{array}{cccc}\n", + "0.0003 & 3.0000 \\\\\n", + "1.0000 & 1.0000 \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "2.0001 \\\\\n", + "1.0000 \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 17, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "warning: division by zero\n", + "warning: called from\n", + " GaussNaive at line 16 column 12\n", + "warning: division by zero\n", + "warning: division by zero\n", + "ans =\n", + "\n", + " NaN\n", + " NaN\n", + " NaN\n", + "\n", + "ans =\n", + "\n", + " -5.423913\n", + " 0.021739\n", + " 2.652174\n", + "\n" + ] + } + ], + "source": [ + "format short\n", + "Aa=[0,2,3;4,6,7;2,-3,6]; ya=[8;-3;5];\n", + "GaussNaive(Aa,ya)\n", + "Aa\\ya" + ] + }, + { + "cell_type": "code", + "execution_count": 32, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "x =\n", + "\n", + " -5.423913\n", + " 0.021739\n", + " 2.652174\n", + "\n", + "Aug =\n", + "\n", + " 4.00000 6.00000 7.00000 -3.00000\n", + " 0.00000 -6.00000 2.50000 6.50000\n", + " 0.00000 0.00000 3.83333 10.16667\n", + "\n", + "npivots = 2\n" + ] + } + ], + "source": [ + "[x,Aug,npivots]=GaussPivot(Aa,ya)" + ] + }, + { + "cell_type": "code", + "execution_count": 33, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 0.325665420556713\n", + " 0.666666666666667\n", + "\n", + "ans =\n", + "\n", + " 0.333333333333333\n", + " 0.666666666666667\n", + "\n" + ] + } + ], + "source": [ + "format long\n", + "Ab=[0.3E-13,3.0000;1.0000,1.0000];yb=[2+0.1e-13;1.0000];\n", + "GaussNaive(Ab,yb)\n", + "Ab\\yb" + ] + }, + { + "cell_type": "code", + "execution_count": 34, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "x =\n", + "\n", + " 0.333333333333333\n", + " 0.666666666666667\n", + "\n", + "Aug =\n", + "\n", + " 1.000000000000000 1.000000000000000 1.000000000000000\n", + " 0.000000000000000 2.999999999999970 1.999999999999980\n", + "\n", + "npivots = 1\n", + "ans =\n", + "\n", + " 0.333333333333333\n", + " 0.666666666666667\n", + "\n" + ] + } + ], + "source": [ + "[x,Aug,npivots]=GaussPivot(Ab,yb)\n", + "Ab\\yb\n", + "format short" + ] + }, + { + "cell_type": "code", + "execution_count": 36, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = -3.0000\n", + "ans = 3.0000\n" + ] + } + ], + "source": [ + "% determinant is (-1)^(number_of_pivots)*diagonal_elements\n", + "det(Ab)\n", + "Aug(1,1)*Aug(2,2)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Spring-Mass System again\n", + "Now, 4 masses are connected in series to 4 springs with $K_{1}$=10 N/m, $K_{2}$=5 N/m, \n", + "$K_{3}$=2 N/m \n", + "and $K_{4}$=1 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses have the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0$\n", + "\n", + "$m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k_{4}(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "k_1+k_2 & -k_2 & 0 & 0 \\\\\n", + "-k_2 & k_2+k_3 & -k_3 & 0 \\\\\n", + "0 & -k_3 & k_3+k_4 & -k_4 \\\\\n", + "0 & 0 & -k_4 & k_4 \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 24, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 15 -5 0 0\n", + " -5 7 -2 0\n", + " 0 -2 3 -1\n", + " 0 0 -1 1\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k1=10; k2=5;k3=2;k4=1; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[k1+k2 -k2 0 0; -k2, k2+k3, -k3 0; 0 -k3, k3+k4, -k4; 0 0 -k4 k4]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Tridiagonal matrix\n", + "\n", + "This matrix, K, could be rewritten as 3 vectors e, f and g\n", + "\n", + "$e=\\left[ \\begin{array}{c}\n", + "0 \\\\\n", + "-5 \\\\\n", + "-2 \\\\\n", + "-1 \\end{array} \\right]$\n", + "\n", + "$f=\\left[ \\begin{array}{c}\n", + "15 \\\\\n", + "7 \\\\\n", + "3 \\\\\n", + "1 \\end{array} \\right]$\n", + "\n", + "$g=\\left[ \\begin{array}{c}\n", + "-5 \\\\\n", + "-2 \\\\\n", + "-1 \\\\\n", + "0 \\end{array} \\right]$\n", + "\n", + "Where all other components are 0 and the length of the vectors are n and the first component of e and the last component of g are zero\n", + "\n", + "`e(1)=0` \n", + "\n", + "`g(end)=0`\n", + "\n", + "No need to pivot and number of calculations reduced enormously.\n", + "\n", + "|method |Number of Floating point operations for n$\\times$n-matrix|\n", + "|----------------|---------|\n", + "| Gauss | n-cubed |\n", + "| Tridiagonal | n |" + ] + }, + { + "cell_type": "code", + "execution_count": 25, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 9.8100 27.4680 61.8030 101.0430\n", + "\n", + "ans =\n", + "\n", + " 9.8100\n", + " 27.4680\n", + " 61.8030\n", + " 101.0430\n", + "\n" + ] + } + ], + "source": [ + "e=[0;-5;-2;-1];\n", + "g=[-5;-2;-1;0];\n", + "f=[15;7;3;1];\n", + "Tridiag(e,f,g,y)\n", + "K\\y\n" + ] + }, + { + "cell_type": "code", + "execution_count": 26, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "% tic ... t=toc \n", + "% is Matlab timer used for debugging programs\n", + "t_GE = zeros(1,100);\n", + "t_GE_tridiag = zeros(1,100);\n", + "t_TD = zeros(1,100);\n", + "%for n = 1:200\n", + "for n=1:100\n", + " A = rand(n,n);\n", + " e = rand(n,1); e(1)=0;\n", + " f = rand(n,1);\n", + " g = rand(n,1); g(end)=0;\n", + " Atd=diag(f, 0) - diag(e(2:n), -1) - diag(g(1:n-1), 1);\n", + " b = rand(n,1);\n", + " tic;\n", + " x = GaussPivot(A,b);\n", + " t_GE(n) = toc;\n", + " tic;\n", + " x = A\\b;\n", + " t_GE_tridiag(n) = toc;\n", + " tic;\n", + " x = Tridiag(e,f,g,b);\n", + " t_TD(n) = toc;\n", + "end" + ] + }, + { + "cell_type": "code", + "execution_count": 28, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"63.6,362.4 534.9,362.4 534.9,16.8 63.6,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,362.4 L76.1,362.4 M535.0,362.4 L522.5,362.4 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,368.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">-5</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,341.6 L69.8,341.6 M535.0,341.6 L528.8,341.6 M63.6,329.4 L69.8,329.4 M535.0,329.4 L528.8,329.4 M63.6,320.8 L69.8,320.8 M535.0,320.8 L528.8,320.8 M63.6,314.1 L69.8,314.1 M535.0,314.1 L528.8,314.1 M63.6,308.6 L69.8,308.6 M535.0,308.6 L528.8,308.6 M63.6,304.0 L69.8,304.0 M535.0,304.0 L528.8,304.0 M63.6,300.0 L69.8,300.0 M535.0,300.0 L528.8,300.0 M63.6,296.4 L69.8,296.4 M535.0,296.4 L528.8,296.4 M63.6,293.3 L76.1,293.3 M535.0,293.3 L522.5,293.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,299.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">-4</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,272.4 L69.8,272.4 M535.0,272.4 L528.8,272.4 M63.6,260.3 L69.8,260.3 M535.0,260.3 L528.8,260.3 M63.6,251.6 L69.8,251.6 M535.0,251.6 L528.8,251.6 M63.6,244.9 L69.8,244.9 M535.0,244.9 L528.8,244.9 M63.6,239.5 L69.8,239.5 M535.0,239.5 L528.8,239.5 M63.6,234.8 L69.8,234.8 M535.0,234.8 L528.8,234.8 M63.6,230.8 L69.8,230.8 M535.0,230.8 L528.8,230.8 M63.6,227.3 L69.8,227.3 M535.0,227.3 L528.8,227.3 M63.6,224.1 L76.1,224.1 M535.0,224.1 L522.5,224.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,230.1)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">-3</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,203.3 L69.8,203.3 M535.0,203.3 L528.8,203.3 M63.6,191.1 L69.8,191.1 M535.0,191.1 L528.8,191.1 M63.6,182.5 L69.8,182.5 M535.0,182.5 L528.8,182.5 M63.6,175.8 L69.8,175.8 M535.0,175.8 L528.8,175.8 M63.6,170.3 L69.8,170.3 M535.0,170.3 L528.8,170.3 M63.6,165.7 L69.8,165.7 M535.0,165.7 L528.8,165.7 M63.6,161.7 L69.8,161.7 M535.0,161.7 L528.8,161.7 M63.6,158.1 L69.8,158.1 M535.0,158.1 L528.8,158.1 M63.6,155.0 L76.1,155.0 M535.0,155.0 L522.5,155.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,161.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">-2</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,134.2 L69.8,134.2 M535.0,134.2 L528.8,134.2 M63.6,122.0 L69.8,122.0 M535.0,122.0 L528.8,122.0 M63.6,113.4 L69.8,113.4 M535.0,113.4 L528.8,113.4 M63.6,106.7 L69.8,106.7 M535.0,106.7 L528.8,106.7 M63.6,101.2 L69.8,101.2 M535.0,101.2 L528.8,101.2 M63.6,96.5 L69.8,96.5 M535.0,96.5 L528.8,96.5 M63.6,92.5 L69.8,92.5 M535.0,92.5 L528.8,92.5 M63.6,89.0 L69.8,89.0 M535.0,89.0 L528.8,89.0 M63.6,85.8 L76.1,85.8 M535.0,85.8 L522.5,85.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,91.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">-1</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,65.0 L69.8,65.0 M535.0,65.0 L528.8,65.0 M63.6,52.9 L69.8,52.9 M535.0,52.9 L528.8,52.9 M63.6,44.2 L69.8,44.2 M535.0,44.2 L528.8,44.2 M63.6,37.5 L69.8,37.5 M535.0,37.5 L528.8,37.5 M63.6,32.0 L69.8,32.0 M535.0,32.0 L528.8,32.0 M63.6,27.4 L69.8,27.4 M535.0,27.4 L528.8,27.4 M63.6,23.4 L69.8,23.4 M535.0,23.4 L528.8,23.4 M63.6,19.9 L69.8,19.9 M535.0,19.9 L528.8,19.9 M63.6,16.7 L76.1,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(55.3,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">0</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,362.4 L63.6,349.9 M63.6,16.7 L63.6,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(63.6,386.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">0</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M134.6,362.4 L134.6,356.2 M134.6,16.7 L134.6,22.9 M176.1,362.4 L176.1,356.2 M176.1,16.7 L176.1,22.9 M205.5,362.4 L205.5,356.2 M205.5,16.7 L205.5,22.9 M228.3,362.4 L228.3,356.2 M228.3,16.7 L228.3,22.9 M247.0,362.4 L247.0,356.2 M247.0,16.7 L247.0,22.9 M262.8,362.4 L262.8,356.2 M262.8,16.7 L262.8,22.9 M276.5,362.4 L276.5,356.2 M276.5,16.7 L276.5,22.9 M288.5,362.4 L288.5,356.2 M288.5,16.7 L288.5,22.9 M299.3,362.4 L299.3,349.9 M299.3,16.7 L299.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(299.3,386.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">1</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M370.3,362.4 L370.3,356.2 M370.3,16.7 L370.3,22.9 M411.8,362.4 L411.8,356.2 M411.8,16.7 L411.8,22.9 M441.2,362.4 L441.2,356.2 M441.2,16.7 L441.2,22.9 M464.0,362.4 L464.0,356.2 M464.0,16.7 L464.0,22.9 M482.7,362.4 L482.7,356.2 M482.7,16.7 L482.7,22.9 M498.5,362.4 L498.5,356.2 M498.5,16.7 L498.5,22.9 M512.2,362.4 L512.2,356.2 M512.2,16.7 L512.2,22.9 M524.2,362.4 L524.2,356.2 M524.2,16.7 L524.2,22.9 M535.0,362.4 L535.0,349.9 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,386.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">10</tspan><tspan dy=\"-8.00px\" font-family=\"{}\" font-size=\"12.8\">2</tspan><tspan dy=\"8.00\" font-size=\"16.0\"/></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M63.6,16.7 L63.6,362.4 L535.0,362.4 L535.0,16.7 L63.6,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(19.1,189.6) rotate(-90)\">\n", + "\t\t<text><tspan font-family=\"{}\">time (s)</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(299.3,413.4)\">\n", + "\t\t<text><tspan font-family=\"{}\">number of elements</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M338.5,169.7 L338.5,25.7 L526.7,25.7 L526.7,169.7 L338.5,169.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>Gauss elim</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Gauss elim</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M349.7,49.7 L403.5,49.7 M63.6,244.9 L134.6,218.9 L176.1,200.5 L205.5,194.1 L228.3,188.5 L247.0,179.7 L262.8,187.8 L276.5,185.1 L288.5,190.9 L299.3,187.8 L309.1,189.0 L318.0,187.7 L326.2,186.5 L333.7,180.1 L340.8,176.5 L347.4,175.6 L353.6,173.1 L359.5,170.3 L365.0,168.4 L370.3,164.0 L375.2,163.3 L380.0,159.1 L384.6,157.2 L388.9,149.8 L393.1,144.2 L397.1,143.9 L401.0,141.9 L404.7,139.7 L408.3,140.8 L411.8,135.0 L415.1,131.6 L418.4,130.7 L421.5,129.9 L424.6,129.2 L427.5,127.8 L430.4,126.1 L433.2,124.6 L436.0,123.0 L438.6,121.5 L441.2,120.0 L443.7,118.6 L446.2,117.3 L448.6,115.9 L451.0,114.6 L453.3,113.2 L455.5,111.9 L457.7,110.6 L459.9,109.3 L462.0,108.1 L464.0,107.0 L466.1,105.8 L468.1,104.7 L470.0,103.7 L471.9,102.6 L473.8,99.4 L475.6,94.0 L477.5,93.2 L479.2,92.1 L481.0,89.6 L482.7,93.0 L484.4,95.1 L486.1,94.3 L487.7,93.2 L489.3,92.5 L490.9,89.9 L492.5,90.6 L494.0,89.7 L495.5,89.0 L497.0,88.3 L498.5,86.9 L499.9,87.1 L501.4,86.4 L502.8,85.7 L504.2,85.2 L505.6,84.4 L506.9,83.9 L508.2,83.3 L509.6,82.6 L510.9,82.3 L512.2,81.6 L513.4,81.0 L514.7,80.6 L515.9,79.7 L517.2,79.2 L518.4,79.1 L519.6,78.0 L520.7,78.0 L521.9,76.9 L523.1,76.5 L524.2,75.8 L525.3,75.3 L526.5,75.1 L527.6,74.3 L528.7,73.7 L529.7,73.3 L530.8,72.7 L531.9,72.2 L532.9,70.9 L534.0,71.2 L535.0,70.7 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>Matlab \\</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Matlab </tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M349.7,97.7 L403.5,97.7 M63.6,259.7 L134.6,242.2 L176.1,215.9 L205.5,223.2 L228.3,222.2 L247.0,222.1 L262.8,228.2 L276.5,234.0 L288.5,239.8 L299.3,240.6 L309.1,235.4 L318.0,240.7 L326.2,240.5 L333.7,236.7 L340.8,234.7 L347.4,235.3 L353.6,233.8 L359.5,233.4 L365.0,229.8 L370.3,230.3 L375.2,227.4 L380.0,227.9 L384.6,224.6 L388.9,217.8 L393.1,216.3 L397.1,215.7 L401.0,214.0 L404.7,213.7 L408.3,219.8 L411.8,207.5 L415.1,209.8 L418.4,208.8 L421.5,208.7 L424.6,208.0 L427.5,207.6 L430.4,206.7 L433.2,205.7 L436.0,205.2 L438.6,204.3 L441.2,203.6 L443.7,203.1 L446.2,202.2 L448.6,201.5 L451.0,200.9 L453.3,200.0 L455.5,199.3 L457.7,198.6 L459.9,197.9 L462.0,197.5 L464.0,197.0 L466.1,196.4 L468.1,195.7 L470.0,195.2 L471.9,194.6 L473.8,192.4 L475.6,193.1 L477.5,192.3 L479.2,192.0 L481.0,174.1 L482.7,190.5 L484.4,190.8 L486.1,190.2 L487.7,189.7 L489.3,189.3 L490.9,189.0 L492.5,188.7 L494.0,187.8 L495.5,187.9 L497.0,187.2 L498.5,187.0 L499.9,186.5 L501.4,186.1 L502.8,185.7 L504.2,185.3 L505.6,184.7 L506.9,184.7 L508.2,184.2 L509.6,183.5 L510.9,183.1 L512.2,183.1 L513.4,182.7 L514.7,182.2 L515.9,181.7 L517.2,181.8 L518.4,181.0 L519.6,180.7 L520.7,180.5 L521.9,180.0 L523.1,180.0 L524.2,179.4 L525.3,179.2 L526.5,179.0 L527.6,178.6 L528.7,178.1 L529.7,178.0 L530.8,177.6 L531.9,182.4 L532.9,177.0 L534.0,176.4 L535.0,182.3 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_3a\"><title>TriDiag</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,151.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">TriDiag</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M349.7,145.7 L403.5,145.7 M63.6,339.8 L134.6,290.4 L176.1,288.0 L205.5,286.1 L228.3,304.0 L247.0,308.1 L262.8,320.7 L276.5,317.2 L288.5,333.7 L299.3,328.4 L309.1,332.6 L318.0,320.0 L326.2,334.8 L333.7,309.0 L340.8,317.2 L347.4,331.6 L353.6,316.0 L359.5,245.2 L365.0,251.3 L370.3,313.5 L375.2,310.1 L380.0,307.6 L384.6,174.9 L388.9,301.9 L393.1,245.9 L397.1,291.6 L401.0,184.6 L404.7,300.6 L408.3,307.6 L411.8,298.5 L415.1,296.1 L418.4,293.2 L421.5,298.4 L424.6,294.5 L427.5,302.7 L430.4,254.5 L433.2,300.3 L436.0,303.1 L438.6,302.3 L441.2,302.7 L443.7,299.2 L446.2,300.6 L448.6,299.7 L451.0,297.4 L453.3,295.8 L455.5,295.1 L457.7,290.6 L459.9,290.9 L462.0,292.9 L464.0,291.2 L466.1,293.9 L468.1,296.1 L470.0,293.9 L471.9,293.9 L473.8,283.2 L475.6,288.8 L477.5,288.0 L479.2,288.0 L481.0,286.8 L482.7,286.8 L484.4,285.8 L486.1,286.5 L487.7,286.1 L489.3,285.6 L490.9,280.9 L492.5,279.9 L494.0,281.9 L495.5,279.4 L497.0,275.8 L498.5,273.8 L499.9,274.0 L501.4,274.5 L502.8,270.7 L504.2,269.6 L505.6,274.4 L506.9,274.6 L508.2,272.6 L509.6,269.3 L510.9,270.0 L512.2,271.7 L513.4,272.1 L514.7,271.0 L515.9,269.6 L517.2,268.6 L518.4,269.9 L519.6,270.3 L520.7,268.4 L521.9,269.6 L523.1,267.0 L524.2,268.5 L525.3,265.0 L526.5,265.8 L527.6,265.7 L528.7,265.0 L529.7,266.1 L530.8,263.8 L531.9,267.0 L532.9,264.9 L534.0,264.1 L535.0,265.2 \" stroke=\"rgb(255, 0, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb(255, 0, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "n=1:100;\n", + "loglog(n,t_GE,n,t_TD,n,t_GE_tridiag)\n", + "legend('Gauss elim','Matlab \\','TriDiag')\n", + "xlabel('number of elements')\n", + "ylabel('time (s)')" + ] + }, + { + "cell_type": "code", + "execution_count": 29, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "x =\n", + "\n", + " 9.8100\n", + " 27.4680\n", + " 61.8030\n", + " 101.0430\n", + "\n", + "Aug =\n", + "\n", + " 15.00000 -5.00000 0.00000 0.00000 9.81000\n", + " 0.00000 5.33333 -2.00000 0.00000 22.89000\n", + " 0.00000 0.00000 2.25000 -1.00000 38.01375\n", + " 0.00000 0.00000 0.00000 0.55556 56.13500\n", + "\n", + "npivots = 0\n" + ] + } + ], + "source": [ + "[x,Aug,npivots]=GaussPivot(K,y)" + ] + }, + { + "cell_type": "code", + "execution_count": 30, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 15.00000 -5.00000 0.00000 0.00000\n", + " 0.00000 5.33333 -2.00000 0.00000\n", + " 0.00000 0.00000 2.25000 -1.00000\n", + " 0.00000 0.00000 0.00000 0.55556\n", + "\n" + ] + } + ], + "source": [ + "A=Aug(1:4,1:4)" + ] + }, + { + "cell_type": "code", + "execution_count": 31, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = 100.00\n", + "detA = 100.00\n" + ] + } + ], + "source": [ + "det(A)\n", + "detA=A(1,1)*A(2,2)*A(3,3)*A(4,4)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_10/lecture_10.log b/lecture_10/lecture_10.log new file mode 100644 index 0000000..9e3113d --- /dev/null +++ b/lecture_10/lecture_10.log @@ -0,0 +1,871 @@ +This is pdfTeX, Version 3.14159265-2.6-1.40.16 (TeX Live 2015/Debian) (preloaded format=pdflatex 2017.1.11) 21 FEB 2017 11:46 +entering extended mode + restricted \write18 enabled. + %&-line parsing enabled. +**lecture_10.tex +(./lecture_10.tex +LaTeX2e <2016/02/01> +Babel <3.9q> and hyphenation patterns for 81 language(s) loaded. +(/usr/share/texlive/texmf-dist/tex/latex/base/article.cls +Document Class: article 2014/09/29 v1.4h Standard LaTeX document class +(/usr/share/texlive/texmf-dist/tex/latex/base/size11.clo +File: size11.clo 2014/09/29 v1.4h Standard LaTeX file (size option) +) +\c@part=\count79 +\c@section=\count80 +\c@subsection=\count81 +\c@subsubsection=\count82 +\c@paragraph=\count83 +\c@subparagraph=\count84 +\c@figure=\count85 +\c@table=\count86 +\abovecaptionskip=\skip41 +\belowcaptionskip=\skip42 +\bibindent=\dimen102 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/fontenc.sty +Package: fontenc 2005/09/27 v1.99g Standard LaTeX package + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1enc.def +File: t1enc.def 2005/09/27 v1.99g Standard LaTeX file +LaTeX Font Info: Redeclaring font encoding T1 on input line 48. +)) +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/mathpazo.sty +Package: mathpazo 2005/04/12 PSNFSS-v9.2a Palatino w/ Pazo Math (D.Puga, WaS) +\symupright=\mathgroup4 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphicx.sty +Package: graphicx 2014/10/28 v1.0g Enhanced LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/keyval.sty +Package: keyval 2014/10/28 v1.15 key=value parser (DPC) +\KV@toks@=\toks14 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphics.sty +Package: graphics 2016/01/03 v1.0q Standard LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/trig.sty +Package: trig 2016/01/03 v1.10 sin cos tan (DPC) +) +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/graphics.cfg +File: graphics.cfg 2010/04/23 v1.9 graphics configuration of TeX Live +) +Package graphics Info: Driver file: pdftex.def on input line 95. + +(/usr/share/texlive/texmf-dist/tex/latex/pdftex-def/pdftex.def +File: pdftex.def 2011/05/27 v0.06d Graphics/color for pdfTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/infwarerr.sty +Package: infwarerr 2010/04/08 v1.3 Providing info/warning/error messages (HO) +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ltxcmds.sty +Package: ltxcmds 2011/11/09 v1.22 LaTeX kernel commands for general use (HO) +) +\Gread@gobject=\count87 +)) +\Gin@req@height=\dimen103 +\Gin@req@width=\dimen104 +) +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption.sty +Package: caption 2016/02/21 v3.3-144 Customizing captions (AR) + +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption3.sty +Package: caption3 2016/02/04 v1.7-139 caption3 kernel (AR) +Package caption3 Info: TeX engine: e-TeX on input line 67. +\captionmargin=\dimen105 +\captionmargin@=\dimen106 +\captionwidth=\dimen107 +\caption@tempdima=\dimen108 +\caption@indent=\dimen109 +\caption@parindent=\dimen110 +\caption@hangindent=\dimen111 +) +\c@ContinuedFloat=\count88 +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjustbox.sty +Package: adjustbox 2012/05/21 v1.0 Adjusting TeX boxes (trim, clip, ...) + +(/usr/share/texlive/texmf-dist/tex/latex/xkeyval/xkeyval.sty +Package: xkeyval 2014/12/03 v2.7a package option processing (HA) + +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkeyval.tex +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkvutils.tex +\XKV@toks=\toks15 +\XKV@tempa@toks=\toks16 +) +\XKV@depth=\count89 +File: xkeyval.tex 2014/12/03 v2.7a key=value parser (HA) +)) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjcalc.sty +Package: adjcalc 2012/05/16 v1.1 Provides advanced setlength with multiple back +-ends (calc, etex, pgfmath) +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/trimclip.sty +Package: trimclip 2012/05/16 v1.0 Trim and clip general TeX material + +(/usr/share/texlive/texmf-dist/tex/latex/collectbox/collectbox.sty +Package: collectbox 2012/05/17 v0.4b Collect macro arguments as boxes +\collectedbox=\box26 +) +\tc@llx=\dimen112 +\tc@lly=\dimen113 +\tc@urx=\dimen114 +\tc@ury=\dimen115 +Package trimclip Info: Using driver 'tc-pdftex.def'. + +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/tc-pdftex.def +File: tc-pdftex.def 2012/05/13 v1.0 Clipping driver for pdftex +)) +\adjbox@Width=\dimen116 +\adjbox@Height=\dimen117 +\adjbox@Depth=\dimen118 +\adjbox@Totalheight=\dimen119 + +(/usr/share/texlive/texmf-dist/tex/latex/ifoddpage/ifoddpage.sty +Package: ifoddpage 2011/09/13 v1.0 Conditionals for odd/even page detection +\c@checkoddpage=\count90 +) +(/usr/share/texlive/texmf-dist/tex/latex/varwidth/varwidth.sty +Package: varwidth 2009/03/30 ver 0.92; Variable-width minipages +\@vwid@box=\box27 +\sift@deathcycles=\count91 +\@vwid@loff=\dimen120 +\@vwid@roff=\dimen121 +)) +(/usr/share/texlive/texmf-dist/tex/latex/xcolor/xcolor.sty +Package: xcolor 2007/01/21 v2.11 LaTeX color extensions (UK) + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/color.cfg +File: color.cfg 2007/01/18 v1.5 color configuration of teTeX/TeXLive +) +Package xcolor Info: Driver file: pdftex.def on input line 225. +Package xcolor Info: Model `cmy' substituted by `cmy0' on input line 1337. +Package xcolor Info: Model `hsb' substituted by `rgb' on input line 1341. +Package xcolor Info: Model `RGB' extended on input line 1353. +Package xcolor Info: Model `HTML' substituted by `rgb' on input line 1355. +Package xcolor Info: Model `Hsb' substituted by `hsb' on input line 1356. +Package xcolor Info: Model `tHsb' substituted by `hsb' on input line 1357. +Package xcolor Info: Model `HSB' substituted by `hsb' on input line 1358. +Package xcolor Info: Model `Gray' substituted by `gray' on input line 1359. +Package xcolor Info: Model `wave' substituted by `hsb' on input line 1360. +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/enumerate.sty +Package: enumerate 2015/07/23 v3.00 enumerate extensions (DPC) +\@enLab=\toks17 +) +(/usr/share/texlive/texmf-dist/tex/latex/geometry/geometry.sty +Package: geometry 2010/09/12 v5.6 Page Geometry + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifpdf.sty +Package: ifpdf 2011/01/30 v2.3 Provides the ifpdf switch (HO) +Package ifpdf Info: pdfTeX in PDF mode is detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifvtex.sty +Package: ifvtex 2010/03/01 v1.5 Detect VTeX and its facilities (HO) +Package ifvtex Info: VTeX not detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/ifxetex/ifxetex.sty +Package: ifxetex 2010/09/12 v0.6 Provides ifxetex conditional +) +\Gm@cnth=\count92 +\Gm@cntv=\count93 +\c@Gm@tempcnt=\count94 +\Gm@bindingoffset=\dimen122 +\Gm@wd@mp=\dimen123 +\Gm@odd@mp=\dimen124 +\Gm@even@mp=\dimen125 +\Gm@layoutwidth=\dimen126 +\Gm@layoutheight=\dimen127 +\Gm@layouthoffset=\dimen128 +\Gm@layoutvoffset=\dimen129 +\Gm@dimlist=\toks18 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsmath.sty +Package: amsmath 2016/03/03 v2.15a AMS math features +\@mathmargin=\skip43 + +For additional information on amsmath, use the `?' option. +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amstext.sty +Package: amstext 2000/06/29 v2.01 AMS text + +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsgen.sty +File: amsgen.sty 1999/11/30 v2.0 generic functions +\@emptytoks=\toks19 +\ex@=\dimen130 +)) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsbsy.sty +Package: amsbsy 1999/11/29 v1.2d Bold Symbols +\pmbraise@=\dimen131 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsopn.sty +Package: amsopn 1999/12/14 v2.01 operator names +) +\inf@bad=\count95 +LaTeX Info: Redefining \frac on input line 199. +\uproot@=\count96 +\leftroot@=\count97 +LaTeX Info: Redefining \overline on input line 297. +\classnum@=\count98 +\DOTSCASE@=\count99 +LaTeX Info: Redefining \ldots on input line 394. +LaTeX Info: Redefining \dots on input line 397. +LaTeX Info: Redefining \cdots on input line 518. +\Mathstrutbox@=\box28 +\strutbox@=\box29 +\big@size=\dimen132 +LaTeX Font Info: Redeclaring font encoding OML on input line 630. +LaTeX Font Info: Redeclaring font encoding OMS on input line 631. +\macc@depth=\count100 +\c@MaxMatrixCols=\count101 +\dotsspace@=\muskip10 +\c@parentequation=\count102 +\dspbrk@lvl=\count103 +\tag@help=\toks20 +\row@=\count104 +\column@=\count105 +\maxfields@=\count106 +\andhelp@=\toks21 +\eqnshift@=\dimen133 +\alignsep@=\dimen134 +\tagshift@=\dimen135 +\tagwidth@=\dimen136 +\totwidth@=\dimen137 +\lineht@=\dimen138 +\@envbody=\toks22 +\multlinegap=\skip44 +\multlinetaggap=\skip45 +\mathdisplay@stack=\toks23 +LaTeX Info: Redefining \[ on input line 2735. +LaTeX Info: Redefining \] on input line 2736. +) +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amssymb.sty +Package: amssymb 2013/01/14 v3.01 AMS font symbols + +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amsfonts.sty +Package: amsfonts 2013/01/14 v3.01 Basic AMSFonts support +\symAMSa=\mathgroup5 +\symAMSb=\mathgroup6 +LaTeX Font Info: Overwriting math alphabet `\mathfrak' in version `bold' +(Font) U/euf/m/n --> U/euf/b/n on input line 106. +)) +(/usr/share/texlive/texmf-dist/tex/latex/base/textcomp.sty +Package: textcomp 2005/09/27 v1.99g Standard LaTeX package +Package textcomp Info: Sub-encoding information: +(textcomp) 5 = only ISO-Adobe without \textcurrency +(textcomp) 4 = 5 + \texteuro +(textcomp) 3 = 4 + \textohm +(textcomp) 2 = 3 + \textestimated + \textcurrency +(textcomp) 1 = TS1 - \textcircled - \t +(textcomp) 0 = TS1 (full) +(textcomp) Font families with sub-encoding setting implement +(textcomp) only a restricted character set as indicated. +(textcomp) Family '?' is the default used for unknown fonts. +(textcomp) See the documentation for details. +Package textcomp Info: Setting ? sub-encoding to TS1/1 on input line 79. + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1enc.def +File: ts1enc.def 2001/06/05 v3.0e (jk/car/fm) Standard LaTeX file +) +LaTeX Info: Redefining \oldstylenums on input line 334. +Package textcomp Info: Setting cmr sub-encoding to TS1/0 on input line 349. +Package textcomp Info: Setting cmss sub-encoding to TS1/0 on input line 350. +Package textcomp Info: Setting cmtt sub-encoding to TS1/0 on input line 351. +Package textcomp Info: Setting cmvtt sub-encoding to TS1/0 on input line 352. +Package textcomp Info: Setting cmbr sub-encoding to TS1/0 on input line 353. +Package textcomp Info: Setting cmtl sub-encoding to TS1/0 on input line 354. +Package textcomp Info: Setting ccr sub-encoding to TS1/0 on input line 355. +Package textcomp Info: Setting ptm sub-encoding to TS1/4 on input line 356. +Package textcomp Info: Setting pcr sub-encoding to TS1/4 on input line 357. +Package textcomp Info: Setting phv sub-encoding to TS1/4 on input line 358. +Package textcomp Info: Setting ppl sub-encoding to TS1/3 on input line 359. +Package textcomp Info: Setting pag sub-encoding to TS1/4 on input line 360. +Package textcomp Info: Setting pbk sub-encoding to TS1/4 on input line 361. +Package textcomp Info: Setting pnc sub-encoding to TS1/4 on input line 362. +Package textcomp Info: Setting pzc sub-encoding to TS1/4 on input line 363. +Package textcomp Info: Setting bch sub-encoding to TS1/4 on input line 364. +Package textcomp Info: Setting put sub-encoding to TS1/5 on input line 365. +Package textcomp Info: Setting uag sub-encoding to TS1/5 on input line 366. +Package textcomp Info: Setting ugq sub-encoding to TS1/5 on input line 367. +Package textcomp Info: Setting ul8 sub-encoding to TS1/4 on input line 368. +Package textcomp Info: Setting ul9 sub-encoding to TS1/4 on input line 369. +Package textcomp Info: Setting augie sub-encoding to TS1/5 on input line 370. +Package textcomp Info: Setting dayrom sub-encoding to TS1/3 on input line 371. +Package textcomp Info: Setting dayroms sub-encoding to TS1/3 on input line 372. + +Package textcomp Info: Setting pxr sub-encoding to TS1/0 on input line 373. +Package textcomp Info: Setting pxss sub-encoding to TS1/0 on input line 374. +Package textcomp Info: Setting pxtt sub-encoding to TS1/0 on input line 375. +Package textcomp Info: Setting txr sub-encoding to TS1/0 on input line 376. +Package textcomp Info: Setting txss sub-encoding to TS1/0 on input line 377. +Package textcomp Info: Setting txtt sub-encoding to TS1/0 on input line 378. +Package textcomp Info: Setting lmr sub-encoding to TS1/0 on input line 379. +Package textcomp Info: Setting lmdh sub-encoding to TS1/0 on input line 380. +Package textcomp Info: Setting lmss sub-encoding to TS1/0 on input line 381. +Package textcomp Info: Setting lmssq sub-encoding to TS1/0 on input line 382. +Package textcomp Info: Setting lmvtt sub-encoding to TS1/0 on input line 383. +Package textcomp Info: Setting lmtt sub-encoding to TS1/0 on input line 384. +Package textcomp Info: Setting qhv sub-encoding to TS1/0 on input line 385. +Package textcomp Info: Setting qag sub-encoding to TS1/0 on input line 386. +Package textcomp Info: Setting qbk sub-encoding to TS1/0 on input line 387. +Package textcomp Info: Setting qcr sub-encoding to TS1/0 on input line 388. +Package textcomp Info: Setting qcs sub-encoding to TS1/0 on input line 389. +Package textcomp Info: Setting qpl sub-encoding to TS1/0 on input line 390. +Package textcomp Info: Setting qtm sub-encoding to TS1/0 on input line 391. +Package textcomp Info: Setting qzc sub-encoding to TS1/0 on input line 392. +Package textcomp Info: Setting qhvc sub-encoding to TS1/0 on input line 393. +Package textcomp Info: Setting futs sub-encoding to TS1/4 on input line 394. +Package textcomp Info: Setting futx sub-encoding to TS1/4 on input line 395. +Package textcomp Info: Setting futj sub-encoding to TS1/4 on input line 396. +Package textcomp Info: Setting hlh sub-encoding to TS1/3 on input line 397. +Package textcomp Info: Setting hls sub-encoding to TS1/3 on input line 398. +Package textcomp Info: Setting hlst sub-encoding to TS1/3 on input line 399. +Package textcomp Info: Setting hlct sub-encoding to TS1/5 on input line 400. +Package textcomp Info: Setting hlx sub-encoding to TS1/5 on input line 401. +Package textcomp Info: Setting hlce sub-encoding to TS1/5 on input line 402. +Package textcomp Info: Setting hlcn sub-encoding to TS1/5 on input line 403. +Package textcomp Info: Setting hlcw sub-encoding to TS1/5 on input line 404. +Package textcomp Info: Setting hlcf sub-encoding to TS1/5 on input line 405. +Package textcomp Info: Setting pplx sub-encoding to TS1/3 on input line 406. +Package textcomp Info: Setting pplj sub-encoding to TS1/3 on input line 407. +Package textcomp Info: Setting ptmx sub-encoding to TS1/4 on input line 408. +Package textcomp Info: Setting ptmj sub-encoding to TS1/4 on input line 409. +) +(/usr/share/texlive/texmf-dist/tex/latex/upquote/upquote.sty +Package: upquote 2012/04/19 v1.3 upright-quote and grave-accent glyphs in verba +tim +) +(/usr/share/texlive/texmf-dist/tex/latex/eurosym/eurosym.sty +Package: eurosym 1998/08/06 v1.1 European currency symbol ``Euro'' +\@eurobox=\box30 +) +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucs.sty +Package: ucs 2013/05/11 v2.2 UCS: Unicode input support + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/data/uni-global.def +File: uni-global.def 2013/05/13 UCS: Unicode global data +) +\uc@secondtry=\count107 +\uc@combtoks=\toks24 +\uc@combtoksb=\toks25 +\uc@temptokena=\toks26 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/inputenc.sty +Package: inputenc 2015/03/17 v1.2c Input encoding file +\inpenc@prehook=\toks27 +\inpenc@posthook=\toks28 + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/utf8x.def +File: utf8x.def 2004/10/17 UCS: Input encoding UTF-8 +)) +(/usr/share/texlive/texmf-dist/tex/latex/fancyvrb/fancyvrb.sty +Package: fancyvrb 2008/02/07 + +Style option: `fancyvrb' v2.7a, with DG/SPQR fixes, and firstline=lastline fix +<2008/02/07> (tvz) +\FV@CodeLineNo=\count108 +\FV@InFile=\read1 +\FV@TabBox=\box31 +\c@FancyVerbLine=\count109 +\FV@StepNumber=\count110 +\FV@OutFile=\write3 +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grffile.sty +Package: grffile 2012/04/05 v1.16 Extended file name support for graphics (HO) + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/kvoptions.sty +Package: kvoptions 2011/06/30 v3.11 Key value format for package options (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/kvsetkeys.sty +Package: kvsetkeys 2012/04/25 v1.16 Key value parser (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/etexcmds.sty +Package: etexcmds 2011/02/16 v1.5 Avoid name clashes with e-TeX commands (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifluatex.sty +Package: ifluatex 2010/03/01 v1.3 Provides the ifluatex switch (HO) +Package ifluatex Info: LuaTeX not detected. +) +Package etexcmds Info: Could not find \expanded. +(etexcmds) That can mean that you are not using pdfTeX 1.50 or +(etexcmds) that some package has redefined \expanded. +(etexcmds) In the latter case, load this package earlier. +))) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/pdftexcmds.sty +Package: pdftexcmds 2011/11/29 v0.20 Utility functions of pdfTeX for LuaTeX (HO +) +Package pdftexcmds Info: LuaTeX not detected. +Package pdftexcmds Info: \pdf@primitive is available. +Package pdftexcmds Info: \pdf@ifprimitive is available. +Package pdftexcmds Info: \pdfdraftmode found. +) +Package grffile Info: Option `multidot' is set to `true'. +Package grffile Info: Option `extendedchars' is set to `false'. +Package grffile Info: Option `space' is set to `true'. +Package grffile Info: \Gin@ii of package `graphicx' fixed on input line 486. +) +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hyperref.sty +Package: hyperref 2012/11/06 v6.83m Hypertext links for LaTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-hyperref.sty +Package: hobsub-hyperref 2012/05/28 v1.13 Bundle oberdiek, subset hyperref (HO) + + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-generic.sty +Package: hobsub-generic 2012/05/28 v1.13 Bundle oberdiek, subset generic (HO) +Package: hobsub 2012/05/28 v1.13 Construct package bundles (HO) +Package hobsub Info: Skipping package `infwarerr' (already loaded). +Package hobsub Info: Skipping package `ltxcmds' (already loaded). +Package hobsub Info: Skipping package `ifluatex' (already loaded). +Package hobsub Info: Skipping package `ifvtex' (already loaded). +Package: intcalc 2007/09/27 v1.1 Expandable calculations with integers (HO) +Package hobsub Info: Skipping package `ifpdf' (already loaded). +Package hobsub Info: Skipping package `etexcmds' (already loaded). +Package hobsub Info: Skipping package `kvsetkeys' (already loaded). +Package: kvdefinekeys 2011/04/07 v1.3 Define keys (HO) +Package hobsub Info: Skipping package `pdftexcmds' (already loaded). +Package: pdfescape 2011/11/25 v1.13 Implements pdfTeX's escape features (HO) +Package: bigintcalc 2012/04/08 v1.3 Expandable calculations on big integers (HO +) +Package: bitset 2011/01/30 v1.1 Handle bit-vector datatype (HO) +Package: uniquecounter 2011/01/30 v1.2 Provide unlimited unique counter (HO) +) +Package hobsub Info: Skipping package `hobsub' (already loaded). +Package: letltxmacro 2010/09/02 v1.4 Let assignment for LaTeX macros (HO) +Package: hopatch 2012/05/28 v1.2 Wrapper for package hooks (HO) +Package: xcolor-patch 2011/01/30 xcolor patch +Package: atveryend 2011/06/30 v1.8 Hooks at the very end of document (HO) +Package atveryend Info: \enddocument detected (standard20110627). +Package: atbegshi 2011/10/05 v1.16 At begin shipout hook (HO) +Package: refcount 2011/10/16 v3.4 Data extraction from label references (HO) +Package: hycolor 2011/01/30 v1.7 Color options for hyperref/bookmark (HO) +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/auxhook.sty +Package: auxhook 2011/03/04 v1.3 Hooks for auxiliary files (HO) +) +\@linkdim=\dimen139 +\Hy@linkcounter=\count111 +\Hy@pagecounter=\count112 + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/pd1enc.def +File: pd1enc.def 2012/11/06 v6.83m Hyperref: PDFDocEncoding definition (HO) +) +\Hy@SavedSpaceFactor=\count113 + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/hyperref.cfg +File: hyperref.cfg 2002/06/06 v1.2 hyperref configuration of TeXLive +) +Package hyperref Info: Hyper figures OFF on input line 4443. +Package hyperref Info: Link nesting OFF on input line 4448. +Package hyperref Info: Hyper index ON on input line 4451. +Package hyperref Info: Plain pages OFF on input line 4458. +Package hyperref Info: Backreferencing OFF on input line 4463. +Package hyperref Info: Implicit mode ON; LaTeX internals redefined. +Package hyperref Info: Bookmarks ON on input line 4688. +\c@Hy@tempcnt=\count114 + +(/usr/share/texlive/texmf-dist/tex/latex/url/url.sty +\Urlmuskip=\muskip11 +Package: url 2013/09/16 ver 3.4 Verb mode for urls, etc. +) +LaTeX Info: Redefining \url on input line 5041. +\XeTeXLinkMargin=\dimen140 +\Fld@menulength=\count115 +\Field@Width=\dimen141 +\Fld@charsize=\dimen142 +Package hyperref Info: Hyper figures OFF on input line 6295. +Package hyperref Info: Link nesting OFF on input line 6300. +Package hyperref Info: Hyper index ON on input line 6303. +Package hyperref Info: backreferencing OFF on input line 6310. +Package hyperref Info: Link coloring OFF on input line 6315. +Package hyperref Info: Link coloring with OCG OFF on input line 6320. +Package hyperref Info: PDF/A mode OFF on input line 6325. +LaTeX Info: Redefining \ref on input line 6365. +LaTeX Info: Redefining \pageref on input line 6369. +\Hy@abspage=\count116 +\c@Item=\count117 +\c@Hfootnote=\count118 +) + +Package hyperref Message: Driver (autodetected): hpdftex. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hpdftex.def +File: hpdftex.def 2012/11/06 v6.83m Hyperref driver for pdfTeX +\Fld@listcount=\count119 +\c@bookmark@seq@number=\count120 + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/rerunfilecheck.sty +Package: rerunfilecheck 2011/04/15 v1.7 Rerun checks for auxiliary files (HO) +Package uniquecounter Info: New unique counter `rerunfilecheck' on input line 2 +82. +) +\Hy@SectionHShift=\skip46 +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/longtable.sty +Package: longtable 2014/10/28 v4.11 Multi-page Table package (DPC) +\LTleft=\skip47 +\LTright=\skip48 +\LTpre=\skip49 +\LTpost=\skip50 +\LTchunksize=\count121 +\LTcapwidth=\dimen143 +\LT@head=\box32 +\LT@firsthead=\box33 +\LT@foot=\box34 +\LT@lastfoot=\box35 +\LT@cols=\count122 +\LT@rows=\count123 +\c@LT@tables=\count124 +\c@LT@chunks=\count125 +\LT@p@ftn=\toks29 +) +(/usr/share/texlive/texmf-dist/tex/latex/booktabs/booktabs.sty +Package: booktabs 2005/04/14 v1.61803 publication quality tables +\heavyrulewidth=\dimen144 +\lightrulewidth=\dimen145 +\cmidrulewidth=\dimen146 +\belowrulesep=\dimen147 +\belowbottomsep=\dimen148 +\aboverulesep=\dimen149 +\abovetopsep=\dimen150 +\cmidrulesep=\dimen151 +\cmidrulekern=\dimen152 +\defaultaddspace=\dimen153 +\@cmidla=\count126 +\@cmidlb=\count127 +\@aboverulesep=\dimen154 +\@belowrulesep=\dimen155 +\@thisruleclass=\count128 +\@lastruleclass=\count129 +\@thisrulewidth=\dimen156 +) +(/usr/share/texlive/texmf-dist/tex/latex/enumitem/enumitem.sty +Package: enumitem 2011/09/28 v3.5.2 Customized lists +\labelindent=\skip51 +\enit@outerparindent=\dimen157 +\enit@toks=\toks30 +\enit@inbox=\box36 +\enitdp@description=\count130 +) +(/usr/share/texlive/texmf-dist/tex/generic/ulem/ulem.sty +\UL@box=\box37 +\UL@hyphenbox=\box38 +\UL@skip=\skip52 +\UL@hook=\toks31 +\UL@height=\dimen158 +\UL@pe=\count131 +\UL@pixel=\dimen159 +\ULC@box=\box39 +Package: ulem 2012/05/18 +\ULdepth=\dimen160 +) +Package hyperref Info: Option `breaklinks' set `true' on input line 264. +Package hyperref Info: Option `colorlinks' set `true' on input line 264. + (./lecture_10.aux + +LaTeX Warning: Label `gauss-elimination' multiply defined. + +) +\openout1 = `lecture_10.aux'. + +LaTeX Font Info: Checking defaults for OML/cmm/m/it on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for T1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OT1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMS/cmsy/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMX/cmex/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for U/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for TS1/cmr/m/n on input line 271. +LaTeX Font Info: Try loading font information for TS1+cmr on input line 271. + + (/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmr.fd +File: ts1cmr.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for PD1/pdf/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Try loading font information for T1+ppl on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/t1ppl.fd +File: t1ppl.fd 2001/06/04 font definitions for T1/ppl. +) +(/usr/share/texlive/texmf-dist/tex/context/base/supp-pdf.mkii +[Loading MPS to PDF converter (version 2006.09.02).] +\scratchcounter=\count132 +\scratchdimen=\dimen161 +\scratchbox=\box40 +\nofMPsegments=\count133 +\nofMParguments=\count134 +\everyMPshowfont=\toks32 +\MPscratchCnt=\count135 +\MPscratchDim=\dimen162 +\MPnumerator=\count136 +\makeMPintoPDFobject=\count137 +\everyMPtoPDFconversion=\toks33 +) (/usr/share/texlive/texmf-dist/tex/latex/oberdiek/epstopdf-base.sty +Package: epstopdf-base 2010/02/09 v2.5 Base part for package epstopdf + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grfext.sty +Package: grfext 2010/08/19 v1.1 Manage graphics extensions (HO) +) +Package grfext Info: Graphics extension search list: +(grfext) [.png,.pdf,.jpg,.mps,.jpeg,.jbig2,.jb2,.PNG,.PDF,.JPG,.JPE +G,.JBIG2,.JB2,.eps] +(grfext) \AppendGraphicsExtensions on input line 452. + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/epstopdf-sys.cfg +File: epstopdf-sys.cfg 2010/07/13 v1.3 Configuration of (r)epstopdf for TeX Liv +e +)) +Package caption Info: Begin \AtBeginDocument code. +Package caption Info: hyperref package is loaded. +Package caption Info: longtable package is loaded. + +(/usr/share/texlive/texmf-dist/tex/latex/caption/ltcaption.sty +Package: ltcaption 2013/06/09 v1.4-94 longtable captions (AR) +) +Package caption Info: End \AtBeginDocument code. + +*geometry* driver: auto-detecting +*geometry* detected driver: pdftex +*geometry* verbose mode - [ preamble ] result: +* driver: pdftex +* paper: <default> +* layout: <same size as paper> +* layoutoffset:(h,v)=(0.0pt,0.0pt) +* modes: +* h-part:(L,W,R)=(72.26999pt, 469.75502pt, 72.26999pt) +* v-part:(T,H,B)=(72.26999pt, 650.43001pt, 72.26999pt) +* \paperwidth=614.295pt +* \paperheight=794.96999pt +* \textwidth=469.75502pt +* \textheight=650.43001pt +* \oddsidemargin=0.0pt +* \evensidemargin=0.0pt +* \topmargin=-37.0pt +* \headheight=12.0pt +* \headsep=25.0pt +* \topskip=11.0pt +* \footskip=30.0pt +* \marginparwidth=59.0pt +* \marginparsep=10.0pt +* \columnsep=10.0pt +* \skip\footins=10.0pt plus 4.0pt minus 2.0pt +* \hoffset=0.0pt +* \voffset=0.0pt +* \mag=1000 +* \@twocolumnfalse +* \@twosidefalse +* \@mparswitchfalse +* \@reversemarginfalse +* (1in=72.27pt=25.4mm, 1cm=28.453pt) + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucsencs.def +File: ucsencs.def 2011/01/21 Fixes to fontencodings LGR, T3 +) +\AtBeginShipoutBox=\box41 +Package hyperref Info: Link coloring ON on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/nameref.sty +Package: nameref 2012/10/27 v2.43 Cross-referencing by name of section + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/gettitlestring.sty +Package: gettitlestring 2010/12/03 v1.4 Cleanup title references (HO) +) +\c@section@level=\count138 +) +LaTeX Info: Redefining \ref on input line 271. +LaTeX Info: Redefining \pageref on input line 271. +LaTeX Info: Redefining \nameref on input line 271. + +(./lecture_10.out) (./lecture_10.out) +\@outlinefile=\write4 +\openout4 = `lecture_10.out'. + +LaTeX Font Info: Try loading font information for OT1+ppl on input line 275. + + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1ppl.fd +File: ot1ppl.fd 2001/06/04 font definitions for OT1/ppl. +) +LaTeX Font Info: Try loading font information for OML+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omlzplm.fd +File: omlzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OML/zplm. +) +LaTeX Font Info: Try loading font information for OMS+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omszplm.fd +File: omszplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMS/zplm. +) +LaTeX Font Info: Try loading font information for OMX+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omxzplm.fd +File: omxzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMX/zplm. +) +LaTeX Font Info: Try loading font information for OT1+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1zplm.fd +File: ot1zplm.fd 2002/09/08 Fontinst v1.914 font definitions for OT1/zplm. +) +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. + + +LaTeX Warning: No \author given. + +LaTeX Font Info: Try loading font information for T1+cmtt on input line 279. + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1cmtt.fd +File: t1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <14.4> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 287. +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <10.95> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 290. + + +Package hyperref Warning: Difference (2) between bookmark levels is greater +(hyperref) than one, level fixed on input line 290. + +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 11.40997pt on input line 295. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 8.33606pt on input line 295. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 6.25204pt on input line 295. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 11.40997pt on input line 295. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 8.33606pt on input line 295. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 6.25204pt on input line 295. +<lecture_10_files/lecture_10_3_0.pdf, id=36, 449.68pt x 337.26pt> +File: lecture_10_files/lecture_10_3_0.pdf Graphic file (type pdf) + +<use lecture_10_files/lecture_10_3_0.pdf> +Package pdftex.def Info: lecture_10_files/lecture_10_3_0.pdf used on input line + 321. +(pdftex.def) Requested size: 449.6789pt x 337.25917pt. + [1 + +{/var/lib/texmf/fonts/map/pdftex/updmap/pdftex.map}] +Underfull \hbox (badness 10000) in paragraph at lines 323--324 + + [] + +LaTeX Font Info: Try loading font information for TS1+cmtt on input line 327 +. +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmtt.fd +File: ts1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) [2 <./lecture_10_files/lecture_10_3_0.pdf>] +<lecture_10_files/lecture_10_6_0.pdf, id=63, 449.68pt x 337.26pt> +File: lecture_10_files/lecture_10_6_0.pdf Graphic file (type pdf) + +<use lecture_10_files/lecture_10_6_0.pdf> +Package pdftex.def Info: lecture_10_files/lecture_10_6_0.pdf used on input line + 382. +(pdftex.def) Requested size: 449.6789pt x 337.25917pt. + +Underfull \hbox (badness 10000) in paragraph at lines 384--385 + + [] + +[3 <./lecture_10_files/lecture_10_6_0.pdf>] +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <12> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 389. + + +! LaTeX Error: Unknown graphics extension: .svg. + +See the LaTeX manual or LaTeX Companion for explanation. +Type H <return> for immediate help. + ... + +l.444 ...egraphics{../lecture_09/mass_springs.svg} + +? +[4] [5] [6] [7] [8] + +! LaTeX Error: Unknown graphics extension: .svg. + +See the LaTeX manual or LaTeX Companion for explanation. +Type H <return> for immediate help. + ... + +l.735 ...egraphics{../lecture_09/mass_springs.svg} + +? +[9] [10] +LaTeX Font Info: Font shape `T1/cmtt/bx/n' in size <10.95> not available +(Font) Font shape `T1/cmtt/m/n' tried instead on input line 843. + <lecture_10_files/lecture_10_29_0.pdf, id=113, 449.68pt x 337.26pt> +File: lecture_10_files/lecture_10_29_0.pdf Graphic file (type pdf) + +<use lecture_10_files/lecture_10_29_0.pdf> +Package pdftex.def Info: lecture_10_files/lecture_10_29_0.pdf used on input lin +e 871. +(pdftex.def) Requested size: 449.6789pt x 337.25917pt. + [11] +Underfull \hbox (badness 10000) in paragraph at lines 873--874 + + [] + +[12 <./lecture_10_files/lecture_10_29_0.pdf>] +Package atveryend Info: Empty hook `BeforeClearDocument' on input line 933. + [13] +Package atveryend Info: Empty hook `AfterLastShipout' on input line 933. + (./lecture_10.aux) +Package atveryend Info: Executing hook `AtVeryEndDocument' on input line 933. +Package atveryend Info: Executing hook `AtEndAfterFileList' on input line 933. +Package rerunfilecheck Info: File `lecture_10.out' has not changed. +(rerunfilecheck) Checksum: F41F49C8B1F4406369908EBDD24F2572;629. + + +LaTeX Warning: There were multiply-defined labels. + +Package atveryend Info: Empty hook `AtVeryVeryEnd' on input line 933. + ) +Here is how much of TeX's memory you used: + 10943 strings out of 493029 + 163805 string characters out of 6136234 + 273063 words of memory out of 5000000 + 14226 multiletter control sequences out of 15000+600000 + 35779 words of font info for 91 fonts, out of 8000000 for 9000 + 1141 hyphenation exceptions out of 8191 + 36i,8n,77p,494b,465s stack positions out of 5000i,500n,10000p,200000b,80000s +{/usr/share/texmf/fonts/enc/dvips/cm-super/cm-super-ts1.enc}{/usr/share/texli +ve/texmf-dist/fonts/enc/dvips/base/8r.enc}{/usr/share/texmf/fonts/enc/dvips/cm- +super/cm-super-t1.enc}</usr/share/texlive/texmf-dist/fonts/type1/public/amsfont +s/cm/cmex10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/c +mr10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/cmsy10.p +fb></usr/share/texmf/fonts/type1/public/cm-super/sfit1095.pfb></usr/share/texmf +/fonts/type1/public/cm-super/sftt1095.pfb></usr/share/texlive/texmf-dist/fonts/ +type1/urw/palatino/uplb8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/pa +latino/uplr8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/palatino/uplri +8a.pfb> +Output written on lecture_10.pdf (13 pages, 190161 bytes). +PDF statistics: + 176 PDF objects out of 1000 (max. 8388607) + 142 compressed objects within 2 object streams + 29 named destinations out of 1000 (max. 500000) + 80 words of extra memory for PDF output out of 10000 (max. 10000000) + diff --git a/lecture_10/lecture_10.md b/lecture_10/lecture_10.md new file mode 100644 index 0000000..dd426e0 --- /dev/null +++ b/lecture_10/lecture_10.md @@ -0,0 +1,593 @@ + + +```octave +%plot --format svg +``` + + +```octave +setdefaults +``` + +# Gauss Elimination +### Solving sets of equations with matrix operations + +The number of dimensions of a matrix indicate the degrees of freedom of the system you are solving. + +If you have a set of known output, $y_{1},~y_{2},~...y_{N}$ and a set of equations that +relate unknown inputs, $x_{1},~x_{2},~...x_{N}$, then these can be written in a vector +matrix format as: + +$y=Ax$ + +Consider a problem with 2 DOF: + +$x_{1}+3x_{2}=1$ + +$2x_{1}+x_{2}=1$ + +$\left[ \begin{array}{cc} +1 & 3 \\ +2 & 1 \end{array} \right] +\left[\begin{array}{c} +x_{1} \\ +x_{2} \end{array}\right]= +\left[\begin{array}{c} +1 \\ +1\end{array}\right]$ + +The solution for $x_{1}$ and $x_{2}$ is the intersection of two lines: + + +```octave +x21=[-2:2]; +x11=1-3*x21; +x21=[-2:2]; +x22=1-2*x21; +plot(x11,x21,x21,x22) +``` + + + + + +For a 3$\times$3 matrix, the solution is the intersection of the 3 planes. + +$10x_{1}+2x_{2}+x_{3}=1$ + +$2x_{1}+x_{2}+x_{3}=1$ + +$x_{1}+2x_{2}+10x_{3}=1$ + +$\left[ \begin{array}{cc} +10 & 2 & 1\\ +2 & 1 & 1 \\ +1 & 2 & 10\end{array} \right] +\left[\begin{array}{c} +x_{1} \\ +x_{2} \\ +x_{3} \end{array}\right]= +\left[\begin{array}{c} +1 \\ +1 \\ +1\end{array}\right]$ + + +```octave +x11=linspace(-2,2,5); +x12=linspace(-2,2,5); +[X11,X12]=meshgrid(x11,x12); +X13=1-10*X11-2*X22; + +x21=linspace(-2,2,5); +x22=linspace(-2,2,5); +[X21,X22]=meshgrid(x21,x22); +X23=1-2*X11-X22; + +x31=linspace(-2,2,5); +x32=linspace(-2,2,5); +[X31,X32]=meshgrid(x31,x32); +X33=1/10*(1-X31-2*X32); + +mesh(X11,X12,X13); +hold on; +mesh(X21,X22,X23) +mesh(X31,X32,X33) +x=[10,2, 1;2,1, 1; 1, 2, 10]\[1;1;1]; +plot3(x(1),x(2),x(3),'o') +view(45,45) +``` + + + + + +After 3 DOF problems, the solutions are described as *hyperplane* intersections. Which are even harder to visualize + +## Gauss elimination +### Solving sets of equations systematically + +$\left[ \begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +2 & 1 & 1 & 1 \\ +1 & 2 & 10 & 1\end{array} +\right] $ + +Ay(2,:)-Ay(1,:)/5 = ([2 1 1 1]-1/5[10 2 1 1]) + +$\left[ \begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +1 & 2 & 10 & 1\end{array} +\right] $ + +Ay(3,:)-Ay(1,:)/10 = ([1 2 10 1]-1/10[10 2 1 1]) + +$\left[ \begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +0 & 1.8 & 9.9 & 0.9\end{array} +\right] $ + +Ay(3,:)-1.8\*5/3\*Ay(2,:) = ([0 1.8 9.9 0.9]-3\*[0 3/5 4/5 4/5]) + +$\left[ \begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +0 & 0 & 7.5 & -1.5\end{array} +\right] $ + +now, $7.5x_{3}=-1.5$ so $x_{3}=-\frac{1}{5}$ + +then, $3/5x_{2}+4/5(-1/5)=1$ so $x_{2}=\frac{8}{5}$ + +finally, $10x_{1}+2(8/5) + +Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? + + + +The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass: + +$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$ + +$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$ + +$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$ + +$m_{4}g-k(x_{4}-x_{3})=0$ + +in matrix form: + +$\left[ \begin{array}{cccc} +2k & -k & 0 & 0 \\ +-k & 2k & -k & 0 \\ +0 & -k & 2k & -k \\ +0 & 0 & -k & k \end{array} \right] +\left[ \begin{array}{c} +x_{1} \\ +x_{2} \\ +x_{3} \\ +x_{4} \end{array} \right]= +\left[ \begin{array}{c} +m_{1}g \\ +m_{2}g \\ +m_{3}g \\ +m_{4}g \end{array} \right]$ + + +```octave +k=10; % N/m +m1=1; % kg +m2=2; +m3=3; +m4=4; +g=9.81; % m/s^2 +K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k] +y=[m1*g;m2*g;m3*g;m4*g] +``` + + K = + + 20 -10 0 0 + -10 20 -10 0 + 0 -10 20 -10 + 0 0 -10 10 + + y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + + +```octave +K1=[K y]; +K1(2,:)=K1(1,:)/2+K1(2,:) +``` + + K1 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 -10.00000 20.00000 -10.00000 29.43000 + 0.00000 0.00000 -10.00000 10.00000 39.24000 + + + + +```octave +K2=K1; +K2(3,:)=K1(2,:)*2/3+K1(3,:) + +``` + + K2 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 0.00000 13.33333 -10.00000 45.78000 + 0.00000 0.00000 -10.00000 10.00000 39.24000 + + + + +```octave +K2(4,:)=-K2(3,:)*K2(4,3)/K2(3,3)+K2(4,:) +``` + + K2 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 0.00000 13.33333 -10.00000 45.78000 + 0.00000 0.00000 0.00000 2.50000 73.57500 + + + + +```octave +yp=K2(:,5); +x4=yp(4)/K2(4,4) +x3=(yp(3)+10*x4)/K2(3,3) +x2=(yp(2)+10*x3)/K2(2,2) +x1=(yp(1)+10*x2)/K2(1,1) +``` + + x4 = 29.430 + x3 = 25.506 + x2 = 18.639 + x1 = 9.8100 + + + +```octave +K\y +``` + + ans = + + 9.8100 + 18.6390 + 25.5060 + 29.4300 + + + +## Automate Gauss Elimination + +We can automate Gauss elimination with a function whose input is A and y: + +`x=GaussNaive(A,y)` + + +```octave +x=GaussNaive(K,y) +``` + + x = + + 9.8100 + 18.6390 + 25.5060 + 29.4300 + + + +## Problem (Diagonal element is zero) + +If a diagonal element is 0 or very small either: + +1. no solution found +2. errors are introduced + +Therefore, we would want to pivot before applying Gauss elimination + +Consider: + +(a) $\left[ \begin{array}{cccc} +0 & 2 & 3 \\ +4 & 6 & 7 \\ +2 & -3 & 6 \end{array} \right] +\left[ \begin{array}{c} +x_{1} \\ +x_{2} \\ +x_{3} \end{array} \right]= +\left[ \begin{array}{c} +8 \\ +-3 \\ +5\end{array} \right]$ + +(b) $\left[ \begin{array}{cccc} +0.0003 & 3.0000 \\ +1.0000 & 1.0000 \end{array} \right] +\left[ \begin{array}{c} +x_{1} \\ +x_{2} \end{array} \right]= +\left[ \begin{array}{c} +2.0001 \\ +1.0000 \end{array} \right]$ + + +```octave +format short +Aa=[0,2,3;4,6,7;2,-3,6]; ya=[8;-3;5]; +GaussNaive(Aa,ya) +Aa\ya +``` + + warning: division by zero + warning: called from + GaussNaive at line 16 column 12 + warning: division by zero + warning: division by zero + ans = + + NaN + NaN + NaN + + ans = + + -5.423913 + 0.021739 + 2.652174 + + + + +```octave +[x,Aug,npivots]=GaussPivot(Aa,ya) +``` + + x = + + -5.423913 + 0.021739 + 2.652174 + + Aug = + + 4.00000 6.00000 7.00000 -3.00000 + 0.00000 -6.00000 2.50000 6.50000 + 0.00000 0.00000 3.83333 10.16667 + + npivots = 2 + + + +```octave +format long +Ab=[0.3E-13,3.0000;1.0000,1.0000];yb=[2+0.1e-13;1.0000]; +GaussNaive(Ab,yb) +Ab\yb +``` + + ans = + + 0.325665420556713 + 0.666666666666667 + + ans = + + 0.333333333333333 + 0.666666666666667 + + + + +```octave +[x,Aug,npivots]=GaussPivot(Ab,yb) +Ab\yb +format short +``` + + x = + + 0.333333333333333 + 0.666666666666667 + + Aug = + + 1.000000000000000 1.000000000000000 1.000000000000000 + 0.000000000000000 2.999999999999970 1.999999999999980 + + npivots = 1 + ans = + + 0.333333333333333 + 0.666666666666667 + + + +### Spring-Mass System again +Now, 4 masses are connected in series to 4 springs with $K_{1}$=10 N/m, $K_{2}$=5 N/m, +$K_{3}$=2 N/m +and $K_{4}$=1 N/m. What are the final positions of the masses? + + + +The masses have the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass: + +$m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0$ + +$m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0$ + +$m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0$ + +$m_{4}g-k_{4}(x_{4}-x_{3})=0$ + +in matrix form: + +$\left[ \begin{array}{cccc} +k_1+k_2 & -k_2 & 0 & 0 \\ +-k_2 & k_2+k_3 & -k_3 & 0 \\ +0 & -k_3 & k_3+k_4 & -k_4 \\ +0 & 0 & -k_4 & k_4 \end{array} \right] +\left[ \begin{array}{c} +x_{1} \\ +x_{2} \\ +x_{3} \\ +x_{4} \end{array} \right]= +\left[ \begin{array}{c} +m_{1}g \\ +m_{2}g \\ +m_{3}g \\ +m_{4}g \end{array} \right]$ + + +```octave +k1=10; k2=5;k3=2;k4=1; % N/m +m1=1; % kg +m2=2; +m3=3; +m4=4; +g=9.81; % m/s^2 +K=[k1+k2 -k2 0 0; -k2, k2+k3, -k3 0; 0 -k3, k3+k4, -k4; 0 0 -k4 k4] +y=[m1*g;m2*g;m3*g;m4*g] +``` + + K = + + 15 -5 0 0 + -5 7 -2 0 + 0 -2 3 -1 + 0 0 -1 1 + + y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + +## Tridiagonal matrix + +This matrix, K, could be rewritten as 3 vectors e, f and g + +$e=\left[ \begin{array}{c} +0 \\ +-5 \\ +-2 \\ +-1 \end{array} \right]$ + +$f=\left[ \begin{array}{c} +15 \\ +7 \\ +3 \\ +1 \end{array} \right]$ + +$g=\left[ \begin{array}{c} +-5 \\ +-2 \\ +-1 \\ +0 \end{array} \right]$ + +Where all other components are 0 and the length of the vectors are n and the first component of e and the last component of g are zero + +`e(1)=0` + +`g(end)=0` + +No need to pivot and number of calculations reduced enormously. + +|method |Number of Floating point operations for n$\times$n-matrix| +|----------------|---------| +| Naive Gauss | n-cubed | +| Tridiagonal | n | + + +```octave +e=[0;-5;-2;-1]; +g=[-5;-2;-1;0]; +f=[15;7;3;1]; +Tridiag(e,f,g,y) + +``` + + ans = + + 9.8100 27.4680 61.8030 101.0430 + + + + +```octave +% tic ... t=toc +% is Matlab timer used for debugging programs +t_GE = zeros(1,100); +t_GE_tridiag = zeros(1,100); +t_TD = zeros(1,100); +for n = 1:200 + A = rand(n,n); + e = rand(n,1); e(1)=0; + f = rand(n,1); + g = rand(n,1); g(end)=0; + Atd=diag(f, 0) - diag(e(2:n), -1) - diag(g(1:n-1), 1); + b = rand(n,1); + tic; + x = GaussPivot(A,b); + t_GE(n) = toc; + tic; + x = GaussPivot(Atd,b); + t_GE_tridiag(n) = toc; + tic; + x = Tridiag(e,f,g,b); + t_TD(n) = toc; +end +``` + + +```octave +n=1:200; +loglog(n,t_GE,n,t_TD,n,t_GE_tridiag) +xlabel('number of elements') +ylabel('time (s)') +``` + + + + + + +```octave +plot(t_TD) +``` + + + + + + +```octave + +``` diff --git a/lecture_10/lecture_10.out b/lecture_10/lecture_10.out new file mode 100644 index 0000000..cb5b517 --- /dev/null +++ b/lecture_10/lecture_10.out @@ -0,0 +1,8 @@ +\BOOKMARK [1][-]{section.1}{Gauss Elimination}{}% 1 +\BOOKMARK [2][-]{subsubsection.1.0.1}{Solving sets of equations with matrix operations}{section.1}% 2 +\BOOKMARK [2][-]{subsection.1.1}{Gauss elimination}{section.1}% 3 +\BOOKMARK [3][-]{subsubsection.1.1.1}{Solving sets of equations systematically}{subsection.1.1}% 4 +\BOOKMARK [2][-]{subsection.1.2}{Automate Gauss Elimination}{section.1}% 5 +\BOOKMARK [2][-]{subsection.1.3}{Problem \(Diagonal element is zero\)}{section.1}% 6 +\BOOKMARK [3][-]{subsubsection.1.3.1}{Spring-Mass System again}{subsection.1.3}% 7 +\BOOKMARK [2][-]{subsection.1.4}{Tridiagonal matrix}{section.1}% 8 diff --git a/lecture_10/lecture_10.pdf b/lecture_10/lecture_10.pdf new file mode 100644 index 0000000..d75909f Binary files /dev/null and b/lecture_10/lecture_10.pdf differ diff --git a/lecture_10/lecture_10.tex b/lecture_10/lecture_10.tex new file mode 100644 index 0000000..633c945 --- /dev/null +++ b/lecture_10/lecture_10.tex @@ -0,0 +1,933 @@ + +% Default to the notebook output style + + + + +% Inherit from the specified cell style. + + + + + +\documentclass[11pt]{article} + + + + \usepackage[T1]{fontenc} + % Nicer default font (+ math font) than Computer Modern for most use cases + \usepackage{mathpazo} + + % Basic figure setup, for now with no caption control since it's done + % automatically by Pandoc (which extracts  syntax from Markdown). + \usepackage{graphicx} + % We will generate all images so they have a width \maxwidth. This means + % that they will get their normal width if they fit onto the page, but + % are scaled down if they would overflow the margins. + \makeatletter + \def\maxwidth{\ifdim\Gin@nat@width>\linewidth\linewidth + \else\Gin@nat@width\fi} + \makeatother + \let\Oldincludegraphics\includegraphics + % Set max figure width to be 80% of text width, for now hardcoded. + \renewcommand{\includegraphics}[1]{\Oldincludegraphics[width=.8\maxwidth]{#1}} + % Ensure that by default, figures have no caption (until we provide a + % proper Figure object with a Caption API and a way to capture that + % in the conversion process - todo). + \usepackage{caption} + \DeclareCaptionLabelFormat{nolabel}{} + \captionsetup{labelformat=nolabel} + + \usepackage{adjustbox} % Used to constrain images to a maximum size + \usepackage{xcolor} % Allow colors to be defined + \usepackage{enumerate} % Needed for markdown enumerations to work + \usepackage{geometry} % Used to adjust the document margins + \usepackage{amsmath} % Equations + \usepackage{amssymb} % Equations + \usepackage{textcomp} % defines textquotesingle + % Hack from http://tex.stackexchange.com/a/47451/13684: + \AtBeginDocument{% + \def\PYZsq{\textquotesingle}% Upright quotes in Pygmentized code + } + \usepackage{upquote} % Upright quotes for verbatim code + \usepackage{eurosym} % defines \euro + \usepackage[mathletters]{ucs} % Extended unicode (utf-8) support + \usepackage[utf8x]{inputenc} % Allow utf-8 characters in the tex document + \usepackage{fancyvrb} % verbatim replacement that allows latex + \usepackage{grffile} % extends the file name processing of package graphics + % to support a larger range + % The hyperref package gives us a pdf with properly built + % internal navigation ('pdf bookmarks' for the table of contents, + % internal cross-reference links, web links for URLs, etc.) + \usepackage{hyperref} + \usepackage{longtable} % longtable support required by pandoc >1.10 + \usepackage{booktabs} % table support for pandoc > 1.12.2 + \usepackage[inline]{enumitem} % IRkernel/repr support (it uses the enumerate* environment) + \usepackage[normalem]{ulem} % ulem is needed to support strikethroughs (\sout) + % normalem makes italics be italics, not underlines + + + + + % Colors for the hyperref package + \definecolor{urlcolor}{rgb}{0,.145,.698} + \definecolor{linkcolor}{rgb}{.71,0.21,0.01} + \definecolor{citecolor}{rgb}{.12,.54,.11} + + % ANSI colors + \definecolor{ansi-black}{HTML}{3E424D} + \definecolor{ansi-black-intense}{HTML}{282C36} + \definecolor{ansi-red}{HTML}{E75C58} + \definecolor{ansi-red-intense}{HTML}{B22B31} + \definecolor{ansi-green}{HTML}{00A250} + \definecolor{ansi-green-intense}{HTML}{007427} + \definecolor{ansi-yellow}{HTML}{DDB62B} + \definecolor{ansi-yellow-intense}{HTML}{B27D12} + \definecolor{ansi-blue}{HTML}{208FFB} + \definecolor{ansi-blue-intense}{HTML}{0065CA} + \definecolor{ansi-magenta}{HTML}{D160C4} + \definecolor{ansi-magenta-intense}{HTML}{A03196} + \definecolor{ansi-cyan}{HTML}{60C6C8} + \definecolor{ansi-cyan-intense}{HTML}{258F8F} + \definecolor{ansi-white}{HTML}{C5C1B4} + \definecolor{ansi-white-intense}{HTML}{A1A6B2} + + % commands and environments needed by pandoc snippets + % extracted from the output of `pandoc -s` + \providecommand{\tightlist}{% + \setlength{\itemsep}{0pt}\setlength{\parskip}{0pt}} + \DefineVerbatimEnvironment{Highlighting}{Verbatim}{commandchars=\\\{\}} + % Add ',fontsize=\small' for more characters per line + \newenvironment{Shaded}{}{} + \newcommand{\KeywordTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\DataTypeTok}[1]{\textcolor[rgb]{0.56,0.13,0.00}{{#1}}} + \newcommand{\DecValTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\BaseNTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\FloatTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\CharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\StringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\CommentTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textit{{#1}}}} + \newcommand{\OtherTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{{#1}}} + \newcommand{\AlertTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\FunctionTok}[1]{\textcolor[rgb]{0.02,0.16,0.49}{{#1}}} + \newcommand{\RegionMarkerTok}[1]{{#1}} + \newcommand{\ErrorTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\NormalTok}[1]{{#1}} + + % Additional commands for more recent versions of Pandoc + \newcommand{\ConstantTok}[1]{\textcolor[rgb]{0.53,0.00,0.00}{{#1}}} + \newcommand{\SpecialCharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\VerbatimStringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\SpecialStringTok}[1]{\textcolor[rgb]{0.73,0.40,0.53}{{#1}}} + \newcommand{\ImportTok}[1]{{#1}} + \newcommand{\DocumentationTok}[1]{\textcolor[rgb]{0.73,0.13,0.13}{\textit{{#1}}}} + \newcommand{\AnnotationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\CommentVarTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\VariableTok}[1]{\textcolor[rgb]{0.10,0.09,0.49}{{#1}}} + \newcommand{\ControlFlowTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\OperatorTok}[1]{\textcolor[rgb]{0.40,0.40,0.40}{{#1}}} + \newcommand{\BuiltInTok}[1]{{#1}} + \newcommand{\ExtensionTok}[1]{{#1}} + \newcommand{\PreprocessorTok}[1]{\textcolor[rgb]{0.74,0.48,0.00}{{#1}}} + \newcommand{\AttributeTok}[1]{\textcolor[rgb]{0.49,0.56,0.16}{{#1}}} + \newcommand{\InformationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\WarningTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + + + % Define a nice break command that doesn't care if a line doesn't already + % exist. + \def\br{\hspace*{\fill} \\* } + % Math Jax compatability definitions + \def\gt{>} + \def\lt{<} + % Document parameters + \title{lecture\_10} + + + + + % Pygments definitions + +\makeatletter +\def\PY@reset{\let\PY@it=\relax \let\PY@bf=\relax% + \let\PY@ul=\relax \let\PY@tc=\relax% + \let\PY@bc=\relax \let\PY@ff=\relax} +\def\PY@tok#1{\csname PY@tok@#1\endcsname} +\def\PY@toks#1+{\ifx\relax#1\empty\else% + \PY@tok{#1}\expandafter\PY@toks\fi} +\def\PY@do#1{\PY@bc{\PY@tc{\PY@ul{% + \PY@it{\PY@bf{\PY@ff{#1}}}}}}} +\def\PY#1#2{\PY@reset\PY@toks#1+\relax+\PY@do{#2}} + +\expandafter\def\csname PY@tok@gd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@gu\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.50,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@gt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.27,0.87}{##1}}} +\expandafter\def\csname PY@tok@gs\endcsname{\let\PY@bf=\textbf} +\expandafter\def\csname PY@tok@gr\endcsname{\def\PY@tc##1{\textcolor[rgb]{1.00,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@cm\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@vg\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@vi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@mh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@cs\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@ge\endcsname{\let\PY@it=\textit} +\expandafter\def\csname PY@tok@vc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@il\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@go\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.53,0.53}{##1}}} +\expandafter\def\csname PY@tok@cp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.74,0.48,0.00}{##1}}} +\expandafter\def\csname PY@tok@gi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@gh\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@ni\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.60,0.60,0.60}{##1}}} +\expandafter\def\csname PY@tok@nl\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@nn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@no\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@na\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.49,0.56,0.16}{##1}}} +\expandafter\def\csname PY@tok@nb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@nd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@ne\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.82,0.25,0.23}{##1}}} +\expandafter\def\csname PY@tok@nf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@si\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@s2\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@nt\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nv\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@s1\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ch\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@m\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@gp\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@sh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ow\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@sx\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@bp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c1\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@o\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@mf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@err\endcsname{\def\PY@bc##1{\setlength{\fboxsep}{0pt}\fcolorbox[rgb]{1.00,0.00,0.00}{1,1,1}{\strut ##1}}} +\expandafter\def\csname PY@tok@mb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@ss\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@sr\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@mo\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kd\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@mi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@cpf\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@kr\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@s\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@kp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@w\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.73,0.73}{##1}}} +\expandafter\def\csname PY@tok@kt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.69,0.00,0.25}{##1}}} +\expandafter\def\csname PY@tok@sc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@sb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@k\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@se\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.13}{##1}}} +\expandafter\def\csname PY@tok@sd\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} + +\def\PYZbs{\char`\\} +\def\PYZus{\char`\_} +\def\PYZob{\char`\{} +\def\PYZcb{\char`\}} +\def\PYZca{\char`\^} +\def\PYZam{\char`\&} +\def\PYZlt{\char`\<} +\def\PYZgt{\char`\>} +\def\PYZsh{\char`\#} +\def\PYZpc{\char`\%} +\def\PYZdl{\char`\$} +\def\PYZhy{\char`\-} +\def\PYZsq{\char`\'} +\def\PYZdq{\char`\"} +\def\PYZti{\char`\~} +% for compatibility with earlier versions +\def\PYZat{@} +\def\PYZlb{[} +\def\PYZrb{]} +\makeatother + + + % Exact colors from NB + \definecolor{incolor}{rgb}{0.0, 0.0, 0.5} + \definecolor{outcolor}{rgb}{0.545, 0.0, 0.0} + + + + + % Prevent overflowing lines due to hard-to-break entities + \sloppy + % Setup hyperref package + \hypersetup{ + breaklinks=true, % so long urls are correctly broken across lines + colorlinks=true, + urlcolor=urlcolor, + linkcolor=linkcolor, + citecolor=citecolor, + } + % Slightly bigger margins than the latex defaults + + \geometry{verbose,tmargin=1in,bmargin=1in,lmargin=1in,rmargin=1in} + + + + \begin{document} + + + \maketitle + + + + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}1}]:} \PY{c}{\PYZpc{}plot \PYZhy{}\PYZhy{}format svg} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}2}]:} \PY{n}{setdefaults} +\end{Verbatim} + + \section{Gauss Elimination}\label{gauss-elimination} + +\subsubsection{Solving sets of equations with matrix +operations}\label{solving-sets-of-equations-with-matrix-operations} + +The number of dimensions of a matrix indicate the degrees of freedom of +the system you are solving. + +If you have a set of known output, \(y_{1},~y_{2},~...y_{N}\) and a set +of equations that relate unknown inputs, \(x_{1},~x_{2},~...x_{N}\), +then these can be written in a vector matrix format as: + +\(y=Ax\) + +Consider a problem with 2 DOF: + +\(x_{1}+3x_{2}=1\) + +\(2x_{1}+x_{2}=1\) + +\(\left[ \begin{array}{cc} 1 & 3 \\ 2 & 1 \end{array} \right] \left[\begin{array}{c} x_{1} \\ x_{2} \end{array}\right]= \left[\begin{array}{c} 1 \\ 1\end{array}\right]\) + +The solution for \(x_{1}\) and \(x_{2}\) is the intersection of two +lines: + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}3}]:} \PY{n}{x21}\PY{p}{=}\PY{p}{[}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{:}\PY{l+m+mi}{2}\PY{p}{]}\PY{p}{;} + \PY{n}{x11}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{l+m+mi}{3}\PY{o}{*}\PY{n}{x21}\PY{p}{;} + \PY{n}{x21}\PY{p}{=}\PY{p}{[}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{:}\PY{l+m+mi}{2}\PY{p}{]}\PY{p}{;} + \PY{n}{x22}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{x21}\PY{p}{;} + \PY{n+nb}{plot}\PY{p}{(}\PY{n}{x11}\PY{p}{,}\PY{n}{x21}\PY{p}{,}\PY{n}{x21}\PY{p}{,}\PY{n}{x22}\PY{p}{)} +\end{Verbatim} + + \begin{center} + \adjustimage{max size={0.9\linewidth}{0.9\paperheight}}{lecture_10_files/lecture_10_3_0.pdf} + \end{center} + { \hspace*{\fill} \\} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}4}]:} \PY{n}{A}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{;}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} + \PY{n}{A}\PY{o}{\PYZbs{}}\PY{n}{y} \PY{c}{\PYZpc{} matlab\PYZsq{}s Ax=y solution for x} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 0.40000 + 0.20000 + + + \end{Verbatim} + + For a \(3\times3\) matrix, the solution is the intersection of the 3 +planes. + +\(10x_{1}+2x_{2}+x_{3}=1\) + +\(2x_{1}+x_{2}+x_{3}=1\) + +\(x_{1}+2x_{2}+10x_{3}=1\) + +$\left[ \begin{array}{ccc} 10 & 2 & 1\\ 2 & 1 & 1 \\ 1 & 2 & 10\end{array} \right] + \left[\begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \end{array}\right]= + \left[\begin{array}{c} 1 \\ 1 \\ 1\end{array}\right]$ + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}9}]:} \PY{n}{N}\PY{p}{=}\PY{l+m+mi}{25}\PY{p}{;} + \PY{n}{x11}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{n}{x12}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{p}{[}\PY{n}{X11}\PY{p}{,}\PY{n}{X12}\PY{p}{]}\PY{p}{=}\PY{n+nb}{meshgrid}\PY{p}{(}\PY{n}{x11}\PY{p}{,}\PY{n}{x12}\PY{p}{)}\PY{p}{;} + \PY{n}{X13}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{l+m+mi}{10}\PY{o}{*}\PY{n}{X11}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{X12}\PY{p}{;} + + \PY{n}{x21}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{n}{x22}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{p}{[}\PY{n}{X21}\PY{p}{,}\PY{n}{X22}\PY{p}{]}\PY{p}{=}\PY{n+nb}{meshgrid}\PY{p}{(}\PY{n}{x21}\PY{p}{,}\PY{n}{x22}\PY{p}{)}\PY{p}{;} + \PY{n}{X23}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{X11}\PY{o}{\PYZhy{}}\PY{n}{X22}\PY{p}{;} + + \PY{n}{x31}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{n}{x32}\PY{p}{=}\PY{n+nb}{linspace}\PY{p}{(}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{p}{[}\PY{n}{X31}\PY{p}{,}\PY{n}{X32}\PY{p}{]}\PY{p}{=}\PY{n+nb}{meshgrid}\PY{p}{(}\PY{n}{x31}\PY{p}{,}\PY{n}{x32}\PY{p}{)}\PY{p}{;} + \PY{n}{X33}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{10}\PY{o}{*}\PY{p}{(}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{n}{X31}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{X32}\PY{p}{)}\PY{p}{;} + + \PY{n+nb}{mesh}\PY{p}{(}\PY{n}{X11}\PY{p}{,}\PY{n}{X12}\PY{p}{,}\PY{n}{X13}\PY{p}{)}\PY{p}{;} + \PY{n+nb}{hold} \PY{n}{on}\PY{p}{;} + \PY{n+nb}{mesh}\PY{p}{(}\PY{n}{X21}\PY{p}{,}\PY{n}{X22}\PY{p}{,}\PY{n}{X23}\PY{p}{)} + \PY{n+nb}{mesh}\PY{p}{(}\PY{n}{X31}\PY{p}{,}\PY{n}{X32}\PY{p}{,}\PY{n}{X33}\PY{p}{)} + \PY{n}{x}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{10}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,} \PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{,} \PY{l+m+mi}{1}\PY{p}{;} \PY{l+m+mi}{1}\PY{p}{,} \PY{l+m+mi}{2}\PY{p}{,} \PY{l+m+mi}{10}\PY{p}{]}\PY{o}{\PYZbs{}}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} + \PY{n}{plot3}\PY{p}{(}\PY{n}{x}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{,}\PY{n}{x}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{,}\PY{n}{x}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{o\PYZsq{}}\PY{p}{)} + \PY{n+nb}{xlabel}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{x1\PYZsq{}}\PY{p}{)} + \PY{n+nb}{ylabel}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{x2\PYZsq{}}\PY{p}{)} + \PY{n+nb}{zlabel}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{x3\PYZsq{}}\PY{p}{)} + \PY{n+nb}{view}\PY{p}{(}\PY{l+m+mi}{10}\PY{p}{,}\PY{l+m+mi}{45}\PY{p}{)} +\end{Verbatim} + + \begin{center} + \adjustimage{max size={0.9\linewidth}{0.9\paperheight}}{lecture_10_files/lecture_10_6_0.pdf} + \end{center} + { \hspace*{\fill} \\} + + After 3 DOF problems, the solutions are described as \emph{hyperplane} +intersections. Which are even harder to visualize + + \subsection{Gauss elimination}\label{gauss-elimination} + +\subsubsection{Solving sets of equations +systematically}\label{solving-sets-of-equations-systematically} + +$\left[ +\begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +2 & 1 & 1 & 1 \\ +1 & 2 & 10 & 1\end{array} +\right] $ + +Ay(2,:)-Ay(1,:)/5 = ({[}2 1 1 1{]}-1/5{[}10 2 1 1{]}) + +$\left[ +\begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +1 & 2 & 10 & 1\end{array} +\right] $ + +Ay(3,:)-Ay(1,:)/10 = ({[}1 2 10 1{]}-1/10{[}10 2 1 1{]}) + +$\left[ +\begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +0 & 1.8 & 9.9 & 0.9\end{array} +\right] $ + +Ay(3,:)-1.8*5/3*Ay(2,:) = ({[}0 1.8 9.9 0.9{]}-3*{[}0 3/5 4/5 4/5{]}) + +$\left[ +\begin{array}{ccc|c} + & A & & y \\ +10 & 2 & 1 & 1\\ +0 & 3/5 & 4/5 & 4/5 \\ +0 & 0 & 7.5 & -1.5\end{array} +\right]$ + +now, \(7.5x_{3}=-1.5\) so \(x_{3}=-\frac{1}{5}\) + +then, \(3/5x_{2}+4/5(-1/5)=1\) so \(x_{2}=\frac{8}{5}\) + +finally, \(10x_{1}+2(8/5)+1(-\frac{1}{5})=1\) + + Consider the problem again from the intro to Linear Algebra, 4 masses +are connected in series to 4 springs with K=10 N/m. What are the final +positions of the masses? + +\begin{figure}[htbp] +\centering +\includegraphics{../lecture_09/mass_springs.svg} +\caption{Springs-masses} +\end{figure} + +The masses haves the following amounts, 1, 2, 3, and 4 kg for masses +1-4. Using a FBD for each mass: + +\(m_{1}g+k(x_{2}-x_{1})-kx_{1}=0\) + +\(m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0\) + +\(m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0\) + +\(m_{4}g-k(x_{4}-x_{3})=0\) + +in matrix form: + +\(\left[ \begin{array}{cccc} 2k & -k & 0 & 0 \\ -k & 2k & -k & 0 \\ 0 & -k & 2k & -k \\ 0 & 0 & -k & k \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \end{array} \right]= \left[ \begin{array}{c} m_{1}g \\ m_{2}g \\ m_{3}g \\ m_{4}g \end{array} \right]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}10}]:} \PY{n}{k}\PY{p}{=}\PY{l+m+mi}{10}\PY{p}{;} \PY{c}{\PYZpc{} N/m} + \PY{n}{m1}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} \PY{c}{\PYZpc{} kg} + \PY{n}{m2}\PY{p}{=}\PY{l+m+mi}{2}\PY{p}{;} + \PY{n}{m3}\PY{p}{=}\PY{l+m+mi}{3}\PY{p}{;} + \PY{n}{m4}\PY{p}{=}\PY{l+m+mi}{4}\PY{p}{;} + \PY{n}{g}\PY{p}{=}\PY{l+m+mf}{9.81}\PY{p}{;} \PY{c}{\PYZpc{} m/s\PYZca{}2} + \PY{n}{K}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{0} \PY{l+m+mi}{0}\PY{p}{;} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{0}\PY{p}{;} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k}\PY{p}{;} \PY{l+m+mi}{0} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{n}{k}\PY{p}{]} + \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{n}{m1}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m2}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m3}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m4}\PY{o}{*}\PY{n}{g}\PY{p}{]} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K = + + 20 -10 0 0 + -10 20 -10 0 + 0 -10 20 -10 + 0 0 -10 10 + +y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}11}]:} \PY{n}{K1}\PY{p}{=}\PY{p}{[}\PY{n}{K} \PY{n}{y}\PY{p}{]}\PY{p}{;} + \PY{n}{K1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{p}{=}\PY{n}{K1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{o}{/}\PY{l+m+mi}{2}\PY{o}{+}\PY{n}{K1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K1 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 -10.00000 20.00000 -10.00000 29.43000 + 0.00000 0.00000 -10.00000 10.00000 39.24000 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}12}]:} \PY{n}{K2}\PY{p}{=}\PY{n}{K1}\PY{p}{;} + \PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{p}{=}\PY{n}{K1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{o}{*}\PY{l+m+mi}{2}\PY{o}{/}\PY{l+m+mi}{3}\PY{o}{+}\PY{n}{K1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{p}{:}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K2 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 0.00000 13.33333 -10.00000 45.78000 + 0.00000 0.00000 -10.00000 10.00000 39.24000 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}13}]:} \PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{p}{=}\PY{o}{\PYZhy{}}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{o}{*}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{/}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{+}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{p}{:}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K2 = + + 20.00000 -10.00000 0.00000 0.00000 9.81000 + 0.00000 15.00000 -10.00000 0.00000 24.52500 + 0.00000 0.00000 13.33333 -10.00000 45.78000 + 0.00000 0.00000 0.00000 2.50000 73.57500 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}14}]:} \PY{n}{yp}\PY{p}{=}\PY{n}{K2}\PY{p}{(}\PY{p}{:}\PY{p}{,}\PY{l+m+mi}{5}\PY{p}{)}\PY{p}{;} + \PY{n}{x4}\PY{p}{=}\PY{n}{yp}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{)}\PY{o}{/}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)} + \PY{n}{x3}\PY{p}{=}\PY{p}{(}\PY{n}{yp}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{+}\PY{l+m+mi}{10}\PY{o}{*}\PY{n}{x4}\PY{p}{)}\PY{o}{/}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)} + \PY{n}{x2}\PY{p}{=}\PY{p}{(}\PY{n}{yp}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{+}\PY{l+m+mi}{10}\PY{o}{*}\PY{n}{x3}\PY{p}{)}\PY{o}{/}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)} + \PY{n}{x1}\PY{p}{=}\PY{p}{(}\PY{n}{yp}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{+}\PY{l+m+mi}{10}\PY{o}{*}\PY{n}{x2}\PY{p}{)}\PY{o}{/}\PY{n}{K2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +x4 = 29.430 +x3 = 25.506 +x2 = 18.639 +x1 = 9.8100 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}15}]:} \PY{n}{K}\PY{o}{\PYZbs{}}\PY{n}{y} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 9.8100 + 18.6390 + 25.5060 + 29.4300 + + + \end{Verbatim} + + \subsection{Automate Gauss +Elimination}\label{automate-gauss-elimination} + +We can automate Gauss elimination with a function whose input is A and +y: + +\texttt{x=GaussNaive(A,y)} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}16}]:} \PY{n}{x}\PY{p}{=}\PY{n}{GaussNaive}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{n}{y}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +x = + + 9.8100 + 18.6390 + 25.5060 + 29.4300 + + + \end{Verbatim} + + \subsection{Problem (Diagonal element is +zero)}\label{problem-diagonal-element-is-zero} + +If a diagonal element is 0 or very small either: + +\begin{enumerate} +\def\labelenumi{\arabic{enumi}.} +\tightlist +\item + no solution found +\item + errors are introduced +\end{enumerate} + +Therefore, we would want to pivot before applying Gauss elimination + +Consider: + +\begin{enumerate} +\def\labelenumi{(\alph{enumi})} +\item + \(\left[ \begin{array}{cccc} 0 & 2 & 3 \\ 4 & 6 & 7 \\ 2 & -3 & 6 \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \end{array} \right]= \left[ \begin{array}{c} 8 \\ -3 \\ 5\end{array} \right]\) +\item + \(\left[ \begin{array}{cccc} 0.0003 & 3.0000 \\ 1.0000 & 1.0000 \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \end{array} \right]= \left[ \begin{array}{c} 2.0001 \\ 1.0000 \end{array} \right]\) +\end{enumerate} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}17}]:} \PY{n}{format} \PY{n}{short} + \PY{n}{Aa}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{0}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{;}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{6}\PY{p}{,}\PY{l+m+mi}{7}\PY{p}{;}\PY{l+m+mi}{2}\PY{p}{,}\PY{o}{\PYZhy{}}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{6}\PY{p}{]}\PY{p}{;} \PY{n}{ya}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{8}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{3}\PY{p}{;}\PY{l+m+mi}{5}\PY{p}{]}\PY{p}{;} + \PY{n}{GaussNaive}\PY{p}{(}\PY{n}{Aa}\PY{p}{,}\PY{n}{ya}\PY{p}{)} + \PY{n}{Aa}\PY{o}{\PYZbs{}}\PY{n}{ya} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +warning: division by zero +warning: called from + GaussNaive at line 16 column 12 +warning: division by zero +warning: division by zero +ans = + + NaN + NaN + NaN + +ans = + + -5.423913 + 0.021739 + 2.652174 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}32}]:} \PY{p}{[}\PY{n}{x}\PY{p}{,}\PY{n}{Aug}\PY{p}{,}\PY{n}{npivots}\PY{p}{]}\PY{p}{=}\PY{n}{GaussPivot}\PY{p}{(}\PY{n}{Aa}\PY{p}{,}\PY{n}{ya}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +x = + + -5.423913 + 0.021739 + 2.652174 + +Aug = + + 4.00000 6.00000 7.00000 -3.00000 + 0.00000 -6.00000 2.50000 6.50000 + 0.00000 0.00000 3.83333 10.16667 + +npivots = 2 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}33}]:} \PY{n}{format} \PY{n}{long} + \PY{n}{Ab}\PY{p}{=}\PY{p}{[}\PY{l+m+mf}{0.3E\PYZhy{}13}\PY{p}{,}\PY{l+m+mf}{3.0000}\PY{p}{;}\PY{l+m+mf}{1.0000}\PY{p}{,}\PY{l+m+mf}{1.0000}\PY{p}{]}\PY{p}{;}\PY{n}{yb}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{o}{+}\PY{l+m+mf}{0.1e\PYZhy{}13}\PY{p}{;}\PY{l+m+mf}{1.0000}\PY{p}{]}\PY{p}{;} + \PY{n}{GaussNaive}\PY{p}{(}\PY{n}{Ab}\PY{p}{,}\PY{n}{yb}\PY{p}{)} + \PY{n}{Ab}\PY{o}{\PYZbs{}}\PY{n}{yb} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 0.325665420556713 + 0.666666666666667 + +ans = + + 0.333333333333333 + 0.666666666666667 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}34}]:} \PY{p}{[}\PY{n}{x}\PY{p}{,}\PY{n}{Aug}\PY{p}{,}\PY{n}{npivots}\PY{p}{]}\PY{p}{=}\PY{n}{GaussPivot}\PY{p}{(}\PY{n}{Ab}\PY{p}{,}\PY{n}{yb}\PY{p}{)} + \PY{n}{Ab}\PY{o}{\PYZbs{}}\PY{n}{yb} + \PY{n}{format} \PY{n}{short} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +x = + + 0.333333333333333 + 0.666666666666667 + +Aug = + + 1.000000000000000 1.000000000000000 1.000000000000000 + 0.000000000000000 2.999999999999970 1.999999999999980 + +npivots = 1 +ans = + + 0.333333333333333 + 0.666666666666667 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}36}]:} \PY{c}{\PYZpc{} determinant is (\PYZhy{}1)\PYZca{}(number\PYZus{}of\PYZus{}pivots)*diagonal\PYZus{}elements} + \PY{n+nb}{det}\PY{p}{(}\PY{n}{Ab}\PY{p}{)} + \PY{n}{Aug}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{Aug}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = -3.0000 +ans = 3.0000 + + \end{Verbatim} + + \subsubsection{Spring-Mass System again}\label{spring-mass-system-again} + +Now, 4 masses are connected in series to 4 springs with \(K_{1}\)=10 +N/m, \(K_{2}\)=5 N/m, \(K_{3}\)=2 N/m and \(K_{4}\)=1 N/m. What are the +final positions of the masses? + +\begin{figure}[htbp] +\centering +\includegraphics{../lecture_09/mass_springs.svg} +\caption{Springs-masses} +\end{figure} + +The masses have the following amounts, 1, 2, 3, and 4 kg for masses 1-4. +Using a FBD for each mass: + +\(m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0\) + +\(m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0\) + +\(m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0\) + +\(m_{4}g-k_{4}(x_{4}-x_{3})=0\) + +in matrix form: + +\(\left[ \begin{array}{cccc} k_1+k_2 & -k_2 & 0 & 0 \\ -k_2 & k_2+k_3 & -k_3 & 0 \\ 0 & -k_3 & k_3+k_4 & -k_4 \\ 0 & 0 & -k_4 & k_4 \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \end{array} \right]= \left[ \begin{array}{c} m_{1}g \\ m_{2}g \\ m_{3}g \\ m_{4}g \end{array} \right]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}24}]:} \PY{n}{k1}\PY{p}{=}\PY{l+m+mi}{10}\PY{p}{;} \PY{n}{k2}\PY{p}{=}\PY{l+m+mi}{5}\PY{p}{;}\PY{n}{k3}\PY{p}{=}\PY{l+m+mi}{2}\PY{p}{;}\PY{n}{k4}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} \PY{c}{\PYZpc{} N/m} + \PY{n}{m1}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} \PY{c}{\PYZpc{} kg} + \PY{n}{m2}\PY{p}{=}\PY{l+m+mi}{2}\PY{p}{;} + \PY{n}{m3}\PY{p}{=}\PY{l+m+mi}{3}\PY{p}{;} + \PY{n}{m4}\PY{p}{=}\PY{l+m+mi}{4}\PY{p}{;} + \PY{n}{g}\PY{p}{=}\PY{l+m+mf}{9.81}\PY{p}{;} \PY{c}{\PYZpc{} m/s\PYZca{}2} + \PY{n}{K}\PY{p}{=}\PY{p}{[}\PY{n}{k1}\PY{o}{+}\PY{n}{k2} \PY{o}{\PYZhy{}}\PY{n}{k2} \PY{l+m+mi}{0} \PY{l+m+mi}{0}\PY{p}{;} \PY{o}{\PYZhy{}}\PY{n}{k2}\PY{p}{,} \PY{n}{k2}\PY{o}{+}\PY{n}{k3}\PY{p}{,} \PY{o}{\PYZhy{}}\PY{n}{k3} \PY{l+m+mi}{0}\PY{p}{;} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k3}\PY{p}{,} \PY{n}{k3}\PY{o}{+}\PY{n}{k4}\PY{p}{,} \PY{o}{\PYZhy{}}\PY{n}{k4}\PY{p}{;} \PY{l+m+mi}{0} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k4} \PY{n}{k4}\PY{p}{]} + \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{n}{m1}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m2}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m3}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m4}\PY{o}{*}\PY{n}{g}\PY{p}{]} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K = + + 15 -5 0 0 + -5 7 -2 0 + 0 -2 3 -1 + 0 0 -1 1 + +y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + \end{Verbatim} + + \subsection{Tridiagonal matrix}\label{tridiagonal-matrix} + +This matrix, K, could be rewritten as 3 vectors e, f and g + +\(e=\left[ \begin{array}{c} 0 \\ -5 \\ -2 \\ -1 \end{array} \right]\) + +\(f=\left[ \begin{array}{c} 15 \\ 7 \\ 3 \\ 1 \end{array} \right]\) + +\(g=\left[ \begin{array}{c} -5 \\ -2 \\ -1 \\ 0 \end{array} \right]\) + +Where all other components are 0 and the length of the vectors are n and +the first component of e and the last component of g are zero + +\texttt{e(1)=0} + +\texttt{g(end)=0} + +No need to pivot and number of calculations reduced enormously. + +\begin{longtable}[c]{@{}ll@{}} +\toprule +method & Number of Floating point operations for +n\(\times\)n-matrix\tabularnewline +\midrule +\endhead +Gauss & n-cubed\tabularnewline +Tridiagonal & n\tabularnewline +\bottomrule +\end{longtable} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}25}]:} \PY{n+nb}{e}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{0}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{5}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} + \PY{n}{g}\PY{p}{=}\PY{p}{[}\PY{o}{\PYZhy{}}\PY{l+m+mi}{5}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{2}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{]}\PY{p}{;} + \PY{n}{f}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{15}\PY{p}{;}\PY{l+m+mi}{7}\PY{p}{;}\PY{l+m+mi}{3}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} + \PY{n}{Tridiag}\PY{p}{(}\PY{n+nb}{e}\PY{p}{,}\PY{n}{f}\PY{p}{,}\PY{n}{g}\PY{p}{,}\PY{n}{y}\PY{p}{)} + \PY{n}{K}\PY{o}{\PYZbs{}}\PY{n}{y} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 9.8100 27.4680 61.8030 101.0430 + +ans = + + 9.8100 + 27.4680 + 61.8030 + 101.0430 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}26}]:} \PY{c}{\PYZpc{} tic ... t=toc } + \PY{c}{\PYZpc{} is Matlab timer used for debugging programs} + \PY{n}{t\PYZus{}GE} \PY{p}{=} \PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{100}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}GE\PYZus{}tridiag} \PY{p}{=} \PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{100}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}TD} \PY{p}{=} \PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{100}\PY{p}{)}\PY{p}{;} + \PY{c}{\PYZpc{}for n = 1:200} + \PY{k}{for} \PY{n}{n}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{100} + \PY{n}{A} \PY{p}{=} \PY{n+nb}{rand}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{n}{n}\PY{p}{)}\PY{p}{;} + \PY{n+nb}{e} \PY{p}{=} \PY{n+nb}{rand}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} \PY{n+nb}{e}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{p}{;} + \PY{n}{f} \PY{p}{=} \PY{n+nb}{rand}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{g} \PY{p}{=} \PY{n+nb}{rand}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} \PY{n}{g}\PY{p}{(}\PY{k}{end}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{p}{;} + \PY{n}{Atd}\PY{p}{=}\PY{n+nb}{diag}\PY{p}{(}\PY{n}{f}\PY{p}{,} \PY{l+m+mi}{0}\PY{p}{)} \PY{o}{\PYZhy{}} \PY{n+nb}{diag}\PY{p}{(}\PY{n+nb}{e}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{:}\PY{n}{n}\PY{p}{)}\PY{p}{,} \PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{)} \PY{o}{\PYZhy{}} \PY{n+nb}{diag}\PY{p}{(}\PY{n}{g}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{:}\PY{n}{n}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{,} \PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{b} \PY{p}{=} \PY{n+nb}{rand}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} + \PY{n}{x} \PY{p}{=} \PY{n}{GaussPivot}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{n}{b}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}GE}\PY{p}{(}\PY{n}{n}\PY{p}{)} \PY{p}{=} \PY{n+nb}{toc}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} + \PY{n}{x} \PY{p}{=} \PY{n}{A}\PY{o}{\PYZbs{}}\PY{n}{b}\PY{p}{;} + \PY{n}{t\PYZus{}GE\PYZus{}tridiag}\PY{p}{(}\PY{n}{n}\PY{p}{)} \PY{p}{=} \PY{n+nb}{toc}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} + \PY{n}{x} \PY{p}{=} \PY{n}{Tridiag}\PY{p}{(}\PY{n+nb}{e}\PY{p}{,}\PY{n}{f}\PY{p}{,}\PY{n}{g}\PY{p}{,}\PY{n}{b}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}TD}\PY{p}{(}\PY{n}{n}\PY{p}{)} \PY{p}{=} \PY{n+nb}{toc}\PY{p}{;} + \PY{k}{end} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}28}]:} \PY{n}{n}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{100}\PY{p}{;} + \PY{n+nb}{loglog}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}GE}\PY{p}{,}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}TD}\PY{p}{,}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}GE\PYZus{}tridiag}\PY{p}{)} + \PY{n+nb}{legend}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{Gauss elim\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{Matlab \PYZbs{}\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{TriDiag\PYZsq{}}\PY{p}{)} + \PY{n+nb}{xlabel}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{number of elements\PYZsq{}}\PY{p}{)} + \PY{n+nb}{ylabel}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{time (s)\PYZsq{}}\PY{p}{)} +\end{Verbatim} + + \begin{center} + \adjustimage{max size={0.9\linewidth}{0.9\paperheight}}{lecture_10_files/lecture_10_29_0.pdf} + \end{center} + { \hspace*{\fill} \\} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}29}]:} \PY{p}{[}\PY{n}{x}\PY{p}{,}\PY{n}{Aug}\PY{p}{,}\PY{n}{npivots}\PY{p}{]}\PY{p}{=}\PY{n}{GaussPivot}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{n}{y}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +x = + + 9.8100 + 27.4680 + 61.8030 + 101.0430 + +Aug = + + 15.00000 -5.00000 0.00000 0.00000 9.81000 + 0.00000 5.33333 -2.00000 0.00000 22.89000 + 0.00000 0.00000 2.25000 -1.00000 38.01375 + 0.00000 0.00000 0.00000 0.55556 56.13500 + +npivots = 0 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}30}]:} \PY{n}{A}\PY{p}{=}\PY{n}{Aug}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{4}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 15.00000 -5.00000 0.00000 0.00000 + 0.00000 5.33333 -2.00000 0.00000 + 0.00000 0.00000 2.25000 -1.00000 + 0.00000 0.00000 0.00000 0.55556 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}31}]:} \PY{n+nb}{det}\PY{p}{(}\PY{n}{A}\PY{p}{)} + \PY{n}{detA}\PY{p}{=}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = 100.00 +detA = 100.00 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor} }]:} +\end{Verbatim} + + + % Add a bibliography block to the postdoc + + + + \end{document} diff --git a/lecture_10/lecture_10_files/lecture_10_27_0.pdf b/lecture_10/lecture_10_files/lecture_10_27_0.pdf new file mode 100644 index 0000000..8606584 Binary files /dev/null and b/lecture_10/lecture_10_files/lecture_10_27_0.pdf differ diff --git a/lecture_10/lecture_10_files/lecture_10_27_0.svg b/lecture_10/lecture_10_files/lecture_10_27_0.svg new file mode 100644 index 0000000..ddf2410 --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_27_0.svg @@ -0,0 +1,129 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="63.6,362.4 534.9,362.4 534.9,16.8 63.6,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,362.4 L76.1,362.4 M535.0,362.4 L522.5,362.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,368.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-4</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,336.4 L69.8,336.4 M535.0,336.4 L528.8,336.4 M63.6,321.2 L69.8,321.2 M535.0,321.2 L528.8,321.2 M63.6,310.4 L69.8,310.4 M535.0,310.4 L528.8,310.4 M63.6,302.0 L69.8,302.0 M535.0,302.0 L528.8,302.0 M63.6,295.1 L69.8,295.1 M535.0,295.1 L528.8,295.1 M63.6,289.4 L69.8,289.4 M535.0,289.4 L528.8,289.4 M63.6,284.4 L69.8,284.4 M535.0,284.4 L528.8,284.4 M63.6,279.9 L69.8,279.9 M535.0,279.9 L528.8,279.9 M63.6,276.0 L76.1,276.0 M535.0,276.0 L522.5,276.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,282.0)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-3</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,250.0 L69.8,250.0 M535.0,250.0 L528.8,250.0 M63.6,234.7 L69.8,234.7 M535.0,234.7 L528.8,234.7 M63.6,223.9 L69.8,223.9 M535.0,223.9 L528.8,223.9 M63.6,215.6 L69.8,215.6 M535.0,215.6 L528.8,215.6 M63.6,208.7 L69.8,208.7 M535.0,208.7 L528.8,208.7 M63.6,202.9 L69.8,202.9 M535.0,202.9 L528.8,202.9 M63.6,197.9 L69.8,197.9 M535.0,197.9 L528.8,197.9 M63.6,193.5 L69.8,193.5 M535.0,193.5 L528.8,193.5 M63.6,189.5 L76.1,189.5 M535.0,189.5 L522.5,189.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,195.5)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-2</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,163.5 L69.8,163.5 M535.0,163.5 L528.8,163.5 M63.6,148.3 L69.8,148.3 M535.0,148.3 L528.8,148.3 M63.6,137.5 L69.8,137.5 M535.0,137.5 L528.8,137.5 M63.6,129.1 L69.8,129.1 M535.0,129.1 L528.8,129.1 M63.6,122.3 L69.8,122.3 M535.0,122.3 L528.8,122.3 M63.6,116.5 L69.8,116.5 M535.0,116.5 L528.8,116.5 M63.6,111.5 L69.8,111.5 M535.0,111.5 L528.8,111.5 M63.6,107.1 L69.8,107.1 M535.0,107.1 L528.8,107.1 M63.6,103.1 L76.1,103.1 M535.0,103.1 L522.5,103.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,109.1)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-1</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,77.1 L69.8,77.1 M535.0,77.1 L528.8,77.1 M63.6,61.9 L69.8,61.9 M535.0,61.9 L528.8,61.9 M63.6,51.1 L69.8,51.1 M535.0,51.1 L528.8,51.1 M63.6,42.7 L69.8,42.7 M535.0,42.7 L528.8,42.7 M63.6,35.9 L69.8,35.9 M535.0,35.9 L528.8,35.9 M63.6,30.1 L69.8,30.1 M535.0,30.1 L528.8,30.1 M63.6,25.1 L69.8,25.1 M535.0,25.1 L528.8,25.1 M63.6,20.7 L69.8,20.7 M535.0,20.7 L528.8,20.7 M63.6,16.7 L76.1,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,22.7)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">0</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,362.4 L63.6,349.9 M63.6,16.7 L63.6,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(63.6,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">0</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M110.9,362.4 L110.9,356.2 M110.9,16.7 L110.9,22.9 M138.6,362.4 L138.6,356.2 M138.6,16.7 L138.6,22.9 M158.2,362.4 L158.2,356.2 M158.2,16.7 L158.2,22.9 M173.4,362.4 L173.4,356.2 M173.4,16.7 L173.4,22.9 M185.9,362.4 L185.9,356.2 M185.9,16.7 L185.9,22.9 M196.4,362.4 L196.4,356.2 M196.4,16.7 L196.4,22.9 M205.5,362.4 L205.5,356.2 M205.5,16.7 L205.5,22.9 M213.5,362.4 L213.5,356.2 M213.5,16.7 L213.5,22.9 M220.7,362.4 L220.7,349.9 M220.7,16.7 L220.7,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(220.7,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">1</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M268.0,362.4 L268.0,356.2 M268.0,16.7 L268.0,22.9 M295.7,362.4 L295.7,356.2 M295.7,16.7 L295.7,22.9 M315.3,362.4 L315.3,356.2 M315.3,16.7 L315.3,22.9 M330.6,362.4 L330.6,356.2 M330.6,16.7 L330.6,22.9 M343.0,362.4 L343.0,356.2 M343.0,16.7 L343.0,22.9 M353.5,362.4 L353.5,356.2 M353.5,16.7 L353.5,22.9 M362.6,362.4 L362.6,356.2 M362.6,16.7 L362.6,22.9 M370.7,362.4 L370.7,356.2 M370.7,16.7 L370.7,22.9 M377.9,362.4 L377.9,349.9 M377.9,16.7 L377.9,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(377.9,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">2</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M425.2,362.4 L425.2,356.2 M425.2,16.7 L425.2,22.9 M452.8,362.4 L452.8,356.2 M452.8,16.7 L452.8,22.9 M472.5,362.4 L472.5,356.2 M472.5,16.7 L472.5,22.9 M487.7,362.4 L487.7,356.2 M487.7,16.7 L487.7,22.9 M500.1,362.4 L500.1,356.2 M500.1,16.7 L500.1,22.9 M510.7,362.4 L510.7,356.2 M510.7,16.7 L510.7,22.9 M519.8,362.4 L519.8,356.2 M519.8,16.7 L519.8,22.9 M527.8,362.4 L527.8,356.2 M527.8,16.7 L527.8,22.9 M535.0,362.4 L535.0,349.9 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">3</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,16.7 L63.6,362.4 L535.0,362.4 L535.0,16.7 L63.6,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(19.1,189.6) rotate(-90)"> + <text><tspan font-family="{}">time (s)</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(299.3,413.4)"> + <text><tspan font-family="{}">number of elements</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M63.6,308.3 L110.9,285.4 L138.6,274.3 L158.2,261.5 L173.4,250.3 L185.9,233.1 L196.4,228.8 L205.5,233.6 L213.5,239.5 L220.7,241.3 L227.2,241.9 L233.2,239.1 L238.6,234.6 L243.7,231.7 L248.4,227.0 L252.8,222.5 L256.9,216.8 L260.8,213.4 L264.5,209.2 L268.0,206.6 L271.4,203.6 L274.5,200.1 L277.6,194.9 L280.5,191.3 L283.3,188.9 L285.9,188.3 L288.5,183.6 L291.0,180.8 L293.4,178.6 L295.7,176.0 L297.9,173.8 L300.1,173.6 L302.2,171.7 L304.2,169.5 L306.2,167.4 L308.1,165.2 L310.0,163.4 L311.8,161.2 L313.6,159.5 L315.3,156.3 L317.0,154.8 L318.7,151.6 L320.3,150.0 L321.8,150.5 L323.4,147.7 L324.9,146.1 L326.3,143.6 L327.8,142.0 L329.2,140.6 L330.6,139.1 L331.9,139.6 L333.2,138.5 L334.5,136.7 L335.8,133.5 L337.1,133.2 L338.3,131.7 L339.5,131.1 L340.7,128.7 L341.9,127.0 L343.0,128.1 L344.1,126.8 L345.2,123.7 L346.3,122.4 L347.4,121.2 L348.5,121.4 L349.5,118.9 L350.5,117.7 L351.5,117.7 L352.5,116.3 L353.5,115.3 L354.5,114.0 L355.4,112.6 L356.4,113.0 L357.3,112.4 L358.2,111.5 L359.1,110.5 L360.0,109.4 L360.9,108.3 L361.8,107.7 L362.6,106.7 L363.5,105.8 L364.3,104.7 L365.2,103.9 L366.0,102.5 L366.8,101.1 L367.6,99.3 L368.4,98.8 L369.1,97.7 L369.9,97.2 L370.7,96.7 L371.4,97.0 L372.2,95.0 L372.9,94.9 L373.6,93.7 L374.4,92.6 L375.1,92.1 L375.8,92.3 L376.5,91.4 L377.2,90.8 L377.9,89.8 L378.5,89.3 L379.2,88.0 L379.9,87.0 L380.5,85.0 L381.2,84.8 L381.8,85.7 L382.5,83.4 L383.1,82.6 L383.7,83.6 L384.4,80.8 L385.0,81.2 L385.6,81.6 L386.2,80.7 L386.8,79.7 L387.4,78.1 L388.0,78.6 L388.6,78.2 L389.2,77.6 L389.7,77.0 L390.3,75.7 L390.9,74.6 L391.4,74.3 L392.0,74.3 L392.5,73.9 L393.1,73.2 L393.6,72.6 L394.2,70.8 L394.7,70.5 L395.2,69.9 L395.8,68.8 L396.3,68.4 L396.8,69.1 L397.3,68.6 L397.8,67.0 L398.3,65.9 L398.9,66.0 L399.4,65.3 L399.8,64.3 L400.3,65.2 L400.8,64.7 L401.3,64.2 L401.8,63.6 L402.3,61.6 L402.8,61.0 L403.2,60.0 L403.7,59.7 L404.2,59.9 L404.6,59.5 L405.1,58.5 L405.5,57.7 L406.0,58.6 L406.4,56.8 L406.9,57.9 L407.3,57.4 L407.8,55.6 L408.2,55.3 L408.6,55.9 L409.1,53.9 L409.5,55.1 L409.9,54.4 L410.4,52.9 L410.8,52.8 L411.2,51.2 L411.6,51.5 L412.0,51.1 L412.5,51.6 L412.9,51.3 L413.3,50.7 L413.7,50.3 L414.1,49.8 L414.5,49.0 L414.9,48.9 L415.3,48.1 L415.7,48.2 L416.1,47.4 L416.4,47.2 L416.8,46.9 L417.2,46.4 L417.6,46.0 L418.0,44.2 L418.4,43.3 L418.7,44.3 L419.1,43.0 L419.5,42.5 L419.8,42.9 L420.2,41.3 L420.6,42.6 L420.9,40.8 L421.3,41.7 L421.7,41.2 L422.0,40.1 L422.4,40.2 L422.7,40.0 L423.1,38.9 L423.4,39.4 L423.8,39.1 L424.1,38.2 L424.5,37.9 L424.8,37.6 L425.2,37.4 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>gnuplot_plot_2a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M63.6,336.8 L110.9,308.3 L138.6,307.9 L158.2,298.1 L173.4,290.5 L185.9,283.1 L196.4,291.3 L205.5,296.6 L213.5,300.5 L220.7,302.1 L227.2,307.2 L233.2,303.9 L238.6,299.6 L243.7,301.8 L248.4,298.4 L252.8,290.9 L256.9,294.0 L260.8,281.4 L264.5,282.9 L268.0,287.7 L271.4,286.5 L274.5,282.6 L277.6,282.8 L280.5,279.3 L283.3,279.5 L285.9,276.0 L288.5,274.6 L291.0,273.4 L293.4,272.2 L295.7,270.8 L297.9,271.9 L300.1,270.8 L302.2,269.5 L304.2,268.4 L306.2,267.5 L308.1,266.3 L310.0,265.3 L311.8,264.3 L313.6,262.8 L315.3,261.2 L317.0,258.8 L318.7,258.0 L320.3,259.7 L321.8,258.5 L323.4,257.5 L324.9,255.3 L326.3,254.0 L327.8,253.3 L329.2,252.5 L330.6,253.6 L331.9,253.3 L333.2,252.6 L334.5,249.9 L335.8,250.7 L337.1,247.7 L338.3,246.4 L339.5,246.4 L340.7,246.0 L341.9,247.8 L343.0,247.1 L344.1,244.0 L345.2,243.4 L346.3,242.8 L347.4,244.2 L348.5,241.3 L349.5,243.1 L350.5,241.8 L351.5,242.1 L352.5,241.6 L353.5,240.5 L354.5,238.3 L355.4,240.2 L356.4,239.7 L357.3,239.1 L358.2,238.5 L359.1,238.2 L360.0,237.7 L360.9,237.1 L361.8,236.7 L362.6,236.2 L363.5,235.7 L364.3,235.1 L365.2,234.8 L366.0,234.3 L366.8,231.6 L367.6,230.9 L368.4,232.9 L369.1,229.9 L369.9,231.3 L370.7,231.7 L371.4,231.4 L372.2,230.9 L372.9,227.0 L373.6,230.1 L374.4,229.7 L375.1,229.3 L375.8,229.0 L376.5,228.7 L377.2,227.9 L377.9,227.7 L378.5,227.5 L379.2,227.1 L379.9,226.6 L380.5,224.1 L381.2,225.9 L381.8,225.8 L382.5,223.0 L383.1,225.0 L383.7,222.4 L384.4,224.1 L385.0,223.9 L385.6,223.1 L386.2,223.1 L386.8,223.0 L387.4,220.2 L388.0,222.3 L388.6,221.4 L389.2,221.6 L389.7,220.5 L390.3,218.3 L390.9,220.8 L391.4,220.4 L392.0,220.1 L392.5,219.9 L393.1,219.6 L393.6,219.2 L394.2,216.7 L394.7,218.1 L395.2,216.2 L395.8,217.7 L396.3,217.8 L396.8,217.5 L397.3,217.2 L397.8,214.6 L398.3,216.6 L398.9,215.0 L399.4,216.0 L399.8,215.6 L400.3,215.5 L400.8,215.2 L401.3,215.0 L401.8,212.4 L402.3,212.1 L402.8,211.9 L403.2,213.3 L403.7,211.9 L404.2,213.3 L404.6,212.9 L405.1,212.7 L405.5,210.4 L406.0,210.3 L406.4,212.1 L406.9,211.9 L407.3,211.6 L407.8,209.0 L408.2,211.2 L408.6,208.6 L409.1,210.2 L409.5,210.5 L409.9,209.8 L410.4,210.0 L410.8,208.3 L411.2,207.1 L411.6,209.2 L412.0,209.1 L412.5,208.8 L412.9,208.5 L413.3,208.2 L413.7,207.7 L414.1,207.9 L414.5,207.6 L414.9,207.6 L415.3,205.2 L415.7,207.1 L416.1,206.8 L416.4,206.4 L416.8,206.4 L417.2,205.9 L417.6,206.0 L418.0,204.9 L418.4,203.2 L418.7,205.3 L419.1,203.2 L419.5,202.6 L419.8,202.9 L420.2,204.5 L420.6,203.2 L420.9,201.9 L421.3,203.4 L421.7,203.5 L422.0,203.6 L422.4,202.0 L422.7,202.7 L423.1,203.2 L423.4,202.8 L423.8,202.0 L424.1,200.2 L424.5,202.2 L424.8,202.1 L425.2,202.0 " stroke="rgb( 0, 128, 0)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>gnuplot_plot_3a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M63.6,319.9 L110.9,285.3 L138.6,277.8 L158.2,264.7 L173.4,249.4 L185.9,237.0 L196.4,235.1 L205.5,243.7 L213.5,244.3 L220.7,238.0 L227.2,243.3 L233.2,236.2 L238.6,236.5 L243.7,231.9 L248.4,223.6 L252.8,222.8 L256.9,218.4 L260.8,213.2 L264.5,211.2 L268.0,206.8 L271.4,203.8 L274.5,198.5 L277.6,196.1 L280.5,193.5 L283.3,190.2 L285.9,186.8 L288.5,184.0 L291.0,181.2 L293.4,179.0 L295.7,176.2 L297.9,174.2 L300.1,173.8 L302.2,172.0 L304.2,169.7 L306.2,167.6 L308.1,165.4 L310.0,163.6 L311.8,161.5 L313.6,157.9 L315.3,157.1 L317.0,153.3 L318.7,151.9 L320.3,152.5 L321.8,150.4 L323.4,148.6 L324.9,146.1 L326.3,143.7 L327.8,142.1 L329.2,140.9 L330.6,138.3 L331.9,140.1 L333.2,138.8 L334.5,137.1 L335.8,134.3 L337.1,132.3 L338.3,132.4 L339.5,129.6 L340.7,128.8 L341.9,128.7 L343.0,128.3 L344.1,126.1 L345.2,123.8 L346.3,122.6 L347.4,122.6 L348.5,120.3 L349.5,120.3 L350.5,117.9 L351.5,117.1 L352.5,117.7 L353.5,115.4 L354.5,113.3 L355.4,114.4 L356.4,113.6 L357.3,112.4 L358.2,111.5 L359.1,110.7 L360.0,109.7 L360.9,108.6 L361.8,107.7 L362.6,106.9 L363.5,105.6 L364.3,105.0 L365.2,104.0 L366.0,102.4 L366.8,101.1 L367.6,100.3 L368.4,98.8 L369.1,98.9 L369.9,97.5 L370.7,98.0 L371.4,96.4 L372.2,95.2 L372.9,94.2 L373.6,93.8 L374.4,93.7 L375.1,93.2 L375.8,92.4 L376.5,91.6 L377.2,90.9 L377.9,90.2 L378.5,89.4 L379.2,88.0 L379.9,87.3 L380.5,85.7 L381.2,86.3 L381.8,85.9 L382.5,83.6 L383.1,84.0 L383.7,81.9 L384.4,82.7 L385.0,82.2 L385.6,81.0 L386.2,80.5 L386.8,80.5 L387.4,78.6 L388.0,79.0 L388.6,78.4 L389.2,77.7 L389.7,76.8 L390.3,76.4 L390.9,75.4 L391.4,73.9 L392.0,74.5 L392.5,74.0 L393.1,73.4 L393.6,72.8 L394.2,70.0 L394.7,70.1 L395.2,69.4 L395.8,69.5 L396.3,69.8 L396.8,69.3 L397.3,68.7 L397.8,67.5 L398.3,66.2 L398.9,65.5 L399.4,64.7 L399.8,65.4 L400.3,65.2 L400.8,64.7 L401.3,64.2 L401.8,63.4 L402.3,61.7 L402.8,61.1 L403.2,60.2 L403.7,60.1 L404.2,59.9 L404.6,58.9 L405.1,60.1 L405.5,58.4 L406.0,58.4 L406.4,58.5 L406.9,57.9 L407.3,56.7 L407.8,56.2 L408.2,54.9 L408.6,54.5 L409.1,55.6 L409.5,55.1 L409.9,54.5 L410.4,53.3 L410.8,53.0 L411.2,52.0 L411.6,51.6 L412.0,52.0 L412.5,51.6 L412.9,51.2 L413.3,50.5 L413.7,50.3 L414.1,49.9 L414.5,49.3 L414.9,49.1 L415.3,48.5 L415.7,47.7 L416.1,47.8 L416.4,47.3 L416.8,47.0 L417.2,46.4 L417.6,46.0 L418.0,45.1 L418.4,44.4 L418.7,43.5 L419.1,43.8 L419.5,42.2 L419.8,41.9 L420.2,41.9 L420.6,41.0 L420.9,40.8 L421.3,42.0 L421.7,41.3 L422.0,40.2 L422.4,39.3 L422.7,39.8 L423.1,39.7 L423.4,39.6 L423.8,39.1 L424.1,37.4 L424.5,38.4 L424.8,37.9 L425.2,37.4 " stroke="rgb(255, 0, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb(255, 0, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_28_0.svg b/lecture_10/lecture_10_files/lecture_10_28_0.svg new file mode 100644 index 0000000..548cda9 --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_28_0.svg @@ -0,0 +1,123 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,390.0)"> + <text><tspan font-family="{}">0.0034</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,310.5 L83.0,310.5 M535.0,310.5 L522.5,310.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,316.5)"> + <text><tspan font-family="{}">0.0036</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,237.1 L83.0,237.1 M535.0,237.1 L522.5,237.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,243.1)"> + <text><tspan font-family="{}">0.0038</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,163.6 L83.0,163.6 M535.0,163.6 L522.5,163.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,169.6)"> + <text><tspan font-family="{}">0.004</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,90.2 L83.0,90.2 M535.0,90.2 L522.5,90.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,96.2)"> + <text><tspan font-family="{}">0.0042</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,22.7)"> + <text><tspan font-family="{}">0.0044</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(70.5,408.0)"> + <text><tspan font-family="{}">0.9</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M186.6,384.0 L186.6,371.5 M186.6,16.7 L186.6,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(186.6,408.0)"> + <text><tspan font-family="{}">0.95</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M302.7,384.0 L302.7,371.5 M302.7,16.7 L302.7,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(302.7,408.0)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M418.9,384.0 L418.9,371.5 M418.9,16.7 L418.9,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(418.9,408.0)"> + <text><tspan font-family="{}">1.05</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">1.1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M302.7,227.1 " stroke="rgb( 0, 0, 255)"/> <g onmousemove="gnuplot_svg.showHypertext(evt,'')" onmouseout="gnuplot_svg.hideHypertext()"><title> </title> + <use color="rgb( 0, 0, 255)" transform="translate(302.7,227.1) scale(3.00)" xlink:href="#gpPt6"/></g> +</g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 0, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_29_0.pdf b/lecture_10/lecture_10_files/lecture_10_29_0.pdf new file mode 100644 index 0000000..20bdd51 Binary files /dev/null and b/lecture_10/lecture_10_files/lecture_10_29_0.pdf differ diff --git a/lecture_10/lecture_10_files/lecture_10_29_0.svg b/lecture_10/lecture_10_files/lecture_10_29_0.svg new file mode 100644 index 0000000..eb8af2c --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_29_0.svg @@ -0,0 +1,148 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="63.6,362.4 534.9,362.4 534.9,16.8 63.6,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,362.4 L76.1,362.4 M535.0,362.4 L522.5,362.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,368.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-5</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,341.6 L69.8,341.6 M535.0,341.6 L528.8,341.6 M63.6,329.4 L69.8,329.4 M535.0,329.4 L528.8,329.4 M63.6,320.8 L69.8,320.8 M535.0,320.8 L528.8,320.8 M63.6,314.1 L69.8,314.1 M535.0,314.1 L528.8,314.1 M63.6,308.6 L69.8,308.6 M535.0,308.6 L528.8,308.6 M63.6,304.0 L69.8,304.0 M535.0,304.0 L528.8,304.0 M63.6,300.0 L69.8,300.0 M535.0,300.0 L528.8,300.0 M63.6,296.4 L69.8,296.4 M535.0,296.4 L528.8,296.4 M63.6,293.3 L76.1,293.3 M535.0,293.3 L522.5,293.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,299.3)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-4</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,272.4 L69.8,272.4 M535.0,272.4 L528.8,272.4 M63.6,260.3 L69.8,260.3 M535.0,260.3 L528.8,260.3 M63.6,251.6 L69.8,251.6 M535.0,251.6 L528.8,251.6 M63.6,244.9 L69.8,244.9 M535.0,244.9 L528.8,244.9 M63.6,239.5 L69.8,239.5 M535.0,239.5 L528.8,239.5 M63.6,234.8 L69.8,234.8 M535.0,234.8 L528.8,234.8 M63.6,230.8 L69.8,230.8 M535.0,230.8 L528.8,230.8 M63.6,227.3 L69.8,227.3 M535.0,227.3 L528.8,227.3 M63.6,224.1 L76.1,224.1 M535.0,224.1 L522.5,224.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,230.1)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-3</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,203.3 L69.8,203.3 M535.0,203.3 L528.8,203.3 M63.6,191.1 L69.8,191.1 M535.0,191.1 L528.8,191.1 M63.6,182.5 L69.8,182.5 M535.0,182.5 L528.8,182.5 M63.6,175.8 L69.8,175.8 M535.0,175.8 L528.8,175.8 M63.6,170.3 L69.8,170.3 M535.0,170.3 L528.8,170.3 M63.6,165.7 L69.8,165.7 M535.0,165.7 L528.8,165.7 M63.6,161.7 L69.8,161.7 M535.0,161.7 L528.8,161.7 M63.6,158.1 L69.8,158.1 M535.0,158.1 L528.8,158.1 M63.6,155.0 L76.1,155.0 M535.0,155.0 L522.5,155.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,161.0)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-2</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,134.2 L69.8,134.2 M535.0,134.2 L528.8,134.2 M63.6,122.0 L69.8,122.0 M535.0,122.0 L528.8,122.0 M63.6,113.4 L69.8,113.4 M535.0,113.4 L528.8,113.4 M63.6,106.7 L69.8,106.7 M535.0,106.7 L528.8,106.7 M63.6,101.2 L69.8,101.2 M535.0,101.2 L528.8,101.2 M63.6,96.5 L69.8,96.5 M535.0,96.5 L528.8,96.5 M63.6,92.5 L69.8,92.5 M535.0,92.5 L528.8,92.5 M63.6,89.0 L69.8,89.0 M535.0,89.0 L528.8,89.0 M63.6,85.8 L76.1,85.8 M535.0,85.8 L522.5,85.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,91.8)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">-1</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,65.0 L69.8,65.0 M535.0,65.0 L528.8,65.0 M63.6,52.9 L69.8,52.9 M535.0,52.9 L528.8,52.9 M63.6,44.2 L69.8,44.2 M535.0,44.2 L528.8,44.2 M63.6,37.5 L69.8,37.5 M535.0,37.5 L528.8,37.5 M63.6,32.0 L69.8,32.0 M535.0,32.0 L528.8,32.0 M63.6,27.4 L69.8,27.4 M535.0,27.4 L528.8,27.4 M63.6,23.4 L69.8,23.4 M535.0,23.4 L528.8,23.4 M63.6,19.9 L69.8,19.9 M535.0,19.9 L528.8,19.9 M63.6,16.7 L76.1,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(55.3,22.7)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">0</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,362.4 L63.6,349.9 M63.6,16.7 L63.6,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(63.6,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">0</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M134.6,362.4 L134.6,356.2 M134.6,16.7 L134.6,22.9 M176.1,362.4 L176.1,356.2 M176.1,16.7 L176.1,22.9 M205.5,362.4 L205.5,356.2 M205.5,16.7 L205.5,22.9 M228.3,362.4 L228.3,356.2 M228.3,16.7 L228.3,22.9 M247.0,362.4 L247.0,356.2 M247.0,16.7 L247.0,22.9 M262.8,362.4 L262.8,356.2 M262.8,16.7 L262.8,22.9 M276.5,362.4 L276.5,356.2 M276.5,16.7 L276.5,22.9 M288.5,362.4 L288.5,356.2 M288.5,16.7 L288.5,22.9 M299.3,362.4 L299.3,349.9 M299.3,16.7 L299.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(299.3,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">1</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M370.3,362.4 L370.3,356.2 M370.3,16.7 L370.3,22.9 M411.8,362.4 L411.8,356.2 M411.8,16.7 L411.8,22.9 M441.2,362.4 L441.2,356.2 M441.2,16.7 L441.2,22.9 M464.0,362.4 L464.0,356.2 M464.0,16.7 L464.0,22.9 M482.7,362.4 L482.7,356.2 M482.7,16.7 L482.7,22.9 M498.5,362.4 L498.5,356.2 M498.5,16.7 L498.5,22.9 M512.2,362.4 L512.2,356.2 M512.2,16.7 L512.2,22.9 M524.2,362.4 L524.2,356.2 M524.2,16.7 L524.2,22.9 M535.0,362.4 L535.0,349.9 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,386.4)"> + <text><tspan font-family="{}">10</tspan><tspan dy="-8.00px" font-family="{}" font-size="12.8">2</tspan><tspan dy="8.00" font-size="16.0"/></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M63.6,16.7 L63.6,362.4 L535.0,362.4 L535.0,16.7 L63.6,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(19.1,189.6) rotate(-90)"> + <text><tspan font-family="{}">time (s)</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(299.3,413.4)"> + <text><tspan font-family="{}">number of elements</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M338.5,169.7 L338.5,25.7 L526.7,25.7 L526.7,169.7 L338.5,169.7 Z " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>Gauss elim</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,55.7)"> + <text><tspan font-family="{}">Gauss elim</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M349.7,49.7 L403.5,49.7 M63.6,244.9 L134.6,218.9 L176.1,200.5 L205.5,194.1 L228.3,188.5 L247.0,179.7 L262.8,187.8 L276.5,185.1 L288.5,190.9 L299.3,187.8 L309.1,189.0 L318.0,187.7 L326.2,186.5 L333.7,180.1 L340.8,176.5 L347.4,175.6 L353.6,173.1 L359.5,170.3 L365.0,168.4 L370.3,164.0 L375.2,163.3 L380.0,159.1 L384.6,157.2 L388.9,149.8 L393.1,144.2 L397.1,143.9 L401.0,141.9 L404.7,139.7 L408.3,140.8 L411.8,135.0 L415.1,131.6 L418.4,130.7 L421.5,129.9 L424.6,129.2 L427.5,127.8 L430.4,126.1 L433.2,124.6 L436.0,123.0 L438.6,121.5 L441.2,120.0 L443.7,118.6 L446.2,117.3 L448.6,115.9 L451.0,114.6 L453.3,113.2 L455.5,111.9 L457.7,110.6 L459.9,109.3 L462.0,108.1 L464.0,107.0 L466.1,105.8 L468.1,104.7 L470.0,103.7 L471.9,102.6 L473.8,99.4 L475.6,94.0 L477.5,93.2 L479.2,92.1 L481.0,89.6 L482.7,93.0 L484.4,95.1 L486.1,94.3 L487.7,93.2 L489.3,92.5 L490.9,89.9 L492.5,90.6 L494.0,89.7 L495.5,89.0 L497.0,88.3 L498.5,86.9 L499.9,87.1 L501.4,86.4 L502.8,85.7 L504.2,85.2 L505.6,84.4 L506.9,83.9 L508.2,83.3 L509.6,82.6 L510.9,82.3 L512.2,81.6 L513.4,81.0 L514.7,80.6 L515.9,79.7 L517.2,79.2 L518.4,79.1 L519.6,78.0 L520.7,78.0 L521.9,76.9 L523.1,76.5 L524.2,75.8 L525.3,75.3 L526.5,75.1 L527.6,74.3 L528.7,73.7 L529.7,73.3 L530.8,72.7 L531.9,72.2 L532.9,70.9 L534.0,71.2 L535.0,70.7 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>Matlab \</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,103.7)"> + <text><tspan font-family="{}">Matlab </tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M349.7,97.7 L403.5,97.7 M63.6,259.7 L134.6,242.2 L176.1,215.9 L205.5,223.2 L228.3,222.2 L247.0,222.1 L262.8,228.2 L276.5,234.0 L288.5,239.8 L299.3,240.6 L309.1,235.4 L318.0,240.7 L326.2,240.5 L333.7,236.7 L340.8,234.7 L347.4,235.3 L353.6,233.8 L359.5,233.4 L365.0,229.8 L370.3,230.3 L375.2,227.4 L380.0,227.9 L384.6,224.6 L388.9,217.8 L393.1,216.3 L397.1,215.7 L401.0,214.0 L404.7,213.7 L408.3,219.8 L411.8,207.5 L415.1,209.8 L418.4,208.8 L421.5,208.7 L424.6,208.0 L427.5,207.6 L430.4,206.7 L433.2,205.7 L436.0,205.2 L438.6,204.3 L441.2,203.6 L443.7,203.1 L446.2,202.2 L448.6,201.5 L451.0,200.9 L453.3,200.0 L455.5,199.3 L457.7,198.6 L459.9,197.9 L462.0,197.5 L464.0,197.0 L466.1,196.4 L468.1,195.7 L470.0,195.2 L471.9,194.6 L473.8,192.4 L475.6,193.1 L477.5,192.3 L479.2,192.0 L481.0,174.1 L482.7,190.5 L484.4,190.8 L486.1,190.2 L487.7,189.7 L489.3,189.3 L490.9,189.0 L492.5,188.7 L494.0,187.8 L495.5,187.9 L497.0,187.2 L498.5,187.0 L499.9,186.5 L501.4,186.1 L502.8,185.7 L504.2,185.3 L505.6,184.7 L506.9,184.7 L508.2,184.2 L509.6,183.5 L510.9,183.1 L512.2,183.1 L513.4,182.7 L514.7,182.2 L515.9,181.7 L517.2,181.8 L518.4,181.0 L519.6,180.7 L520.7,180.5 L521.9,180.0 L523.1,180.0 L524.2,179.4 L525.3,179.2 L526.5,179.0 L527.6,178.6 L528.7,178.1 L529.7,178.0 L530.8,177.6 L531.9,182.4 L532.9,177.0 L534.0,176.4 L535.0,182.3 " stroke="rgb( 0, 128, 0)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>TriDiag</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,151.7)"> + <text><tspan font-family="{}">TriDiag</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M349.7,145.7 L403.5,145.7 M63.6,339.8 L134.6,290.4 L176.1,288.0 L205.5,286.1 L228.3,304.0 L247.0,308.1 L262.8,320.7 L276.5,317.2 L288.5,333.7 L299.3,328.4 L309.1,332.6 L318.0,320.0 L326.2,334.8 L333.7,309.0 L340.8,317.2 L347.4,331.6 L353.6,316.0 L359.5,245.2 L365.0,251.3 L370.3,313.5 L375.2,310.1 L380.0,307.6 L384.6,174.9 L388.9,301.9 L393.1,245.9 L397.1,291.6 L401.0,184.6 L404.7,300.6 L408.3,307.6 L411.8,298.5 L415.1,296.1 L418.4,293.2 L421.5,298.4 L424.6,294.5 L427.5,302.7 L430.4,254.5 L433.2,300.3 L436.0,303.1 L438.6,302.3 L441.2,302.7 L443.7,299.2 L446.2,300.6 L448.6,299.7 L451.0,297.4 L453.3,295.8 L455.5,295.1 L457.7,290.6 L459.9,290.9 L462.0,292.9 L464.0,291.2 L466.1,293.9 L468.1,296.1 L470.0,293.9 L471.9,293.9 L473.8,283.2 L475.6,288.8 L477.5,288.0 L479.2,288.0 L481.0,286.8 L482.7,286.8 L484.4,285.8 L486.1,286.5 L487.7,286.1 L489.3,285.6 L490.9,280.9 L492.5,279.9 L494.0,281.9 L495.5,279.4 L497.0,275.8 L498.5,273.8 L499.9,274.0 L501.4,274.5 L502.8,270.7 L504.2,269.6 L505.6,274.4 L506.9,274.6 L508.2,272.6 L509.6,269.3 L510.9,270.0 L512.2,271.7 L513.4,272.1 L514.7,271.0 L515.9,269.6 L517.2,268.6 L518.4,269.9 L519.6,270.3 L520.7,268.4 L521.9,269.6 L523.1,267.0 L524.2,268.5 L525.3,265.0 L526.5,265.8 L527.6,265.7 L528.7,265.0 L529.7,266.1 L530.8,263.8 L531.9,267.0 L532.9,264.9 L534.0,264.1 L535.0,265.2 " stroke="rgb(255, 0, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb(255, 0, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_3_0.pdf b/lecture_10/lecture_10_files/lecture_10_3_0.pdf new file mode 100644 index 0000000..5ebf43a Binary files /dev/null and b/lecture_10/lecture_10_files/lecture_10_3_0.pdf differ diff --git a/lecture_10/lecture_10_files/lecture_10_3_0.svg b/lecture_10/lecture_10_files/lecture_10_3_0.svg new file mode 100644 index 0000000..62b5e17 --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_3_0.svg @@ -0,0 +1,140 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="37.3,384.0 534.9,384.0 534.9,16.8 37.3,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,384.0 L49.8,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,390.0)"> + <text><tspan font-family="{}">-4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,310.5 L49.8,310.5 M535.0,310.5 L522.5,310.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,316.5)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,237.1 L49.8,237.1 M535.0,237.1 L522.5,237.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,243.1)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,163.6 L49.8,163.6 M535.0,163.6 L522.5,163.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,169.6)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,90.2 L49.8,90.2 M535.0,90.2 L522.5,90.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,96.2)"> + <text><tspan font-family="{}">4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,16.7 L49.8,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(29.0,22.7)"> + <text><tspan font-family="{}">6</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,384.0 L37.3,371.5 M37.3,16.7 L37.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(37.3,408.0)"> + <text><tspan font-family="{}">-6</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M108.4,384.0 L108.4,371.5 M108.4,16.7 L108.4,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(108.4,408.0)"> + <text><tspan font-family="{}">-4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M179.5,384.0 L179.5,371.5 M179.5,16.7 L179.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(179.5,408.0)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M250.6,384.0 L250.6,371.5 M250.6,16.7 L250.6,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(250.6,408.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M321.7,384.0 L321.7,371.5 M321.7,16.7 L321.7,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(321.7,408.0)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M392.8,384.0 L392.8,371.5 M392.8,16.7 L392.8,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(392.8,408.0)"> + <text><tspan font-family="{}">4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M463.9,384.0 L463.9,371.5 M463.9,16.7 L463.9,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(463.9,408.0)"> + <text><tspan font-family="{}">6</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">8</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M37.3,16.7 L37.3,384.0 L535.0,384.0 L535.0,16.7 L37.3,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M499.5,310.5 L392.8,273.8 L286.2,237.1 L179.5,200.3 L72.9,163.6 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>gnuplot_plot_2a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M179.5,53.4 L215.1,126.9 L250.6,200.3 L286.2,273.8 L321.7,347.3 " stroke="rgb( 0, 128, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 128, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_5_0.svg b/lecture_10/lecture_10_files/lecture_10_5_0.svg new file mode 100644 index 0000000..9d2a214 --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_5_0.svg @@ -0,0 +1,377 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L280.0,172.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L280.0,172.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L74.5,130.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L280.0,31.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L485.5,130.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,130.8 L280.0,31.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,130.8 L280.0,31.4 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,271.2 L280.0,172.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L61.5,277.5 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L293.0,165.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(52.9,292.5)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M100.2,283.6 L305.6,184.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M100.2,283.6 L87.2,289.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M305.6,184.4 L318.7,178.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(78.6,304.9)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M125.9,296.0 L331.3,196.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M125.9,296.0 L112.8,302.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M331.3,196.8 L344.4,190.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(104.3,317.3)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M151.6,308.5 L357.0,209.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M151.6,308.5 L138.5,314.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M357.0,209.1 L370.1,202.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(130.0,329.8)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M177.3,320.9 L382.7,221.5 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M177.3,320.9 L164.2,327.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M382.7,221.5 L395.8,215.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(155.7,342.2)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M203.0,333.3 L408.4,233.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M203.0,333.3 L189.9,339.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M408.4,233.9 L421.5,227.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(181.3,354.6)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M228.7,345.7 L434.1,246.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M228.7,345.7 L215.6,352.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M434.1,246.4 L447.2,240.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(207.0,367.0)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M254.4,358.1 L459.8,258.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M254.4,358.1 L241.3,364.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M459.8,258.8 L472.8,252.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(232.7,379.4)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,370.6 L485.5,271.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L267.0,376.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L498.5,264.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(258.4,391.9)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,370.6 L74.5,271.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L288.9,374.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L65.6,266.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(294.7,387.0)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M305.6,358.1 L100.2,258.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M305.6,358.1 L314.6,362.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M100.2,258.8 L91.3,254.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(320.4,374.6)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M331.3,345.7 L125.9,246.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M331.3,345.7 L340.2,350.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M125.9,246.4 L117.0,242.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(346.1,362.2)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M357.0,333.3 L151.6,233.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M357.0,333.3 L365.9,337.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M151.6,233.9 L142.7,229.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(371.8,349.8)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M382.7,320.9 L177.3,221.5 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M382.7,320.9 L391.6,325.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M177.3,221.5 L168.4,217.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(397.5,337.3)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M408.4,308.5 L203.0,209.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M408.4,308.5 L417.3,312.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M203.0,209.1 L194.1,204.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(423.2,324.9)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M434.1,296.0 L228.7,196.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M434.1,296.0 L443.0,300.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M228.7,196.8 L219.8,192.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(448.9,312.5)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M459.8,283.6 L254.4,184.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M459.8,283.6 L468.7,287.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M254.4,184.4 L245.4,180.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(474.6,300.1)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M485.5,271.2 L280.0,172.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L494.4,275.5 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L271.1,167.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(500.3,287.7)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,271.2 L280.0,172.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,172.0 L485.5,271.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L62.0,271.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,277.2)"> + <text><tspan font-family="{}">-30</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L498.0,271.2 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,247.8 L280.0,148.5 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,148.5 L485.5,247.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,247.8 L62.0,247.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,253.8)"> + <text><tspan font-family="{}">-20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,247.8 L498.0,247.8 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,224.4 L280.0,125.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,125.1 L485.5,224.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,224.4 L62.0,224.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,230.4)"> + <text><tspan font-family="{}">-10</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,224.4 L498.0,224.4 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,201.0 L280.0,101.7 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,101.7 L485.5,201.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,201.0 L62.0,201.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,207.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,201.0 L498.0,201.0 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,177.6 L280.0,78.3 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,78.3 L485.5,177.6 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,177.6 L62.0,177.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,183.6)"> + <text><tspan font-family="{}">10</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,177.6 L498.0,177.6 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,154.2 L280.0,54.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,54.9 L485.5,154.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,154.2 L62.0,154.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,160.2)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,154.2 L498.0,154.2 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M74.5,130.8 L280.0,31.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M280.0,31.4 L485.5,130.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,130.8 L62.0,130.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,136.8)"> + <text><tspan font-family="{}">30</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,130.8 L498.0,130.8 " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M280.0,61.9 L228.7,82.0 " stroke="rgb(255, 18, 0)"/> <path d="M228.7,82.0 L177.3,102.2 " stroke="rgb(225, 0, 0)"/> <path d="M177.3,102.2 L125.9,122.4 " stroke="rgb(176, 0, 0)"/> <path d="M125.9,122.4 L74.5,142.5 " stroke="rgb(144, 0, 0)"/> <path d="M331.3,110.1 L280.0,130.3 " stroke="rgb(255, 229, 0)"/> <path d="M280.0,130.3 L228.7,150.5 " stroke="rgb(255, 180, 0)"/> <path d="M228.7,150.5 L177.3,170.6 " stroke="rgb(255, 148, 0)"/> <path d="M177.3,170.6 L125.9,190.8 " stroke="rgb(255, 99, 0)"/> <path d="M382.7,158.4 L331.3,178.6 " stroke="rgb( 71, 255, 184)"/> <path d="M331.3,178.6 L280.0,198.7 " stroke="rgb(103, 255, 152)"/> <path d="M280.0,198.7 L228.7,218.8 " stroke="rgb(152, 255, 103)"/> <path d="M228.7,218.8 L177.3,238.9 " stroke="rgb(200, 255, 55)"/> <path d="M434.1,206.6 L382.7,226.7 " stroke="rgb( 0, 99, 255)"/> <path d="M382.7,226.7 L331.3,246.9 " stroke="rgb( 0, 148, 255)"/> <path d="M331.3,246.9 L280.0,267.0 " stroke="rgb( 0, 196, 255)"/> <path d="M280.0,267.0 L228.7,287.2 " stroke="rgb( 0, 229, 255)"/> <path d="M485.5,254.8 L434.1,275.0 " stroke="rgb( 0, 0, 144)"/> <path d="M434.1,275.0 L382.7,295.1 " stroke="rgb( 0, 0, 192)"/> <path d="M382.7,295.1 L331.3,315.3 " stroke="rgb( 0, 0, 225)"/> <path d="M331.3,315.3 L280.0,335.4 " stroke="rgb( 0, 18, 255)"/> <path d="M280.0,61.9 L331.3,110.1 " stroke="rgb(255, 148, 0)"/> <path d="M331.3,110.1 L382.7,158.4 " stroke="rgb(152, 255, 103)"/> <path d="M382.7,158.4 L434.1,206.6 " stroke="rgb( 0, 196, 255)"/> <path d="M434.1,206.6 L485.5,254.8 " stroke="rgb( 0, 0, 225)"/> <path d="M228.7,82.0 L280.0,130.3 " stroke="rgb(255, 99, 0)"/> <path d="M280.0,130.3 L331.3,178.6 " stroke="rgb(200, 255, 55)"/> <path d="M331.3,178.6 L382.7,226.7 " stroke="rgb( 0, 229, 255)"/> <path d="M382.7,226.7 L434.1,275.0 " stroke="rgb( 0, 18, 255)"/> <path d="M177.3,102.2 L228.7,150.5 " stroke="rgb(255, 51, 0)"/> <path d="M228.7,150.5 L280.0,198.7 " stroke="rgb(233, 255, 22)"/> <path d="M280.0,198.7 L331.3,246.9 " stroke="rgb( 22, 255, 233)"/> <path d="M331.3,246.9 L382.7,295.1 " stroke="rgb( 0, 67, 255)"/> <path d="M125.9,122.4 L177.3,170.6 " stroke="rgb(255, 18, 0)"/> <path d="M177.3,170.6 L228.7,218.8 " stroke="rgb(255, 229, 0)"/> <path d="M228.7,218.8 L280.0,267.0 " stroke="rgb( 71, 255, 184)"/> <path d="M280.0,267.0 L331.3,315.3 " stroke="rgb( 0, 99, 255)"/> <path d="M74.5,142.5 L125.9,190.8 " stroke="rgb(225, 0, 0)"/> <path d="M125.9,190.8 L177.3,238.9 " stroke="rgb(255, 180, 0)"/> <path d="M177.3,238.9 L228.7,287.2 " stroke="rgb(103, 255, 152)"/> <path d="M228.7,287.2 L280.0,335.4 " stroke="rgb( 0, 148, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>gnuplot_plot_2a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M280.0,94.7 L228.7,117.2 " stroke="rgb(184, 255, 71)"/> <path d="M228.7,117.2 L177.3,139.7 " stroke="rgb(200, 255, 55)"/> <path d="M177.3,139.7 L125.9,162.2 " stroke="rgb(233, 255, 22)"/> <path d="M125.9,162.2 L74.5,184.7 " stroke="rgb(249, 255, 6)"/> <path d="M331.3,124.2 L280.0,146.7 " stroke="rgb(136, 255, 119)"/> <path d="M280.0,146.7 L228.7,169.2 " stroke="rgb(168, 255, 87)"/> <path d="M228.7,169.2 L177.3,191.7 " stroke="rgb(184, 255, 71)"/> <path d="M177.3,191.7 L125.9,214.1 " stroke="rgb(200, 255, 55)"/> <path d="M382.7,153.7 L331.3,176.2 " stroke="rgb(103, 255, 152)"/> <path d="M331.3,176.2 L280.0,198.7 " stroke="rgb(119, 255, 136)"/> <path d="M280.0,198.7 L228.7,221.1 " stroke="rgb(136, 255, 119)"/> <path d="M228.7,221.1 L177.3,243.6 " stroke="rgb(168, 255, 87)"/> <path d="M434.1,183.2 L382.7,205.6 " stroke="rgb( 55, 255, 200)"/> <path d="M382.7,205.6 L331.3,228.1 " stroke="rgb( 71, 255, 184)"/> <path d="M331.3,228.1 L280.0,250.6 " stroke="rgb(103, 255, 152)"/> <path d="M280.0,250.6 L228.7,273.1 " stroke="rgb(119, 255, 136)"/> <path d="M485.5,212.7 L434.1,235.2 " stroke="rgb( 6, 255, 249)"/> <path d="M434.1,235.2 L382.7,257.7 " stroke="rgb( 38, 255, 217)"/> <path d="M382.7,257.7 L331.3,280.1 " stroke="rgb( 55, 255, 200)"/> <path d="M331.3,280.1 L280.0,302.6 " stroke="rgb( 71, 255, 184)"/> <path d="M280.0,94.7 L331.3,124.2 " stroke="rgb(152, 255, 103)"/> <path d="M331.3,124.2 L382.7,153.7 " stroke="rgb(103, 255, 152)"/> <path d="M382.7,153.7 L434.1,183.2 " stroke="rgb( 71, 255, 184)"/> <path d="M434.1,183.2 L485.5,212.7 " stroke="rgb( 22, 255, 233)"/> <path d="M228.7,117.2 L280.0,146.7 " stroke="rgb(168, 255, 87)"/> <path d="M280.0,146.7 L331.3,176.2 " stroke="rgb(136, 255, 119)"/> <path d="M331.3,176.2 L382.7,205.6 " stroke="rgb( 87, 255, 168)"/> <path d="M382.7,205.6 L434.1,235.2 " stroke="rgb( 38, 255, 217)"/> <path d="M177.3,139.7 L228.7,169.2 " stroke="rgb(200, 255, 55)"/> <path d="M228.7,169.2 L280.0,198.7 " stroke="rgb(152, 255, 103)"/> <path d="M280.0,198.7 L331.3,228.1 " stroke="rgb(103, 255, 152)"/> <path d="M331.3,228.1 L382.7,257.7 " stroke="rgb( 71, 255, 184)"/> <path d="M125.9,162.2 L177.3,191.7 " stroke="rgb(217, 255, 38)"/> <path d="M177.3,191.7 L228.7,221.1 " stroke="rgb(168, 255, 87)"/> <path d="M228.7,221.1 L280.0,250.6 " stroke="rgb(136, 255, 119)"/> <path d="M280.0,250.6 L331.3,280.1 " stroke="rgb( 87, 255, 168)"/> <path d="M74.5,184.7 L125.9,214.1 " stroke="rgb(233, 255, 22)"/> <path d="M125.9,214.1 L177.3,243.6 " stroke="rgb(200, 255, 55)"/> <path d="M177.3,243.6 L228.7,273.1 " stroke="rgb(152, 255, 103)"/> <path d="M228.7,273.1 L280.0,302.6 " stroke="rgb(103, 255, 152)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>gnuplot_plot_3a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M280.0,101.9 L228.7,126.3 L177.3,150.7 " stroke="rgb(103, 255, 152)"/> <path d="M177.3,150.7 L125.9,175.0 L74.5,199.4 " stroke="rgb(119, 255, 136)"/> <path d="M331.3,127.0 L280.0,151.4 L228.7,175.7 " stroke="rgb(103, 255, 152)"/> <path d="M228.7,175.7 L177.3,200.1 L125.9,224.4 " stroke="rgb(119, 255, 136)"/> <path d="M382.7,152.1 L331.3,176.4 L280.0,200.8 L228.7,225.1 " stroke="rgb(103, 255, 152)"/> <path d="M228.7,225.1 L177.3,249.5 " stroke="rgb(119, 255, 136)"/> <path d="M434.1,177.1 L382.7,201.4 L331.3,225.8 L280.0,250.2 " stroke="rgb(103, 255, 152)"/> <path d="M280.0,250.2 L228.7,274.5 " stroke="rgb(119, 255, 136)"/> <path d="M485.5,202.1 L434.1,226.5 L382.7,250.9 L331.3,275.2 L280.0,299.6 M280.0,101.9 L331.3,127.0 L382.7,152.1 L434.1,177.1 L485.5,202.1 M228.7,126.3 L280.0,151.4 L331.3,176.4 L382.7,201.4 L434.1,226.5 " stroke="rgb(103, 255, 152)"/> <path d="M177.3,150.7 L228.7,175.7 " stroke="rgb(119, 255, 136)"/> <path d="M228.7,175.7 L280.0,200.8 L331.3,225.8 L382.7,250.9 " stroke="rgb(103, 255, 152)"/> <path d="M125.9,175.0 L177.3,200.1 L228.7,225.1 L280.0,250.2 " stroke="rgb(119, 255, 136)"/> <path d="M280.0,250.2 L331.3,275.2 " stroke="rgb(103, 255, 152)"/> <path d="M74.5,199.4 L125.9,224.4 L177.3,249.5 L228.7,274.5 L280.0,299.6 " stroke="rgb(119, 255, 136)"/></g> + </g> + <g id="gnuplot_plot_4a"><title>gnuplot_plot_4a</title> +<g color="white" fill="none" stroke="rgb(119, 255, 136)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <use color="rgb( 0, 0, 255)" transform="translate(351.9,156.8) scale(9.00)" xlink:href="#gpPt5"/> +</g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 0, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L280.0,370.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L280.0,370.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L280.0,299.6 " stroke="black"/></g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_5_1.pdf b/lecture_10/lecture_10_files/lecture_10_5_1.pdf new file mode 100644 index 0000000..4da2561 Binary files /dev/null and b/lecture_10/lecture_10_files/lecture_10_5_1.pdf differ diff --git a/lecture_10/lecture_10_files/lecture_10_5_1.svg b/lecture_10/lecture_10_files/lecture_10_5_1.svg new file mode 100644 index 0000000..70e0f6a --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_5_1.svg @@ -0,0 +1,322 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L280.0,172.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L280.0,172.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L74.5,130.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L280.0,31.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L485.5,130.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,130.8 L280.0,31.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,130.8 L280.0,31.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L61.5,277.5 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L293.0,165.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(52.9,292.5)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M100.2,283.6 L87.2,289.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M305.6,184.4 L318.7,178.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(78.6,304.9)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M125.9,296.0 L112.8,302.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M331.3,196.8 L344.4,190.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(104.3,317.3)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M151.6,308.5 L138.5,314.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M357.0,209.1 L370.1,202.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(130.0,329.8)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M177.3,320.9 L164.2,327.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M382.7,221.5 L395.8,215.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(155.7,342.2)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M203.0,333.3 L189.9,339.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M408.4,233.9 L421.5,227.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(181.3,354.6)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M228.7,345.7 L215.6,352.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M434.1,246.4 L447.2,240.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(207.0,367.0)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M254.4,358.1 L241.3,364.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M459.8,258.8 L472.8,252.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(232.7,379.4)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L267.0,376.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L498.5,264.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(258.4,391.9)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L288.9,374.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L65.6,266.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(294.7,387.0)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M305.6,358.1 L314.6,362.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M100.2,258.8 L91.3,254.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(320.4,374.6)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M331.3,345.7 L340.2,350.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M125.9,246.4 L117.0,242.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(346.1,362.2)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M357.0,333.3 L365.9,337.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M151.6,233.9 L142.7,229.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(371.8,349.8)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M382.7,320.9 L391.6,325.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M177.3,221.5 L168.4,217.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(397.5,337.3)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M408.4,308.5 L417.3,312.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M203.0,209.1 L194.1,204.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(423.2,324.9)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M434.1,296.0 L443.0,300.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M228.7,196.8 L219.8,192.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(448.9,312.5)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M459.8,283.6 L468.7,287.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M254.4,184.4 L245.4,180.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(474.6,300.1)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L494.4,275.5 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,172.0 L271.1,167.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(500.3,287.7)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L62.0,271.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,277.2)"> + <text><tspan font-family="{}">-6</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L498.0,271.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,251.1 L62.0,251.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,257.1)"> + <text><tspan font-family="{}">-4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,251.1 L498.0,251.1 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,231.1 L62.0,231.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,237.1)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,231.1 L498.0,231.1 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,211.0 L62.0,211.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,217.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,211.0 L498.0,211.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,191.0 L62.0,191.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,197.0)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,191.0 L498.0,191.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,170.9 L62.0,170.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,176.9)"> + <text><tspan font-family="{}">4</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,170.9 L498.0,170.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,150.9 L62.0,150.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,156.9)"> + <text><tspan font-family="{}">6</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,150.9 L498.0,150.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,130.8 L62.0,130.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(43.9,136.8)"> + <text><tspan font-family="{}">8</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,130.8 L498.0,130.8 " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M280.0,81.6 L228.7,96.4 " stroke="rgb(255, 164, 0)"/> <path d="M228.7,96.4 L177.3,111.2 " stroke="rgb(255, 83, 0)"/> <path d="M177.3,111.2 L125.9,126.0 " stroke="rgb(241, 0, 0)"/> <path d="M125.9,126.0 L74.5,140.8 " stroke="rgb(160, 0, 0)"/> <path d="M331.3,126.5 L280.0,141.3 " stroke="rgb(168, 255, 87)"/> <path d="M280.0,141.3 L228.7,156.1 " stroke="rgb(255, 245, 0)"/> <path d="M228.7,156.1 L177.3,170.9 " stroke="rgb(255, 164, 0)"/> <path d="M177.3,170.9 L125.9,185.7 " stroke="rgb(255, 83, 0)"/> <path d="M382.7,171.4 L331.3,186.2 " stroke="rgb( 6, 255, 249)"/> <path d="M331.3,186.2 L280.0,201.0 " stroke="rgb( 87, 255, 168)"/> <path d="M280.0,201.0 L228.7,215.8 " stroke="rgb(168, 255, 87)"/> <path d="M228.7,215.8 L177.3,230.6 " stroke="rgb(255, 245, 0)"/> <path d="M434.1,216.3 L382.7,231.1 " stroke="rgb( 0, 83, 255)"/> <path d="M382.7,231.1 L331.3,245.9 " stroke="rgb( 0, 164, 255)"/> <path d="M331.3,245.9 L280.0,260.7 " stroke="rgb( 6, 255, 249)"/> <path d="M280.0,260.7 L228.7,275.5 " stroke="rgb( 87, 255, 168)"/> <path d="M485.5,261.2 L434.1,276.0 " stroke="rgb( 0, 0, 160)"/> <path d="M434.1,276.0 L382.7,290.8 " stroke="rgb( 0, 2, 255)"/> <path d="M382.7,290.8 L331.3,305.6 " stroke="rgb( 0, 83, 255)"/> <path d="M331.3,305.6 L280.0,320.4 " stroke="rgb( 0, 164, 255)"/> <path d="M280.0,81.6 L331.3,126.5 " stroke="rgb(217, 255, 38)"/> <path d="M331.3,126.5 L382.7,171.4 " stroke="rgb( 38, 255, 217)"/> <path d="M382.7,171.4 L434.1,216.3 " stroke="rgb( 0, 132, 255)"/> <path d="M434.1,216.3 L485.5,261.2 " stroke="rgb( 0, 0, 208)"/> <path d="M228.7,96.4 L280.0,141.3 " stroke="rgb(255, 212, 0)"/> <path d="M280.0,141.3 L331.3,186.2 " stroke="rgb(136, 255, 119)"/> <path d="M331.3,186.2 L382.7,231.1 " stroke="rgb( 0, 212, 255)"/> <path d="M382.7,231.1 L434.1,276.0 " stroke="rgb( 0, 34, 255)"/> <path d="M177.3,111.2 L228.7,156.1 " stroke="rgb(255, 115, 0)"/> <path d="M228.7,156.1 L280.0,201.0 " stroke="rgb(217, 255, 38)"/> <path d="M280.0,201.0 L331.3,245.9 " stroke="rgb( 38, 255, 217)"/> <path d="M331.3,245.9 L382.7,290.8 " stroke="rgb( 0, 132, 255)"/> <path d="M125.9,126.0 L177.3,170.9 " stroke="rgb(255, 34, 0)"/> <path d="M177.3,170.9 L228.7,215.8 " stroke="rgb(255, 212, 0)"/> <path d="M228.7,215.8 L280.0,260.7 " stroke="rgb(136, 255, 119)"/> <path d="M280.0,260.7 L331.3,305.6 " stroke="rgb( 0, 212, 255)"/> <path d="M74.5,140.8 L125.9,185.7 " stroke="rgb(208, 0, 0)"/> <path d="M125.9,185.7 L177.3,230.6 " stroke="rgb(255, 115, 0)"/> <path d="M177.3,230.6 L228.7,275.5 " stroke="rgb(217, 255, 38)"/> <path d="M228.7,275.5 L280.0,320.4 " stroke="rgb( 38, 255, 217)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>gnuplot_plot_2a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M280.0,112.7 L228.7,135.6 " stroke="rgb( 38, 255, 217)"/> <path d="M228.7,135.6 L177.3,158.4 " stroke="rgb( 55, 255, 200)"/> <path d="M177.3,158.4 L125.9,181.2 " stroke="rgb( 71, 255, 184)"/> <path d="M125.9,181.2 L74.5,204.0 " stroke="rgb( 87, 255, 168)"/> <path d="M331.3,138.6 L280.0,161.4 " stroke="rgb( 38, 255, 217)"/> <path d="M280.0,161.4 L228.7,184.2 " stroke="rgb( 55, 255, 200)"/> <path d="M228.7,184.2 L177.3,207.0 " stroke="rgb( 71, 255, 184)"/> <path d="M177.3,207.0 L125.9,229.8 " stroke="rgb( 87, 255, 168)"/> <path d="M382.7,164.4 L331.3,187.3 " stroke="rgb( 22, 255, 233)"/> <path d="M331.3,187.3 L280.0,210.0 " stroke="rgb( 38, 255, 217)"/> <path d="M280.0,210.0 L228.7,232.8 " stroke="rgb( 55, 255, 200)"/> <path d="M228.7,232.8 L177.3,255.6 " stroke="rgb( 71, 255, 184)"/> <path d="M434.1,190.3 L382.7,213.0 " stroke="rgb( 22, 255, 233)"/> <path d="M382.7,213.0 L331.3,235.8 " stroke="rgb( 38, 255, 217)"/> <path d="M331.3,235.8 L280.0,258.7 " stroke="rgb( 55, 255, 200)"/> <path d="M280.0,258.7 L228.7,281.5 " stroke="rgb( 71, 255, 184)"/> <path d="M485.5,216.0 L434.1,238.8 " stroke="rgb( 6, 255, 249)"/> <path d="M434.1,238.8 L382.7,261.7 " stroke="rgb( 22, 255, 233)"/> <path d="M382.7,261.7 L331.3,284.5 " stroke="rgb( 38, 255, 217)"/> <path d="M331.3,284.5 L280.0,307.3 " stroke="rgb( 55, 255, 200)"/> <path d="M280.0,112.7 L331.3,138.6 L382.7,164.4 " stroke="rgb( 22, 255, 233)"/> <path d="M382.7,164.4 L434.1,190.3 L485.5,216.0 " stroke="rgb( 6, 255, 249)"/> <path d="M228.7,135.6 L280.0,161.4 L331.3,187.3 " stroke="rgb( 38, 255, 217)"/> <path d="M331.3,187.3 L382.7,213.0 L434.1,238.8 " stroke="rgb( 22, 255, 233)"/> <path d="M177.3,158.4 L228.7,184.2 " stroke="rgb( 71, 255, 184)"/> <path d="M228.7,184.2 L280.0,210.0 " stroke="rgb( 55, 255, 200)"/> <path d="M280.0,210.0 L331.3,235.8 L382.7,261.7 " stroke="rgb( 38, 255, 217)"/> <path d="M125.9,181.2 L177.3,207.0 " stroke="rgb( 87, 255, 168)"/> <path d="M177.3,207.0 L228.7,232.8 L280.0,258.7 " stroke="rgb( 71, 255, 184)"/> <path d="M280.0,258.7 L331.3,284.5 " stroke="rgb( 55, 255, 200)"/> <path d="M74.5,204.0 L125.9,229.8 " stroke="rgb(103, 255, 152)"/> <path d="M125.9,229.8 L177.3,255.6 L228.7,281.5 " stroke="rgb( 87, 255, 168)"/> <path d="M228.7,281.5 L280.0,307.3 " stroke="rgb( 71, 255, 184)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>gnuplot_plot_3a</title> +<g color="white" fill="none" stroke="rgb( 71, 255, 184)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <use color="rgb( 0, 0, 255)" transform="translate(351.9,168.4) scale(9.00)" xlink:href="#gpPt5"/> +</g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 0, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,271.2 L280.0,370.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,271.2 L280.0,370.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M280.0,370.6 L280.0,230.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M74.5,130.8 L280.0,230.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M485.5,130.8 L280.0,230.0 " stroke="black"/></g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/lecture_10_files/lecture_10_6_0.pdf b/lecture_10/lecture_10_files/lecture_10_6_0.pdf new file mode 100644 index 0000000..53b6aa0 Binary files /dev/null and b/lecture_10/lecture_10_files/lecture_10_6_0.pdf differ diff --git a/lecture_10/lecture_10_files/lecture_10_6_0.svg b/lecture_10/lecture_10_files/lecture_10_6_0.svg new file mode 100644 index 0000000..73465c0 --- /dev/null +++ b/lecture_10/lecture_10_files/lecture_10_6_0.svg @@ -0,0 +1,397 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L162.1,189.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L162.1,189.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L111.7,187.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M162.1,189.9 L162.1,49.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L448.3,73.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,187.8 L162.1,49.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,73.8 L162.1,49.4 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,328.2 L162.1,189.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L108.5,337.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M162.1,189.9 L165.3,181.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(106.4,355.5)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M147.5,331.2 L197.9,193.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M147.5,331.2 L144.3,340.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M197.9,193.0 L201.1,184.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(142.1,358.5)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M183.2,334.3 L233.7,196.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M183.2,334.3 L180.0,343.1 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M233.7,196.0 L236.9,187.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(177.9,361.6)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M219.0,337.3 L269.5,199.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M219.0,337.3 L215.8,346.1 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M269.5,199.1 L272.7,190.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(213.7,364.6)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M254.8,340.4 L305.2,202.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M254.8,340.4 L251.6,349.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M305.2,202.0 L308.4,193.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(249.5,367.7)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M290.5,343.4 L341.0,205.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M290.5,343.4 L287.3,352.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M341.0,205.1 L344.2,196.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(285.2,370.7)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M326.3,346.5 L376.8,208.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M326.3,346.5 L323.1,355.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M376.8,208.1 L380.0,199.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(321.0,373.8)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M362.1,349.5 L412.5,211.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M362.1,349.5 L358.9,358.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M412.5,211.2 L415.7,202.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(356.8,376.8)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M397.9,352.6 L448.3,214.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M397.9,352.6 L394.7,361.4 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L451.5,205.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(392.5,379.9)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M397.9,352.6 L111.7,328.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M397.9,352.6 L410.3,353.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L99.3,327.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(418.4,361.2)"> + <text><tspan font-family="{}">-2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M404.2,335.3 L118.0,310.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M404.2,335.3 L416.6,336.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M118.0,310.9 L105.6,309.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(424.7,343.9)"> + <text><tspan font-family="{}">-1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M410.5,318.0 L124.3,293.6 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M410.5,318.0 L422.9,319.0 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M124.3,293.6 L111.9,292.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(431.1,326.6)"> + <text><tspan font-family="{}">-1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M416.8,300.7 L130.6,276.3 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M416.8,300.7 L429.2,301.8 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M130.6,276.3 L118.2,275.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(437.4,309.3)"> + <text><tspan font-family="{}">-0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M423.1,283.4 L136.9,259.0 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M423.1,283.4 L435.5,284.5 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M136.9,259.0 L124.5,257.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(443.7,292.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M429.4,266.1 L143.2,241.7 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M429.4,266.1 L441.8,267.2 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M143.2,241.7 L130.8,240.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(450.0,274.7)"> + <text><tspan font-family="{}">0.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M435.7,248.8 L149.5,224.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M435.7,248.8 L448.1,249.9 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M149.5,224.4 L137.1,223.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(456.3,257.4)"> + <text><tspan font-family="{}">1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M442.0,231.5 L155.8,207.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M442.0,231.5 L454.4,232.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M155.8,207.1 L143.4,206.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(462.6,240.1)"> + <text><tspan font-family="{}">1.5</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M448.3,214.2 L162.1,189.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L460.7,215.3 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M162.1,189.9 L149.7,188.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="start" transform="translate(468.9,222.8)"> + <text><tspan font-family="{}">2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,328.2 L162.1,189.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,189.9 L448.3,214.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L99.2,328.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,334.2)"> + <text><tspan font-family="{}">-30</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L460.8,214.2 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,304.8 L162.1,166.5 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,166.5 L448.3,190.9 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,304.8 L99.2,304.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,310.8)"> + <text><tspan font-family="{}">-20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,190.9 L460.8,190.9 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,281.4 L162.1,143.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,143.1 L448.3,167.5 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,281.4 L99.2,281.4 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,287.4)"> + <text><tspan font-family="{}">-10</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,167.5 L460.8,167.5 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,257.9 L162.1,119.7 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,119.7 L448.3,144.1 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,257.9 L99.2,257.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,263.9)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,144.1 L460.8,144.1 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,234.5 L162.1,96.3 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,96.3 L448.3,120.6 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,234.5 L99.2,234.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,240.5)"> + <text><tspan font-family="{}">10</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,120.6 L460.8,120.6 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,211.1 L162.1,72.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,72.8 L448.3,97.2 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,211.1 L99.2,211.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,217.1)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,97.2 L460.8,97.2 " stroke="black"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M111.7,187.8 L162.1,49.4 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="gray" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path class="gridline" d="M162.1,49.4 L448.3,73.8 " stroke="gray" stroke-dasharray="2,4"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,187.8 L99.2,187.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(81.1,193.8)"> + <text><tspan font-family="{}">30</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,73.8 L460.8,73.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(59.6,257.9) rotate(-90)"> + <text><tspan font-family="{}">x3</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> + <g id="gnuplot_plot_1a"><title>gnuplot_plot_1a</title> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M162.1,79.9 L160.0,84.8 " stroke="rgb(255, 34, 0)"/> <path d="M160.0,84.8 L157.9,89.8 L155.8,94.8 L153.7,99.8 " stroke="rgb(255, 18, 0)"/> <path d="M153.7,99.8 L151.6,104.8 L149.5,109.8 " stroke="rgb(255, 2, 0)"/> <path d="M149.5,109.8 L147.4,114.8 L145.3,119.7 " stroke="rgb(241, 0, 0)"/> <path d="M145.3,119.7 L143.2,124.7 L141.1,129.7 " stroke="rgb(225, 0, 0)"/> <path d="M141.1,129.7 L139.0,134.7 L136.9,139.7 L134.8,144.7 " stroke="rgb(208, 0, 0)"/> <path d="M134.8,144.7 L132.7,149.6 L130.6,154.6 " stroke="rgb(192, 0, 0)"/> <path d="M130.6,154.6 L128.5,159.6 L126.4,164.6 " stroke="rgb(176, 0, 0)"/> <path d="M126.4,164.6 L124.3,169.6 L122.2,174.6 " stroke="rgb(160, 0, 0)"/> <path d="M122.2,174.6 L120.1,179.6 L118.0,184.5 L115.9,189.5 " stroke="rgb(144, 0, 0)"/> <path d="M115.9,189.5 L113.8,194.5 L111.7,199.5 " stroke="rgb(128, 0, 0)"/> <path d="M174.1,84.8 L172.0,89.8 L169.9,94.7 " stroke="rgb(255, 67, 0)"/> <path d="M169.9,94.7 L167.8,99.7 L165.7,104.7 " stroke="rgb(255, 51, 0)"/> <path d="M165.7,104.7 L163.6,109.7 L161.5,114.7 " stroke="rgb(255, 34, 0)"/> <path d="M161.5,114.7 L159.4,119.7 L157.2,124.7 L155.1,129.6 " stroke="rgb(255, 18, 0)"/> <path d="M155.1,129.6 L153.0,134.6 L150.9,139.6 " stroke="rgb(255, 2, 0)"/> <path d="M150.9,139.6 L148.8,144.6 L146.7,149.6 " stroke="rgb(241, 0, 0)"/> <path d="M146.7,149.6 L144.6,154.6 L142.5,159.5 " stroke="rgb(225, 0, 0)"/> <path d="M142.5,159.5 L140.4,164.5 L138.3,169.5 L136.2,174.5 " stroke="rgb(208, 0, 0)"/> <path d="M136.2,174.5 L134.1,179.5 L132.0,184.5 " stroke="rgb(192, 0, 0)"/> <path d="M132.0,184.5 L129.9,189.5 L127.8,194.4 " stroke="rgb(176, 0, 0)"/> <path d="M127.8,194.4 L125.7,199.4 L123.6,204.3 " stroke="rgb(160, 0, 0)"/> <path d="M186.0,89.7 L183.9,94.7 L181.8,99.7 " stroke="rgb(255, 99, 0)"/> <path d="M181.8,99.7 L179.7,104.7 L177.6,109.6 L175.5,114.6 " stroke="rgb(255, 83, 0)"/> <path d="M175.5,114.6 L173.4,119.6 L171.3,124.6 " stroke="rgb(255, 67, 0)"/> <path d="M171.3,124.6 L169.2,129.6 L167.1,134.6 " stroke="rgb(255, 51, 0)"/> <path d="M167.1,134.6 L165.0,139.5 L162.9,144.5 " stroke="rgb(255, 34, 0)"/> <path d="M162.9,144.5 L160.8,149.5 L158.7,154.5 L156.6,159.5 " stroke="rgb(255, 18, 0)"/> <path d="M156.6,159.5 L154.5,164.5 L152.4,169.5 " stroke="rgb(255, 2, 0)"/> <path d="M152.4,169.5 L150.2,174.4 L148.1,179.4 " stroke="rgb(241, 0, 0)"/> <path d="M148.1,179.4 L146.0,184.4 L143.9,189.4 " stroke="rgb(225, 0, 0)"/> <path d="M143.9,189.4 L141.8,194.4 L139.7,199.4 L137.6,204.2 " stroke="rgb(208, 0, 0)"/> <path d="M137.6,204.2 L135.5,209.2 " stroke="rgb(192, 0, 0)"/> <path d="M197.9,94.6 L195.8,99.6 " stroke="rgb(255, 148, 0)"/> <path d="M195.8,99.6 L193.7,104.6 L191.6,109.6 " stroke="rgb(255, 132, 0)"/> <path d="M191.6,109.6 L189.5,114.6 L187.4,119.5 " stroke="rgb(255, 115, 0)"/> <path d="M187.4,119.5 L185.3,124.5 L183.2,129.5 " stroke="rgb(255, 99, 0)"/> <path d="M183.2,129.5 L181.1,134.5 L179.0,139.5 L176.9,144.5 " stroke="rgb(255, 83, 0)"/> <path d="M176.9,144.5 L174.8,149.4 L172.7,154.4 " stroke="rgb(255, 67, 0)"/> <path d="M172.7,154.4 L170.6,159.4 L168.5,164.4 " stroke="rgb(255, 51, 0)"/> <path d="M168.5,164.4 L166.4,169.4 L164.3,174.4 " stroke="rgb(255, 34, 0)"/> <path d="M164.3,174.4 L162.2,179.4 L160.1,184.3 L158.0,189.3 " stroke="rgb(255, 18, 0)"/> <path d="M158.0,189.3 L155.9,194.3 L153.8,199.3 " stroke="rgb(255, 2, 0)"/> <path d="M153.8,199.3 L151.7,204.2 L149.6,209.2 " stroke="rgb(241, 0, 0)"/> <path d="M149.6,209.2 L147.5,214.2 " stroke="rgb(225, 0, 0)"/> <path d="M209.9,99.5 L207.8,104.5 " stroke="rgb(255, 180, 0)"/> <path d="M207.8,104.5 L205.7,109.5 L203.6,114.5 " stroke="rgb(255, 164, 0)"/> <path d="M203.6,114.5 L201.4,119.5 L199.3,124.5 L197.2,129.4 " stroke="rgb(255, 148, 0)"/> <path d="M197.2,129.4 L195.1,134.4 L193.0,139.4 " stroke="rgb(255, 132, 0)"/> <path d="M193.0,139.4 L190.9,144.4 L188.8,149.4 " stroke="rgb(255, 115, 0)"/> <path d="M188.8,149.4 L186.7,154.4 L184.6,159.4 " stroke="rgb(255, 99, 0)"/> <path d="M184.6,159.4 L182.5,164.3 L180.4,169.3 L178.3,174.3 " stroke="rgb(255, 83, 0)"/> <path d="M178.3,174.3 L176.2,179.3 L174.1,184.3 " stroke="rgb(255, 67, 0)"/> <path d="M174.1,184.3 L172.0,189.3 L169.9,194.2 " stroke="rgb(255, 51, 0)"/> <path d="M169.9,194.2 L167.8,199.2 L165.7,204.1 " stroke="rgb(255, 34, 0)"/> <path d="M165.7,204.1 L163.6,209.1 L161.5,214.1 L159.4,219.1 " stroke="rgb(255, 18, 0)"/> <path d="M221.8,104.5 L219.7,109.4 L217.6,114.4 " stroke="rgb(255, 212, 0)"/> <path d="M217.6,114.4 L215.5,119.4 L213.4,124.4 " stroke="rgb(255, 196, 0)"/> <path d="M213.4,124.4 L211.3,129.4 L209.2,134.4 " stroke="rgb(255, 180, 0)"/> <path d="M209.2,134.4 L207.1,139.3 L205.0,144.3 " stroke="rgb(255, 164, 0)"/> <path d="M205.0,144.3 L202.9,149.3 L200.8,154.3 L198.7,159.3 " stroke="rgb(255, 148, 0)"/> <path d="M198.7,159.3 L196.6,164.3 L194.4,169.3 " stroke="rgb(255, 132, 0)"/> <path d="M194.4,169.3 L192.3,174.2 L190.2,179.2 " stroke="rgb(255, 115, 0)"/> <path d="M190.2,179.2 L188.1,184.2 L186.0,189.2 " stroke="rgb(255, 99, 0)"/> <path d="M186.0,189.2 L183.9,194.2 L181.8,199.2 L179.7,204.1 " stroke="rgb(255, 83, 0)"/> <path d="M179.7,204.1 L177.6,209.0 L175.5,214.0 " stroke="rgb(255, 67, 0)"/> <path d="M175.5,214.0 L173.4,219.0 L171.3,224.0 " stroke="rgb(255, 51, 0)"/> <path d="M233.7,109.4 L231.6,114.4 L229.5,119.3 " stroke="rgb(255, 245, 0)"/> <path d="M229.5,119.3 L227.4,124.3 L225.3,129.3 " stroke="rgb(255, 229, 0)"/> <path d="M225.3,129.3 L223.2,134.3 L221.1,139.3 L219.0,144.3 " stroke="rgb(255, 212, 0)"/> <path d="M219.0,144.3 L216.9,149.3 L214.8,154.2 " stroke="rgb(255, 196, 0)"/> <path d="M214.8,154.2 L212.7,159.2 L210.6,164.2 " stroke="rgb(255, 180, 0)"/> <path d="M210.6,164.2 L208.5,169.2 L206.4,174.2 " stroke="rgb(255, 164, 0)"/> <path d="M206.4,174.2 L204.3,179.2 L202.2,184.1 L200.1,189.1 " stroke="rgb(255, 148, 0)"/> <path d="M200.1,189.1 L198.0,194.1 L195.9,199.1 " stroke="rgb(255, 132, 0)"/> <path d="M195.9,199.1 L193.8,204.0 L191.7,209.0 " stroke="rgb(255, 115, 0)"/> <path d="M191.7,209.0 L189.5,214.0 L187.4,218.9 " stroke="rgb(255, 99, 0)"/> <path d="M187.4,218.9 L185.3,223.9 L183.2,228.9 " stroke="rgb(255, 83, 0)"/> <path d="M245.6,114.3 L243.5,119.3 L241.4,124.3 L239.3,129.2 " stroke="rgb(233, 255, 22)"/> <path d="M239.3,129.2 L237.2,134.2 L235.1,139.2 " stroke="rgb(249, 255, 6)"/> <path d="M235.1,139.2 L233.0,144.2 L230.9,149.2 " stroke="rgb(255, 245, 0)"/> <path d="M230.9,149.2 L228.8,154.2 L226.7,159.2 " stroke="rgb(255, 229, 0)"/> <path d="M226.7,159.2 L224.6,164.1 L222.5,169.1 L220.4,174.1 " stroke="rgb(255, 212, 0)"/> <path d="M220.4,174.1 L218.3,179.1 L216.2,184.1 " stroke="rgb(255, 196, 0)"/> <path d="M216.2,184.1 L214.1,189.1 L212.0,194.1 " stroke="rgb(255, 180, 0)"/> <path d="M212.0,194.1 L209.9,199.0 L207.8,203.9 " stroke="rgb(255, 164, 0)"/> <path d="M207.8,203.9 L205.7,208.9 L203.6,213.9 L201.5,218.9 " stroke="rgb(255, 148, 0)"/> <path d="M201.5,218.9 L199.4,223.9 L197.3,228.8 " stroke="rgb(255, 132, 0)"/> <path d="M197.3,228.8 L195.2,233.8 " stroke="rgb(255, 115, 0)"/> <path d="M257.6,119.2 L255.5,124.2 " stroke="rgb(184, 255, 71)"/> <path d="M255.5,124.2 L253.4,129.2 L251.3,134.2 " stroke="rgb(200, 255, 55)"/> <path d="M251.3,134.2 L249.2,139.2 L247.1,144.1 " stroke="rgb(217, 255, 38)"/> <path d="M247.1,144.1 L245.0,149.1 L242.9,154.1 L240.7,159.1 " stroke="rgb(233, 255, 22)"/> <path d="M240.7,159.1 L238.6,164.1 L236.5,169.1 " stroke="rgb(249, 255, 6)"/> <path d="M236.5,169.1 L234.4,174.0 L232.3,179.0 " stroke="rgb(255, 245, 0)"/> <path d="M232.3,179.0 L230.2,184.0 L228.1,189.0 " stroke="rgb(255, 229, 0)"/> <path d="M228.1,189.0 L226.0,194.0 L223.9,199.0 L221.8,203.9 " stroke="rgb(255, 212, 0)"/> <path d="M221.8,203.9 L219.7,208.8 L217.6,213.8 " stroke="rgb(255, 196, 0)"/> <path d="M217.6,213.8 L215.5,218.8 L213.4,223.8 " stroke="rgb(255, 180, 0)"/> <path d="M213.4,223.8 L211.3,228.8 L209.2,233.8 " stroke="rgb(255, 164, 0)"/> <path d="M209.2,233.8 L207.1,238.7 " stroke="rgb(255, 148, 0)"/> <path d="M269.5,124.1 L267.4,129.1 " stroke="rgb(152, 255, 103)"/> <path d="M267.4,129.1 L265.3,134.1 L263.2,139.1 L261.1,144.1 " stroke="rgb(168, 255, 87)"/> <path d="M261.1,144.1 L259.0,149.1 L256.9,154.0 " stroke="rgb(184, 255, 71)"/> <path d="M256.9,154.0 L254.8,159.0 L252.7,164.0 " stroke="rgb(200, 255, 55)"/> <path d="M252.7,164.0 L250.6,169.0 L248.5,174.0 " stroke="rgb(217, 255, 38)"/> <path d="M248.5,174.0 L246.4,179.0 L244.3,184.0 L242.2,188.9 " stroke="rgb(233, 255, 22)"/> <path d="M242.2,188.9 L240.1,193.9 L238.0,198.9 " stroke="rgb(249, 255, 6)"/> <path d="M238.0,198.9 L235.9,203.8 L233.7,208.8 " stroke="rgb(255, 245, 0)"/> <path d="M233.7,208.8 L231.6,213.8 L229.5,218.7 " stroke="rgb(255, 229, 0)"/> <path d="M229.5,218.7 L227.4,223.7 L225.3,228.7 L223.2,233.7 " stroke="rgb(255, 212, 0)"/> <path d="M223.2,233.7 L221.1,238.7 L219.0,243.7 " stroke="rgb(255, 196, 0)"/> <path d="M281.3,129.1 L279.3,134.0 L277.2,139.0 " stroke="rgb(119, 255, 136)"/> <path d="M277.2,139.0 L275.1,144.0 L273.0,149.0 " stroke="rgb(136, 255, 119)"/> <path d="M273.0,149.0 L270.9,154.0 L268.8,159.0 " stroke="rgb(152, 255, 103)"/> <path d="M268.8,159.0 L266.7,163.9 L264.6,168.9 L262.5,173.9 " stroke="rgb(168, 255, 87)"/> <path d="M262.5,173.9 L260.4,178.9 L258.3,183.9 " stroke="rgb(184, 255, 71)"/> <path d="M258.3,183.9 L256.2,188.9 L254.1,193.9 " stroke="rgb(200, 255, 55)"/> <path d="M254.1,193.9 L252.0,198.8 L249.9,203.7 " stroke="rgb(217, 255, 38)"/> <path d="M249.9,203.7 L247.8,208.7 L245.7,213.7 L243.6,218.7 " stroke="rgb(233, 255, 22)"/> <path d="M243.6,218.7 L241.5,223.7 L239.4,228.6 " stroke="rgb(249, 255, 6)"/> <path d="M239.4,228.6 L237.3,233.6 L235.2,238.6 " stroke="rgb(255, 245, 0)"/> <path d="M235.2,238.6 L233.1,243.6 L231.0,248.6 " stroke="rgb(255, 229, 0)"/> <path d="M293.3,134.0 L291.2,139.0 L289.1,143.9 " stroke="rgb( 87, 255, 168)"/> <path d="M289.1,143.9 L287.0,148.9 L284.8,153.9 L282.7,158.9 " stroke="rgb(103, 255, 152)"/> <path d="M282.7,158.9 L280.6,163.9 L278.6,168.9 " stroke="rgb(119, 255, 136)"/> <path d="M278.6,168.9 L276.5,173.8 L274.4,178.8 " stroke="rgb(136, 255, 119)"/> <path d="M274.4,178.8 L272.3,183.8 L270.2,188.8 " stroke="rgb(152, 255, 103)"/> <path d="M270.2,188.8 L268.1,193.8 L266.0,198.8 L263.9,203.7 " stroke="rgb(168, 255, 87)"/> <path d="M263.9,203.7 L261.8,208.6 L259.7,213.6 " stroke="rgb(184, 255, 71)"/> <path d="M259.7,213.6 L257.6,218.6 L255.5,223.6 " stroke="rgb(200, 255, 55)"/> <path d="M255.5,223.6 L253.4,228.6 L251.3,233.6 " stroke="rgb(217, 255, 38)"/> <path d="M251.3,233.6 L249.2,238.6 L247.1,243.5 L245.0,248.5 " stroke="rgb(233, 255, 22)"/> <path d="M245.0,248.5 L242.9,253.5 " stroke="rgb(249, 255, 6)"/> <path d="M305.2,138.9 L303.1,143.9 " stroke="rgb( 38, 255, 217)"/> <path d="M303.1,143.9 L301.0,148.9 L298.9,153.8 " stroke="rgb( 55, 255, 200)"/> <path d="M298.9,153.8 L296.8,158.8 L294.7,163.8 " stroke="rgb( 71, 255, 184)"/> <path d="M294.7,163.8 L292.6,168.8 L290.5,173.8 " stroke="rgb( 87, 255, 168)"/> <path d="M290.5,173.8 L288.4,178.8 L286.3,183.8 L284.2,188.7 " stroke="rgb(103, 255, 152)"/> <path d="M284.2,188.7 L282.1,193.7 L280.0,198.7 " stroke="rgb(119, 255, 136)"/> <path d="M280.0,198.7 L277.9,203.6 L275.8,208.6 " stroke="rgb(136, 255, 119)"/> <path d="M275.8,208.6 L273.7,213.6 L271.6,218.5 " stroke="rgb(152, 255, 103)"/> <path d="M271.6,218.5 L269.5,223.5 L267.4,228.5 L265.3,233.5 " stroke="rgb(168, 255, 87)"/> <path d="M265.3,233.5 L263.2,238.5 L261.1,243.5 " stroke="rgb(184, 255, 71)"/> <path d="M261.1,243.5 L259.0,248.5 L256.9,253.4 " stroke="rgb(200, 255, 55)"/> <path d="M256.9,253.4 L254.8,258.4 " stroke="rgb(217, 255, 38)"/> <path d="M317.1,143.8 L315.0,148.8 " stroke="rgb( 6, 255, 249)"/> <path d="M315.0,148.8 L312.9,153.8 L310.8,158.8 " stroke="rgb( 22, 255, 233)"/> <path d="M310.8,158.8 L308.7,163.7 L306.6,168.7 L304.5,173.7 " stroke="rgb( 38, 255, 217)"/> <path d="M304.5,173.7 L302.4,178.7 L300.3,183.7 " stroke="rgb( 55, 255, 200)"/> <path d="M300.3,183.7 L298.2,188.7 L296.1,193.7 " stroke="rgb( 71, 255, 184)"/> <path d="M296.1,193.7 L294.0,198.6 L291.9,203.5 " stroke="rgb( 87, 255, 168)"/> <path d="M291.9,203.5 L289.8,208.5 L287.7,213.5 L285.6,218.5 " stroke="rgb(103, 255, 152)"/> <path d="M285.6,218.5 L283.5,223.5 L281.4,228.5 " stroke="rgb(119, 255, 136)"/> <path d="M281.4,228.5 L279.4,233.4 L277.3,238.4 " stroke="rgb(136, 255, 119)"/> <path d="M277.3,238.4 L275.2,243.4 L273.0,248.4 " stroke="rgb(152, 255, 103)"/> <path d="M273.0,248.4 L270.9,253.4 L268.8,258.4 L266.7,263.3 " stroke="rgb(168, 255, 87)"/> <path d="M329.0,148.7 L326.9,153.7 L324.8,158.7 " stroke="rgb( 0, 229, 255)"/> <path d="M324.8,158.7 L322.7,163.7 L320.6,168.7 " stroke="rgb( 0, 245, 255)"/> <path d="M320.6,168.7 L318.5,173.7 L316.4,178.6 " stroke="rgb( 6, 255, 249)"/> <path d="M316.4,178.6 L314.3,183.6 L312.2,188.6 " stroke="rgb( 22, 255, 233)"/> <path d="M312.2,188.6 L310.1,193.6 L308.0,198.6 L305.9,203.5 " stroke="rgb( 38, 255, 217)"/> <path d="M305.9,203.5 L303.8,208.4 L301.7,213.4 " stroke="rgb( 55, 255, 200)"/> <path d="M301.7,213.4 L299.6,218.4 L297.5,223.4 " stroke="rgb( 71, 255, 184)"/> <path d="M297.5,223.4 L295.4,228.4 L293.3,233.4 " stroke="rgb( 87, 255, 168)"/> <path d="M293.3,233.4 L291.2,238.4 L289.1,243.3 L287.0,248.3 " stroke="rgb(103, 255, 152)"/> <path d="M287.0,248.3 L284.9,253.3 L282.8,258.3 " stroke="rgb(119, 255, 136)"/> <path d="M282.8,258.3 L280.7,263.3 L278.7,268.3 " stroke="rgb(136, 255, 119)"/> <path d="M341.0,153.6 L338.9,158.6 L336.8,163.6 " stroke="rgb( 0, 196, 255)"/> <path d="M336.8,163.6 L334.7,168.6 L332.6,173.6 " stroke="rgb( 0, 212, 255)"/> <path d="M332.6,173.6 L330.5,178.6 L328.4,183.6 L326.3,188.5 " stroke="rgb( 0, 229, 255)"/> <path d="M326.3,188.5 L324.1,193.5 L322.0,198.5 " stroke="rgb( 0, 245, 255)"/> <path d="M322.0,198.5 L319.9,203.4 L317.8,208.4 " stroke="rgb( 6, 255, 249)"/> <path d="M317.8,208.4 L315.7,213.4 L313.6,218.4 " stroke="rgb( 22, 255, 233)"/> <path d="M313.6,218.4 L311.5,223.3 L309.4,228.3 L307.3,233.3 " stroke="rgb( 38, 255, 217)"/> <path d="M307.3,233.3 L305.2,238.3 L303.1,243.3 " stroke="rgb( 55, 255, 200)"/> <path d="M303.1,243.3 L301.0,248.3 L298.9,253.2 " stroke="rgb( 71, 255, 184)"/> <path d="M298.9,253.2 L296.8,258.2 L294.7,263.2 " stroke="rgb( 87, 255, 168)"/> <path d="M294.7,263.2 L292.6,268.2 L290.5,273.2 " stroke="rgb(103, 255, 152)"/> <path d="M352.9,158.6 L350.8,163.6 L348.7,168.5 L346.6,173.5 " stroke="rgb( 0, 164, 255)"/> <path d="M346.6,173.5 L344.5,178.5 L342.4,183.5 " stroke="rgb( 0, 180, 255)"/> <path d="M342.4,183.5 L340.3,188.5 L338.2,193.5 " stroke="rgb( 0, 196, 255)"/> <path d="M338.2,193.5 L336.1,198.4 L334.0,203.3 " stroke="rgb( 0, 212, 255)"/> <path d="M334.0,203.3 L331.9,208.3 L329.8,213.3 L327.7,218.3 " stroke="rgb( 0, 229, 255)"/> <path d="M327.7,218.3 L325.6,223.3 L323.5,228.3 " stroke="rgb( 0, 245, 255)"/> <path d="M323.5,228.3 L321.4,233.2 L319.3,238.2 " stroke="rgb( 6, 255, 249)"/> <path d="M319.3,238.2 L317.1,243.2 L315.0,248.2 " stroke="rgb( 22, 255, 233)"/> <path d="M315.0,248.2 L312.9,253.2 L310.8,258.2 L308.7,263.1 " stroke="rgb( 38, 255, 217)"/> <path d="M308.7,263.1 L306.6,268.1 L304.5,273.1 " stroke="rgb( 55, 255, 200)"/> <path d="M304.5,273.1 L302.4,278.1 " stroke="rgb( 71, 255, 184)"/> <path d="M364.8,163.5 L362.7,168.5 " stroke="rgb( 0, 115, 255)"/> <path d="M362.7,168.5 L360.6,173.5 L358.5,178.4 " stroke="rgb( 0, 132, 255)"/> <path d="M358.5,178.4 L356.4,183.4 L354.3,188.4 " stroke="rgb( 0, 148, 255)"/> <path d="M354.3,188.4 L352.2,193.4 L350.1,198.4 L348.0,203.3 " stroke="rgb( 0, 164, 255)"/> <path d="M348.0,203.3 L345.9,208.3 L343.8,213.2 " stroke="rgb( 0, 180, 255)"/> <path d="M343.8,213.2 L341.7,218.2 L339.6,223.2 " stroke="rgb( 0, 196, 255)"/> <path d="M339.6,223.2 L337.5,228.2 L335.4,233.2 " stroke="rgb( 0, 212, 255)"/> <path d="M335.4,233.2 L333.3,238.2 L331.2,243.1 L329.1,248.1 " stroke="rgb( 0, 229, 255)"/> <path d="M329.1,248.1 L327.0,253.1 L324.9,258.1 " stroke="rgb( 0, 245, 255)"/> <path d="M324.9,258.1 L322.8,263.1 L320.7,268.1 " stroke="rgb( 6, 255, 249)"/> <path d="M320.7,268.1 L318.6,273.1 L316.5,278.0 " stroke="rgb( 22, 255, 233)"/> <path d="M316.5,278.0 L314.4,283.0 " stroke="rgb( 38, 255, 217)"/> <path d="M376.8,168.4 L374.7,173.4 " stroke="rgb( 0, 83, 255)"/> <path d="M374.7,173.4 L372.6,178.4 L370.5,183.4 L368.3,188.3 " stroke="rgb( 0, 99, 255)"/> <path d="M368.3,188.3 L366.2,193.3 L364.1,198.3 " stroke="rgb( 0, 115, 255)"/> <path d="M364.1,198.3 L362.0,203.2 L359.9,208.2 " stroke="rgb( 0, 132, 255)"/> <path d="M359.9,208.2 L357.8,213.2 L355.7,218.2 " stroke="rgb( 0, 148, 255)"/> <path d="M355.7,218.2 L353.6,223.1 L351.5,228.1 L349.4,233.1 " stroke="rgb( 0, 164, 255)"/> <path d="M349.4,233.1 L347.3,238.1 L345.2,243.1 " stroke="rgb( 0, 180, 255)"/> <path d="M345.2,243.1 L343.1,248.1 L341.0,253.0 " stroke="rgb( 0, 196, 255)"/> <path d="M341.0,253.0 L338.9,258.0 L336.8,263.0 " stroke="rgb( 0, 212, 255)"/> <path d="M336.8,263.0 L334.7,268.0 L332.6,273.0 L330.5,278.0 " stroke="rgb( 0, 229, 255)"/> <path d="M330.5,278.0 L328.4,283.0 L326.3,287.9 " stroke="rgb( 0, 245, 255)"/> <path d="M388.7,173.3 L386.6,178.3 L384.5,183.3 " stroke="rgb( 0, 51, 255)"/> <path d="M384.5,183.3 L382.4,188.3 L380.3,193.3 " stroke="rgb( 0, 67, 255)"/> <path d="M380.3,193.3 L378.2,198.3 L376.1,203.1 " stroke="rgb( 0, 83, 255)"/> <path d="M376.1,203.1 L374.0,208.1 L371.9,213.1 L369.8,218.1 " stroke="rgb( 0, 99, 255)"/> <path d="M369.8,218.1 L367.7,223.1 L365.6,228.1 " stroke="rgb( 0, 115, 255)"/> <path d="M365.6,228.1 L363.4,233.0 L361.3,238.0 " stroke="rgb( 0, 132, 255)"/> <path d="M361.3,238.0 L359.2,243.0 L357.1,248.0 " stroke="rgb( 0, 148, 255)"/> <path d="M357.1,248.0 L355.0,253.0 L352.9,258.0 L350.8,263.0 " stroke="rgb( 0, 164, 255)"/> <path d="M350.8,263.0 L348.7,267.9 L346.6,272.9 " stroke="rgb( 0, 180, 255)"/> <path d="M346.6,272.9 L344.5,277.9 L342.4,282.9 " stroke="rgb( 0, 196, 255)"/> <path d="M342.4,282.9 L340.3,287.9 L338.2,292.9 " stroke="rgb( 0, 212, 255)"/> <path d="M400.6,178.2 L398.5,183.2 L396.4,188.2 " stroke="rgb( 0, 18, 255)"/> <path d="M396.4,188.2 L394.3,193.2 L392.2,198.2 L390.1,203.1 " stroke="rgb( 0, 34, 255)"/> <path d="M390.1,203.1 L388.0,208.1 L385.9,213.0 " stroke="rgb( 0, 51, 255)"/> <path d="M385.9,213.0 L383.8,218.0 L381.7,223.0 " stroke="rgb( 0, 67, 255)"/> <path d="M381.7,223.0 L379.6,228.0 L377.5,233.0 " stroke="rgb( 0, 83, 255)"/> <path d="M377.5,233.0 L375.4,238.0 L373.3,242.9 L371.2,247.9 " stroke="rgb( 0, 99, 255)"/> <path d="M371.2,247.9 L369.1,252.9 L367.0,257.9 " stroke="rgb( 0, 115, 255)"/> <path d="M367.0,257.9 L364.9,262.9 L362.8,267.9 " stroke="rgb( 0, 132, 255)"/> <path d="M362.8,267.9 L360.7,272.9 L358.6,277.8 " stroke="rgb( 0, 148, 255)"/> <path d="M358.6,277.8 L356.4,282.8 L354.3,287.8 L352.2,292.8 " stroke="rgb( 0, 164, 255)"/> <path d="M352.2,292.8 L350.1,297.8 " stroke="rgb( 0, 180, 255)"/> <path d="M412.5,183.2 L410.4,188.2 " stroke="rgb( 0, 0, 225)"/> <path d="M410.4,188.2 L408.3,193.1 L406.2,198.1 " stroke="rgb( 0, 0, 241)"/> <path d="M406.2,198.1 L404.1,203.0 L402.0,208.0 " stroke="rgb( 0, 2, 255)"/> <path d="M402.0,208.0 L399.9,213.0 L397.8,218.0 " stroke="rgb( 0, 18, 255)"/> <path d="M397.8,218.0 L395.7,222.9 L393.6,227.9 L391.5,232.9 " stroke="rgb( 0, 34, 255)"/> <path d="M391.5,232.9 L389.4,237.9 L387.3,242.9 " stroke="rgb( 0, 51, 255)"/> <path d="M387.3,242.9 L385.2,247.9 L383.1,252.9 " stroke="rgb( 0, 67, 255)"/> <path d="M383.1,252.9 L381.0,257.8 L378.9,262.8 " stroke="rgb( 0, 83, 255)"/> <path d="M378.9,262.8 L376.8,267.8 L374.7,272.8 L372.6,277.8 " stroke="rgb( 0, 99, 255)"/> <path d="M372.6,277.8 L370.5,282.8 L368.4,287.7 " stroke="rgb( 0, 115, 255)"/> <path d="M368.4,287.7 L366.3,292.7 L364.2,297.7 " stroke="rgb( 0, 132, 255)"/> <path d="M364.2,297.7 L362.1,302.7 " stroke="rgb( 0, 148, 255)"/> <path d="M424.5,188.1 L422.4,193.1 " stroke="rgb( 0, 0, 192)"/> <path d="M422.4,193.1 L420.3,198.1 L418.2,202.9 " stroke="rgb( 0, 0, 208)"/> <path d="M418.2,202.9 L416.1,207.9 L414.0,212.9 L411.9,217.9 " stroke="rgb( 0, 0, 225)"/> <path d="M411.9,217.9 L409.8,222.9 L407.6,227.9 " stroke="rgb( 0, 0, 241)"/> <path d="M407.6,227.9 L405.5,232.8 L403.4,237.8 " stroke="rgb( 0, 2, 255)"/> <path d="M403.4,237.8 L401.3,242.8 L399.2,247.8 " stroke="rgb( 0, 18, 255)"/> <path d="M399.2,247.8 L397.1,252.8 L395.0,257.8 L392.9,262.8 " stroke="rgb( 0, 34, 255)"/> <path d="M392.9,262.8 L390.8,267.7 L388.7,272.7 " stroke="rgb( 0, 51, 255)"/> <path d="M388.7,272.7 L386.6,277.7 L384.5,282.7 " stroke="rgb( 0, 67, 255)"/> <path d="M384.5,282.7 L382.4,287.7 L380.3,292.7 " stroke="rgb( 0, 83, 255)"/> <path d="M380.3,292.7 L378.2,297.6 L376.1,302.6 L374.0,307.6 " stroke="rgb( 0, 99, 255)"/> <path d="M436.4,193.0 L434.3,198.0 L432.2,202.9 " stroke="rgb( 0, 0, 160)"/> <path d="M432.2,202.9 L430.1,207.9 L428.0,212.8 " stroke="rgb( 0, 0, 176)"/> <path d="M428.0,212.8 L425.9,217.8 L423.8,222.8 " stroke="rgb( 0, 0, 192)"/> <path d="M423.8,222.8 L421.7,227.8 L419.6,232.8 " stroke="rgb( 0, 0, 208)"/> <path d="M419.6,232.8 L417.5,237.8 L415.4,242.8 L413.3,247.7 " stroke="rgb( 0, 0, 225)"/> <path d="M413.3,247.7 L411.2,252.7 L409.1,257.7 " stroke="rgb( 0, 0, 241)"/> <path d="M409.1,257.7 L407.0,262.7 L404.9,267.7 " stroke="rgb( 0, 2, 255)"/> <path d="M404.9,267.7 L402.8,272.7 L400.6,277.6 " stroke="rgb( 0, 18, 255)"/> <path d="M400.6,277.6 L398.5,282.6 L396.4,287.6 L394.3,292.6 " stroke="rgb( 0, 34, 255)"/> <path d="M394.3,292.6 L392.2,297.6 L390.1,302.6 " stroke="rgb( 0, 51, 255)"/> <path d="M390.1,302.6 L388.0,307.6 L385.9,312.5 " stroke="rgb( 0, 67, 255)"/> <path d="M448.3,197.9 L446.2,202.8 L444.1,207.8 " stroke="rgb( 0, 0, 128)"/> <path d="M444.1,207.8 L442.0,212.8 L439.9,217.8 " stroke="rgb( 0, 0, 144)"/> <path d="M439.9,217.8 L437.8,222.7 L435.7,227.7 L433.6,232.7 " stroke="rgb( 0, 0, 160)"/> <path d="M433.6,232.7 L431.5,237.7 L429.4,242.7 " stroke="rgb( 0, 0, 176)"/> <path d="M429.4,242.7 L427.3,247.7 L425.2,252.7 " stroke="rgb( 0, 0, 192)"/> <path d="M425.2,252.7 L423.1,257.6 L421.0,262.6 " stroke="rgb( 0, 0, 208)"/> <path d="M421.0,262.6 L418.9,267.6 L416.8,272.6 L414.7,277.6 " stroke="rgb( 0, 0, 225)"/> <path d="M414.7,277.6 L412.6,282.6 L410.5,287.5 " stroke="rgb( 0, 0, 241)"/> <path d="M410.5,287.5 L408.4,292.5 L406.3,297.5 " stroke="rgb( 0, 2, 255)"/> <path d="M406.3,297.5 L404.2,302.5 L402.1,307.5 " stroke="rgb( 0, 18, 255)"/> <path d="M402.1,307.5 L400.0,312.5 L397.9,317.5 " stroke="rgb( 0, 34, 255)"/> <path d="M162.1,79.9 L174.1,84.8 " stroke="rgb(255, 51, 0)"/> <path d="M174.1,84.8 L186.0,89.7 " stroke="rgb(255, 83, 0)"/> <path d="M186.0,89.7 L197.9,94.6 " stroke="rgb(255, 132, 0)"/> <path d="M197.9,94.6 L209.9,99.5 " stroke="rgb(255, 164, 0)"/> <path d="M209.9,99.5 L221.8,104.5 " stroke="rgb(255, 196, 0)"/> <path d="M221.8,104.5 L233.7,109.4 " stroke="rgb(255, 229, 0)"/> <path d="M233.7,109.4 L245.6,114.3 " stroke="rgb(233, 255, 22)"/> <path d="M245.6,114.3 L257.6,119.2 " stroke="rgb(200, 255, 55)"/> <path d="M257.6,119.2 L269.5,124.1 " stroke="rgb(168, 255, 87)"/> <path d="M269.5,124.1 L281.3,129.1 " stroke="rgb(136, 255, 119)"/> <path d="M281.3,129.1 L293.3,134.0 " stroke="rgb(103, 255, 152)"/> <path d="M293.3,134.0 L305.2,138.9 " stroke="rgb( 55, 255, 200)"/> <path d="M305.2,138.9 L317.1,143.8 " stroke="rgb( 22, 255, 233)"/> <path d="M317.1,143.8 L329.0,148.7 " stroke="rgb( 0, 245, 255)"/> <path d="M329.0,148.7 L341.0,153.6 " stroke="rgb( 0, 212, 255)"/> <path d="M341.0,153.6 L352.9,158.6 " stroke="rgb( 0, 164, 255)"/> <path d="M352.9,158.6 L364.8,163.5 " stroke="rgb( 0, 132, 255)"/> <path d="M364.8,163.5 L376.8,168.4 " stroke="rgb( 0, 99, 255)"/> <path d="M376.8,168.4 L388.7,173.3 " stroke="rgb( 0, 67, 255)"/> <path d="M388.7,173.3 L400.6,178.2 " stroke="rgb( 0, 34, 255)"/> <path d="M400.6,178.2 L412.5,183.2 " stroke="rgb( 0, 0, 241)"/> <path d="M412.5,183.2 L424.5,188.1 " stroke="rgb( 0, 0, 208)"/> <path d="M424.5,188.1 L436.4,193.0 " stroke="rgb( 0, 0, 176)"/> <path d="M436.4,193.0 L448.3,197.9 " stroke="rgb( 0, 0, 144)"/> <path d="M160.0,84.8 L172.0,89.8 " stroke="rgb(255, 51, 0)"/> <path d="M172.0,89.8 L183.9,94.7 " stroke="rgb(255, 83, 0)"/> <path d="M183.9,94.7 L195.8,99.6 " stroke="rgb(255, 115, 0)"/> <path d="M195.8,99.6 L207.8,104.5 " stroke="rgb(255, 148, 0)"/> <path d="M207.8,104.5 L219.7,109.4 " stroke="rgb(255, 196, 0)"/> <path d="M219.7,109.4 L231.6,114.4 " stroke="rgb(255, 229, 0)"/> <path d="M231.6,114.4 L243.5,119.3 " stroke="rgb(249, 255, 6)"/> <path d="M243.5,119.3 L255.5,124.2 " stroke="rgb(217, 255, 38)"/> <path d="M255.5,124.2 L267.4,129.1 " stroke="rgb(168, 255, 87)"/> <path d="M267.4,129.1 L279.3,134.0 " stroke="rgb(136, 255, 119)"/> <path d="M279.3,134.0 L291.2,139.0 " stroke="rgb(103, 255, 152)"/> <path d="M291.2,139.0 L303.1,143.9 " stroke="rgb( 71, 255, 184)"/> <path d="M303.1,143.9 L315.0,148.8 " stroke="rgb( 38, 255, 217)"/> <path d="M315.0,148.8 L326.9,153.7 " stroke="rgb( 0, 245, 255)"/> <path d="M326.9,153.7 L338.9,158.6 " stroke="rgb( 0, 212, 255)"/> <path d="M338.9,158.6 L350.8,163.6 " stroke="rgb( 0, 180, 255)"/> <path d="M350.8,163.6 L362.7,168.5 " stroke="rgb( 0, 148, 255)"/> <path d="M362.7,168.5 L374.7,173.4 " stroke="rgb( 0, 99, 255)"/> <path d="M374.7,173.4 L386.6,178.3 " stroke="rgb( 0, 67, 255)"/> <path d="M386.6,178.3 L398.5,183.2 " stroke="rgb( 0, 34, 255)"/> <path d="M398.5,183.2 L410.4,188.2 " stroke="rgb( 0, 2, 255)"/> <path d="M410.4,188.2 L422.4,193.1 " stroke="rgb( 0, 0, 225)"/> <path d="M422.4,193.1 L434.3,198.0 " stroke="rgb( 0, 0, 176)"/> <path d="M434.3,198.0 L446.2,202.8 " stroke="rgb( 0, 0, 144)"/> <path d="M157.9,89.8 L169.9,94.7 " stroke="rgb(255, 34, 0)"/> <path d="M169.9,94.7 L181.8,99.7 " stroke="rgb(255, 83, 0)"/> <path d="M181.8,99.7 L193.7,104.6 " stroke="rgb(255, 115, 0)"/> <path d="M193.7,104.6 L205.7,109.5 " stroke="rgb(255, 148, 0)"/> <path d="M205.7,109.5 L217.6,114.4 " stroke="rgb(255, 180, 0)"/> <path d="M217.6,114.4 L229.5,119.3 " stroke="rgb(255, 212, 0)"/> <path d="M229.5,119.3 L241.4,124.3 " stroke="rgb(249, 255, 6)"/> <path d="M241.4,124.3 L253.4,129.2 " stroke="rgb(217, 255, 38)"/> <path d="M253.4,129.2 L265.3,134.1 " stroke="rgb(184, 255, 71)"/> <path d="M265.3,134.1 L277.2,139.0 " stroke="rgb(152, 255, 103)"/> <path d="M277.2,139.0 L289.1,143.9 " stroke="rgb(103, 255, 152)"/> <path d="M289.1,143.9 L301.0,148.9 " stroke="rgb( 71, 255, 184)"/> <path d="M301.0,148.9 L312.9,153.8 " stroke="rgb( 38, 255, 217)"/> <path d="M312.9,153.8 L324.8,158.7 " stroke="rgb( 6, 255, 249)"/> <path d="M324.8,158.7 L336.8,163.6 " stroke="rgb( 0, 229, 255)"/> <path d="M336.8,163.6 L348.7,168.5 " stroke="rgb( 0, 180, 255)"/> <path d="M348.7,168.5 L360.6,173.5 " stroke="rgb( 0, 148, 255)"/> <path d="M360.6,173.5 L372.6,178.4 " stroke="rgb( 0, 115, 255)"/> <path d="M372.6,178.4 L384.5,183.3 " stroke="rgb( 0, 83, 255)"/> <path d="M384.5,183.3 L396.4,188.2 " stroke="rgb( 0, 34, 255)"/> <path d="M396.4,188.2 L408.3,193.1 " stroke="rgb( 0, 2, 255)"/> <path d="M408.3,193.1 L420.3,198.1 " stroke="rgb( 0, 0, 225)"/> <path d="M420.3,198.1 L432.2,202.9 " stroke="rgb( 0, 0, 192)"/> <path d="M432.2,202.9 L444.1,207.8 " stroke="rgb( 0, 0, 160)"/> <path d="M155.8,94.8 L167.8,99.7 " stroke="rgb(255, 34, 0)"/> <path d="M167.8,99.7 L179.7,104.7 " stroke="rgb(255, 67, 0)"/> <path d="M179.7,104.7 L191.6,109.6 " stroke="rgb(255, 99, 0)"/> <path d="M191.6,109.6 L203.6,114.5 " stroke="rgb(255, 148, 0)"/> <path d="M203.6,114.5 L215.5,119.4 " stroke="rgb(255, 180, 0)"/> <path d="M215.5,119.4 L227.4,124.3 " stroke="rgb(255, 212, 0)"/> <path d="M227.4,124.3 L239.3,129.2 " stroke="rgb(255, 245, 0)"/> <path d="M239.3,129.2 L251.3,134.2 " stroke="rgb(233, 255, 22)"/> <path d="M251.3,134.2 L263.2,139.1 " stroke="rgb(184, 255, 71)"/> <path d="M263.2,139.1 L275.1,144.0 " stroke="rgb(152, 255, 103)"/> <path d="M275.1,144.0 L287.0,148.9 " stroke="rgb(119, 255, 136)"/> <path d="M287.0,148.9 L298.9,153.8 " stroke="rgb( 87, 255, 168)"/> <path d="M298.9,153.8 L310.8,158.8 " stroke="rgb( 38, 255, 217)"/> <path d="M310.8,158.8 L322.7,163.7 " stroke="rgb( 6, 255, 249)"/> <path d="M322.7,163.7 L334.7,168.6 " stroke="rgb( 0, 229, 255)"/> <path d="M334.7,168.6 L346.6,173.5 " stroke="rgb( 0, 196, 255)"/> <path d="M346.6,173.5 L358.5,178.4 " stroke="rgb( 0, 164, 255)"/> <path d="M358.5,178.4 L370.5,183.4 " stroke="rgb( 0, 115, 255)"/> <path d="M370.5,183.4 L382.4,188.3 " stroke="rgb( 0, 83, 255)"/> <path d="M382.4,188.3 L394.3,193.2 " stroke="rgb( 0, 51, 255)"/> <path d="M394.3,193.2 L406.2,198.1 " stroke="rgb( 0, 18, 255)"/> <path d="M406.2,198.1 L418.2,202.9 " stroke="rgb( 0, 0, 225)"/> <path d="M418.2,202.9 L430.1,207.9 " stroke="rgb( 0, 0, 192)"/> <path d="M430.1,207.9 L442.0,212.8 " stroke="rgb( 0, 0, 160)"/> <path d="M153.7,99.8 L165.7,104.7 " stroke="rgb(255, 18, 0)"/> <path d="M165.7,104.7 L177.6,109.6 " stroke="rgb(255, 67, 0)"/> <path d="M177.6,109.6 L189.5,114.6 " stroke="rgb(255, 99, 0)"/> <path d="M189.5,114.6 L201.4,119.5 " stroke="rgb(255, 132, 0)"/> <path d="M201.4,119.5 L213.4,124.4 " stroke="rgb(255, 164, 0)"/> <path d="M213.4,124.4 L225.3,129.3 " stroke="rgb(255, 212, 0)"/> <path d="M225.3,129.3 L237.2,134.2 " stroke="rgb(255, 245, 0)"/> <path d="M237.2,134.2 L249.2,139.2 " stroke="rgb(233, 255, 22)"/> <path d="M249.2,139.2 L261.1,144.1 " stroke="rgb(200, 255, 55)"/> <path d="M261.1,144.1 L273.0,149.0 " stroke="rgb(168, 255, 87)"/> <path d="M273.0,149.0 L284.8,153.9 " stroke="rgb(119, 255, 136)"/> <path d="M284.8,153.9 L296.8,158.8 " stroke="rgb( 87, 255, 168)"/> <path d="M296.8,158.8 L308.7,163.7 " stroke="rgb( 55, 255, 200)"/> <path d="M308.7,163.7 L320.6,168.7 " stroke="rgb( 22, 255, 233)"/> <path d="M320.6,168.7 L332.6,173.6 " stroke="rgb( 0, 229, 255)"/> <path d="M332.6,173.6 L344.5,178.5 " stroke="rgb( 0, 196, 255)"/> <path d="M344.5,178.5 L356.4,183.4 " stroke="rgb( 0, 164, 255)"/> <path d="M356.4,183.4 L368.3,188.3 " stroke="rgb( 0, 132, 255)"/> <path d="M368.3,188.3 L380.3,193.3 " stroke="rgb( 0, 99, 255)"/> <path d="M380.3,193.3 L392.2,198.2 " stroke="rgb( 0, 51, 255)"/> <path d="M392.2,198.2 L404.1,203.0 " stroke="rgb( 0, 18, 255)"/> <path d="M404.1,203.0 L416.1,207.9 " stroke="rgb( 0, 0, 241)"/> <path d="M416.1,207.9 L428.0,212.8 " stroke="rgb( 0, 0, 208)"/> <path d="M428.0,212.8 L439.9,217.8 " stroke="rgb( 0, 0, 160)"/> <path d="M151.6,104.8 L163.6,109.7 " stroke="rgb(255, 18, 0)"/> <path d="M163.6,109.7 L175.5,114.6 " stroke="rgb(255, 51, 0)"/> <path d="M175.5,114.6 L187.4,119.5 " stroke="rgb(255, 83, 0)"/> <path d="M187.4,119.5 L199.3,124.5 " stroke="rgb(255, 132, 0)"/> <path d="M199.3,124.5 L211.3,129.4 " stroke="rgb(255, 164, 0)"/> <path d="M211.3,129.4 L223.2,134.3 " stroke="rgb(255, 196, 0)"/> <path d="M223.2,134.3 L235.1,139.2 " stroke="rgb(255, 229, 0)"/> <path d="M235.1,139.2 L247.1,144.1 " stroke="rgb(233, 255, 22)"/> <path d="M247.1,144.1 L259.0,149.1 " stroke="rgb(200, 255, 55)"/> <path d="M259.0,149.1 L270.9,154.0 " stroke="rgb(168, 255, 87)"/> <path d="M270.9,154.0 L282.7,158.9 " stroke="rgb(136, 255, 119)"/> <path d="M282.7,158.9 L294.7,163.8 " stroke="rgb(103, 255, 152)"/> <path d="M294.7,163.8 L306.6,168.7 " stroke="rgb( 55, 255, 200)"/> <path d="M306.6,168.7 L318.5,173.7 " stroke="rgb( 22, 255, 233)"/> <path d="M318.5,173.7 L330.5,178.6 " stroke="rgb( 0, 245, 255)"/> <path d="M330.5,178.6 L342.4,183.5 " stroke="rgb( 0, 212, 255)"/> <path d="M342.4,183.5 L354.3,188.4 " stroke="rgb( 0, 164, 255)"/> <path d="M354.3,188.4 L366.2,193.3 " stroke="rgb( 0, 132, 255)"/> <path d="M366.2,193.3 L378.2,198.3 " stroke="rgb( 0, 99, 255)"/> <path d="M378.2,198.3 L390.1,203.1 " stroke="rgb( 0, 67, 255)"/> <path d="M390.1,203.1 L402.0,208.0 " stroke="rgb( 0, 34, 255)"/> <path d="M402.0,208.0 L414.0,212.9 " stroke="rgb( 0, 0, 241)"/> <path d="M414.0,212.9 L425.9,217.8 " stroke="rgb( 0, 0, 208)"/> <path d="M425.9,217.8 L437.8,222.7 " stroke="rgb( 0, 0, 176)"/> <path d="M149.5,109.8 L161.5,114.7 " stroke="rgb(255, 18, 0)"/> <path d="M161.5,114.7 L173.4,119.6 " stroke="rgb(255, 51, 0)"/> <path d="M173.4,119.6 L185.3,124.5 " stroke="rgb(255, 83, 0)"/> <path d="M185.3,124.5 L197.2,129.4 " stroke="rgb(255, 115, 0)"/> <path d="M197.2,129.4 L209.2,134.4 " stroke="rgb(255, 148, 0)"/> <path d="M209.2,134.4 L221.1,139.3 " stroke="rgb(255, 196, 0)"/> <path d="M221.1,139.3 L233.0,144.2 " stroke="rgb(255, 229, 0)"/> <path d="M233.0,144.2 L245.0,149.1 " stroke="rgb(249, 255, 6)"/> <path d="M245.0,149.1 L256.9,154.0 " stroke="rgb(217, 255, 38)"/> <path d="M256.9,154.0 L268.8,159.0 " stroke="rgb(168, 255, 87)"/> <path d="M268.8,159.0 L280.6,163.9 " stroke="rgb(136, 255, 119)"/> <path d="M280.6,163.9 L292.6,168.8 " stroke="rgb(103, 255, 152)"/> <path d="M292.6,168.8 L304.5,173.7 " stroke="rgb( 71, 255, 184)"/> <path d="M304.5,173.7 L316.4,178.6 " stroke="rgb( 38, 255, 217)"/> <path d="M316.4,178.6 L328.4,183.6 " stroke="rgb( 0, 245, 255)"/> <path d="M328.4,183.6 L340.3,188.5 " stroke="rgb( 0, 212, 255)"/> <path d="M340.3,188.5 L352.2,193.4 " stroke="rgb( 0, 180, 255)"/> <path d="M352.2,193.4 L364.1,198.3 " stroke="rgb( 0, 148, 255)"/> <path d="M364.1,198.3 L376.1,203.1 " stroke="rgb( 0, 99, 255)"/> <path d="M376.1,203.1 L388.0,208.1 " stroke="rgb( 0, 67, 255)"/> <path d="M388.0,208.1 L399.9,213.0 " stroke="rgb( 0, 34, 255)"/> <path d="M399.9,213.0 L411.9,217.9 " stroke="rgb( 0, 2, 255)"/> <path d="M411.9,217.9 L423.8,222.8 " stroke="rgb( 0, 0, 225)"/> <path d="M423.8,222.8 L435.7,227.7 " stroke="rgb( 0, 0, 176)"/> <path d="M147.4,114.8 L159.4,119.7 " stroke="rgb(255, 2, 0)"/> <path d="M159.4,119.7 L171.3,124.6 " stroke="rgb(255, 34, 0)"/> <path d="M171.3,124.6 L183.2,129.5 " stroke="rgb(255, 83, 0)"/> <path d="M183.2,129.5 L195.1,134.4 " stroke="rgb(255, 115, 0)"/> <path d="M195.1,134.4 L207.1,139.3 " stroke="rgb(255, 148, 0)"/> <path d="M207.1,139.3 L219.0,144.3 " stroke="rgb(255, 180, 0)"/> <path d="M219.0,144.3 L230.9,149.2 " stroke="rgb(255, 212, 0)"/> <path d="M230.9,149.2 L242.9,154.1 " stroke="rgb(249, 255, 6)"/> <path d="M242.9,154.1 L254.8,159.0 " stroke="rgb(217, 255, 38)"/> <path d="M254.8,159.0 L266.7,163.9 " stroke="rgb(184, 255, 71)"/> <path d="M266.7,163.9 L278.6,168.9 " stroke="rgb(152, 255, 103)"/> <path d="M278.6,168.9 L290.5,173.8 " stroke="rgb(103, 255, 152)"/> <path d="M290.5,173.8 L302.4,178.7 " stroke="rgb( 71, 255, 184)"/> <path d="M302.4,178.7 L314.3,183.6 " stroke="rgb( 38, 255, 217)"/> <path d="M314.3,183.6 L326.3,188.5 " stroke="rgb( 6, 255, 249)"/> <path d="M326.3,188.5 L338.2,193.5 " stroke="rgb( 0, 229, 255)"/> <path d="M338.2,193.5 L350.1,198.4 " stroke="rgb( 0, 180, 255)"/> <path d="M350.1,198.4 L362.0,203.2 " stroke="rgb( 0, 148, 255)"/> <path d="M362.0,203.2 L374.0,208.1 " stroke="rgb( 0, 115, 255)"/> <path d="M374.0,208.1 L385.9,213.0 " stroke="rgb( 0, 83, 255)"/> <path d="M385.9,213.0 L397.8,218.0 " stroke="rgb( 0, 34, 255)"/> <path d="M397.8,218.0 L409.8,222.9 " stroke="rgb( 0, 2, 255)"/> <path d="M409.8,222.9 L421.7,227.8 " stroke="rgb( 0, 0, 225)"/> <path d="M421.7,227.8 L433.6,232.7 " stroke="rgb( 0, 0, 192)"/> <path d="M145.3,119.7 L157.2,124.7 " stroke="rgb(255, 2, 0)"/> <path d="M157.2,124.7 L169.2,129.6 " stroke="rgb(255, 34, 0)"/> <path d="M169.2,129.6 L181.1,134.5 " stroke="rgb(255, 67, 0)"/> <path d="M181.1,134.5 L193.0,139.4 " stroke="rgb(255, 99, 0)"/> <path d="M193.0,139.4 L205.0,144.3 " stroke="rgb(255, 148, 0)"/> <path d="M205.0,144.3 L216.9,149.3 " stroke="rgb(255, 180, 0)"/> <path d="M216.9,149.3 L228.8,154.2 " stroke="rgb(255, 212, 0)"/> <path d="M228.8,154.2 L240.7,159.1 " stroke="rgb(255, 245, 0)"/> <path d="M240.7,159.1 L252.7,164.0 " stroke="rgb(233, 255, 22)"/> <path d="M252.7,164.0 L264.6,168.9 " stroke="rgb(184, 255, 71)"/> <path d="M264.6,168.9 L276.5,173.8 " stroke="rgb(152, 255, 103)"/> <path d="M276.5,173.8 L288.4,178.8 " stroke="rgb(119, 255, 136)"/> <path d="M288.4,178.8 L300.3,183.7 " stroke="rgb( 87, 255, 168)"/> <path d="M300.3,183.7 L312.2,188.6 " stroke="rgb( 38, 255, 217)"/> <path d="M312.2,188.6 L324.1,193.5 " stroke="rgb( 6, 255, 249)"/> <path d="M324.1,193.5 L336.1,198.4 " stroke="rgb( 0, 229, 255)"/> <path d="M336.1,198.4 L348.0,203.3 " stroke="rgb( 0, 196, 255)"/> <path d="M348.0,203.3 L359.9,208.2 " stroke="rgb( 0, 164, 255)"/> <path d="M359.9,208.2 L371.9,213.1 " stroke="rgb( 0, 115, 255)"/> <path d="M371.9,213.1 L383.8,218.0 " stroke="rgb( 0, 83, 255)"/> <path d="M383.8,218.0 L395.7,222.9 " stroke="rgb( 0, 51, 255)"/> <path d="M395.7,222.9 L407.6,227.9 " stroke="rgb( 0, 18, 255)"/> <path d="M407.6,227.9 L419.6,232.8 " stroke="rgb( 0, 0, 225)"/> <path d="M419.6,232.8 L431.5,237.7 " stroke="rgb( 0, 0, 192)"/> <path d="M143.2,124.7 L155.1,129.6 " stroke="rgb(241, 0, 0)"/> <path d="M155.1,129.6 L167.1,134.6 " stroke="rgb(255, 18, 0)"/> <path d="M167.1,134.6 L179.0,139.5 " stroke="rgb(255, 67, 0)"/> <path d="M179.0,139.5 L190.9,144.4 " stroke="rgb(255, 99, 0)"/> <path d="M190.9,144.4 L202.9,149.3 " stroke="rgb(255, 132, 0)"/> <path d="M202.9,149.3 L214.8,154.2 " stroke="rgb(255, 164, 0)"/> <path d="M214.8,154.2 L226.7,159.2 " stroke="rgb(255, 212, 0)"/> <path d="M226.7,159.2 L238.6,164.1 " stroke="rgb(255, 245, 0)"/> <path d="M238.6,164.1 L250.6,169.0 " stroke="rgb(233, 255, 22)"/> <path d="M250.6,169.0 L262.5,173.9 " stroke="rgb(200, 255, 55)"/> <path d="M262.5,173.9 L274.4,178.8 " stroke="rgb(168, 255, 87)"/> <path d="M274.4,178.8 L286.3,183.8 " stroke="rgb(119, 255, 136)"/> <path d="M286.3,183.8 L298.2,188.7 " stroke="rgb( 87, 255, 168)"/> <path d="M298.2,188.7 L310.1,193.6 " stroke="rgb( 55, 255, 200)"/> <path d="M310.1,193.6 L322.0,198.5 " stroke="rgb( 22, 255, 233)"/> <path d="M322.0,198.5 L334.0,203.3 " stroke="rgb( 0, 229, 255)"/> <path d="M334.0,203.3 L345.9,208.3 " stroke="rgb( 0, 196, 255)"/> <path d="M345.9,208.3 L357.8,213.2 " stroke="rgb( 0, 164, 255)"/> <path d="M357.8,213.2 L369.8,218.1 " stroke="rgb( 0, 132, 255)"/> <path d="M369.8,218.1 L381.7,223.0 " stroke="rgb( 0, 99, 255)"/> <path d="M381.7,223.0 L393.6,227.9 " stroke="rgb( 0, 51, 255)"/> <path d="M393.6,227.9 L405.5,232.8 " stroke="rgb( 0, 18, 255)"/> <path d="M405.5,232.8 L417.5,237.8 " stroke="rgb( 0, 0, 241)"/> <path d="M417.5,237.8 L429.4,242.7 " stroke="rgb( 0, 0, 208)"/> <path d="M141.1,129.7 L153.0,134.6 " stroke="rgb(241, 0, 0)"/> <path d="M153.0,134.6 L165.0,139.5 " stroke="rgb(255, 18, 0)"/> <path d="M165.0,139.5 L176.9,144.5 " stroke="rgb(255, 51, 0)"/> <path d="M176.9,144.5 L188.8,149.4 " stroke="rgb(255, 83, 0)"/> <path d="M188.8,149.4 L200.8,154.3 " stroke="rgb(255, 132, 0)"/> <path d="M200.8,154.3 L212.7,159.2 " stroke="rgb(255, 164, 0)"/> <path d="M212.7,159.2 L224.6,164.1 " stroke="rgb(255, 196, 0)"/> <path d="M224.6,164.1 L236.5,169.1 " stroke="rgb(255, 229, 0)"/> <path d="M236.5,169.1 L248.5,174.0 " stroke="rgb(233, 255, 22)"/> <path d="M248.5,174.0 L260.4,178.9 " stroke="rgb(200, 255, 55)"/> <path d="M260.4,178.9 L272.3,183.8 " stroke="rgb(168, 255, 87)"/> <path d="M272.3,183.8 L284.2,188.7 " stroke="rgb(136, 255, 119)"/> <path d="M284.2,188.7 L296.1,193.7 " stroke="rgb(103, 255, 152)"/> <path d="M296.1,193.7 L308.0,198.6 " stroke="rgb( 55, 255, 200)"/> <path d="M308.0,198.6 L319.9,203.4 " stroke="rgb( 22, 255, 233)"/> <path d="M319.9,203.4 L331.9,208.3 " stroke="rgb( 0, 245, 255)"/> <path d="M331.9,208.3 L343.8,213.2 " stroke="rgb( 0, 212, 255)"/> <path d="M343.8,213.2 L355.7,218.2 " stroke="rgb( 0, 164, 255)"/> <path d="M355.7,218.2 L367.7,223.1 " stroke="rgb( 0, 132, 255)"/> <path d="M367.7,223.1 L379.6,228.0 " stroke="rgb( 0, 99, 255)"/> <path d="M379.6,228.0 L391.5,232.9 " stroke="rgb( 0, 67, 255)"/> <path d="M391.5,232.9 L403.4,237.8 " stroke="rgb( 0, 34, 255)"/> <path d="M403.4,237.8 L415.4,242.8 " stroke="rgb( 0, 0, 241)"/> <path d="M415.4,242.8 L427.3,247.7 " stroke="rgb( 0, 0, 208)"/> <path d="M139.0,134.7 L150.9,139.6 " stroke="rgb(225, 0, 0)"/> <path d="M150.9,139.6 L162.9,144.5 " stroke="rgb(255, 18, 0)"/> <path d="M162.9,144.5 L174.8,149.4 " stroke="rgb(255, 51, 0)"/> <path d="M174.8,149.4 L186.7,154.4 " stroke="rgb(255, 83, 0)"/> <path d="M186.7,154.4 L198.7,159.3 " stroke="rgb(255, 115, 0)"/> <path d="M198.7,159.3 L210.6,164.2 " stroke="rgb(255, 148, 0)"/> <path d="M210.6,164.2 L222.5,169.1 " stroke="rgb(255, 196, 0)"/> <path d="M222.5,169.1 L234.4,174.0 " stroke="rgb(255, 229, 0)"/> <path d="M234.4,174.0 L246.4,179.0 " stroke="rgb(249, 255, 6)"/> <path d="M246.4,179.0 L258.3,183.9 " stroke="rgb(217, 255, 38)"/> <path d="M258.3,183.9 L270.2,188.8 " stroke="rgb(168, 255, 87)"/> <path d="M270.2,188.8 L282.1,193.7 " stroke="rgb(136, 255, 119)"/> <path d="M282.1,193.7 L294.0,198.6 " stroke="rgb(103, 255, 152)"/> <path d="M294.0,198.6 L305.9,203.5 " stroke="rgb( 71, 255, 184)"/> <path d="M305.9,203.5 L317.8,208.4 " stroke="rgb( 38, 255, 217)"/> <path d="M317.8,208.4 L329.8,213.3 " stroke="rgb( 0, 245, 255)"/> <path d="M329.8,213.3 L341.7,218.2 " stroke="rgb( 0, 212, 255)"/> <path d="M341.7,218.2 L353.6,223.1 " stroke="rgb( 0, 180, 255)"/> <path d="M353.6,223.1 L365.6,228.1 " stroke="rgb( 0, 148, 255)"/> <path d="M365.6,228.1 L377.5,233.0 " stroke="rgb( 0, 99, 255)"/> <path d="M377.5,233.0 L389.4,237.9 " stroke="rgb( 0, 67, 255)"/> <path d="M389.4,237.9 L401.3,242.8 " stroke="rgb( 0, 34, 255)"/> <path d="M401.3,242.8 L413.3,247.7 " stroke="rgb( 0, 2, 255)"/> <path d="M413.3,247.7 L425.2,252.7 " stroke="rgb( 0, 0, 225)"/> <path d="M136.9,139.7 L148.8,144.6 " stroke="rgb(225, 0, 0)"/> <path d="M148.8,144.6 L160.8,149.5 " stroke="rgb(255, 2, 0)"/> <path d="M160.8,149.5 L172.7,154.4 " stroke="rgb(255, 34, 0)"/> <path d="M172.7,154.4 L184.6,159.4 " stroke="rgb(255, 83, 0)"/> <path d="M184.6,159.4 L196.6,164.3 " stroke="rgb(255, 115, 0)"/> <path d="M196.6,164.3 L208.5,169.2 " stroke="rgb(255, 148, 0)"/> <path d="M208.5,169.2 L220.4,174.1 " stroke="rgb(255, 180, 0)"/> <path d="M220.4,174.1 L232.3,179.0 " stroke="rgb(255, 212, 0)"/> <path d="M232.3,179.0 L244.3,184.0 " stroke="rgb(249, 255, 6)"/> <path d="M244.3,184.0 L256.2,188.9 " stroke="rgb(217, 255, 38)"/> <path d="M256.2,188.9 L268.1,193.8 " stroke="rgb(184, 255, 71)"/> <path d="M268.1,193.8 L280.0,198.7 " stroke="rgb(152, 255, 103)"/> <path d="M280.0,198.7 L291.9,203.5 " stroke="rgb(103, 255, 152)"/> <path d="M291.9,203.5 L303.8,208.4 " stroke="rgb( 71, 255, 184)"/> <path d="M303.8,208.4 L315.7,213.4 " stroke="rgb( 38, 255, 217)"/> <path d="M315.7,213.4 L327.7,218.3 " stroke="rgb( 6, 255, 249)"/> <path d="M327.7,218.3 L339.6,223.2 " stroke="rgb( 0, 229, 255)"/> <path d="M339.6,223.2 L351.5,228.1 " stroke="rgb( 0, 180, 255)"/> <path d="M351.5,228.1 L363.4,233.0 " stroke="rgb( 0, 148, 255)"/> <path d="M363.4,233.0 L375.4,238.0 " stroke="rgb( 0, 115, 255)"/> <path d="M375.4,238.0 L387.3,242.9 " stroke="rgb( 0, 83, 255)"/> <path d="M387.3,242.9 L399.2,247.8 " stroke="rgb( 0, 34, 255)"/> <path d="M399.2,247.8 L411.2,252.7 " stroke="rgb( 0, 2, 255)"/> <path d="M411.2,252.7 L423.1,257.6 " stroke="rgb( 0, 0, 225)"/> <path d="M134.8,144.7 L146.7,149.6 " stroke="rgb(208, 0, 0)"/> <path d="M146.7,149.6 L158.7,154.5 " stroke="rgb(255, 2, 0)"/> <path d="M158.7,154.5 L170.6,159.4 " stroke="rgb(255, 34, 0)"/> <path d="M170.6,159.4 L182.5,164.3 " stroke="rgb(255, 67, 0)"/> <path d="M182.5,164.3 L194.4,169.3 " stroke="rgb(255, 99, 0)"/> <path d="M194.4,169.3 L206.4,174.2 " stroke="rgb(255, 148, 0)"/> <path d="M206.4,174.2 L218.3,179.1 " stroke="rgb(255, 180, 0)"/> <path d="M218.3,179.1 L230.2,184.0 " stroke="rgb(255, 212, 0)"/> <path d="M230.2,184.0 L242.2,188.9 " stroke="rgb(255, 245, 0)"/> <path d="M242.2,188.9 L254.1,193.9 " stroke="rgb(233, 255, 22)"/> <path d="M254.1,193.9 L266.0,198.8 " stroke="rgb(184, 255, 71)"/> <path d="M266.0,198.8 L277.9,203.6 " stroke="rgb(152, 255, 103)"/> <path d="M277.9,203.6 L289.8,208.5 " stroke="rgb(119, 255, 136)"/> <path d="M289.8,208.5 L301.7,213.4 " stroke="rgb( 87, 255, 168)"/> <path d="M301.7,213.4 L313.6,218.4 " stroke="rgb( 38, 255, 217)"/> <path d="M313.6,218.4 L325.6,223.3 " stroke="rgb( 6, 255, 249)"/> <path d="M325.6,223.3 L337.5,228.2 " stroke="rgb( 0, 229, 255)"/> <path d="M337.5,228.2 L349.4,233.1 " stroke="rgb( 0, 196, 255)"/> <path d="M349.4,233.1 L361.3,238.0 " stroke="rgb( 0, 164, 255)"/> <path d="M361.3,238.0 L373.3,242.9 " stroke="rgb( 0, 115, 255)"/> <path d="M373.3,242.9 L385.2,247.9 " stroke="rgb( 0, 83, 255)"/> <path d="M385.2,247.9 L397.1,252.8 " stroke="rgb( 0, 51, 255)"/> <path d="M397.1,252.8 L409.1,257.7 " stroke="rgb( 0, 18, 255)"/> <path d="M409.1,257.7 L421.0,262.6 " stroke="rgb( 0, 0, 225)"/> <path d="M132.7,149.6 L144.6,154.6 " stroke="rgb(208, 0, 0)"/> <path d="M144.6,154.6 L156.6,159.5 " stroke="rgb(241, 0, 0)"/> <path d="M156.6,159.5 L168.5,164.4 " stroke="rgb(255, 18, 0)"/> <path d="M168.5,164.4 L180.4,169.3 " stroke="rgb(255, 67, 0)"/> <path d="M180.4,169.3 L192.3,174.2 " stroke="rgb(255, 99, 0)"/> <path d="M192.3,174.2 L204.3,179.2 " stroke="rgb(255, 132, 0)"/> <path d="M204.3,179.2 L216.2,184.1 " stroke="rgb(255, 164, 0)"/> <path d="M216.2,184.1 L228.1,189.0 " stroke="rgb(255, 212, 0)"/> <path d="M228.1,189.0 L240.1,193.9 " stroke="rgb(255, 245, 0)"/> <path d="M240.1,193.9 L252.0,198.8 " stroke="rgb(233, 255, 22)"/> <path d="M252.0,198.8 L263.9,203.7 " stroke="rgb(200, 255, 55)"/> <path d="M263.9,203.7 L275.8,208.6 " stroke="rgb(168, 255, 87)"/> <path d="M275.8,208.6 L287.7,213.5 " stroke="rgb(119, 255, 136)"/> <path d="M287.7,213.5 L299.6,218.4 " stroke="rgb( 87, 255, 168)"/> <path d="M299.6,218.4 L311.5,223.3 " stroke="rgb( 55, 255, 200)"/> <path d="M311.5,223.3 L323.5,228.3 " stroke="rgb( 22, 255, 233)"/> <path d="M323.5,228.3 L335.4,233.2 " stroke="rgb( 0, 229, 255)"/> <path d="M335.4,233.2 L347.3,238.1 " stroke="rgb( 0, 196, 255)"/> <path d="M347.3,238.1 L359.2,243.0 " stroke="rgb( 0, 164, 255)"/> <path d="M359.2,243.0 L371.2,247.9 " stroke="rgb( 0, 132, 255)"/> <path d="M371.2,247.9 L383.1,252.9 " stroke="rgb( 0, 99, 255)"/> <path d="M383.1,252.9 L395.0,257.8 " stroke="rgb( 0, 51, 255)"/> <path d="M395.0,257.8 L407.0,262.7 " stroke="rgb( 0, 18, 255)"/> <path d="M407.0,262.7 L418.9,267.6 " stroke="rgb( 0, 0, 241)"/> <path d="M130.6,154.6 L142.5,159.5 " stroke="rgb(208, 0, 0)"/> <path d="M142.5,159.5 L154.5,164.5 " stroke="rgb(241, 0, 0)"/> <path d="M154.5,164.5 L166.4,169.4 " stroke="rgb(255, 18, 0)"/> <path d="M166.4,169.4 L178.3,174.3 " stroke="rgb(255, 51, 0)"/> <path d="M178.3,174.3 L190.2,179.2 " stroke="rgb(255, 83, 0)"/> <path d="M190.2,179.2 L202.2,184.1 " stroke="rgb(255, 132, 0)"/> <path d="M202.2,184.1 L214.1,189.1 " stroke="rgb(255, 164, 0)"/> <path d="M214.1,189.1 L226.0,194.0 " stroke="rgb(255, 196, 0)"/> <path d="M226.0,194.0 L238.0,198.9 " stroke="rgb(255, 229, 0)"/> <path d="M238.0,198.9 L249.9,203.7 " stroke="rgb(233, 255, 22)"/> <path d="M249.9,203.7 L261.8,208.6 " stroke="rgb(200, 255, 55)"/> <path d="M261.8,208.6 L273.7,213.6 " stroke="rgb(168, 255, 87)"/> <path d="M273.7,213.6 L285.6,218.5 " stroke="rgb(136, 255, 119)"/> <path d="M285.6,218.5 L297.5,223.4 " stroke="rgb(103, 255, 152)"/> <path d="M297.5,223.4 L309.4,228.3 " stroke="rgb( 55, 255, 200)"/> <path d="M309.4,228.3 L321.4,233.2 " stroke="rgb( 22, 255, 233)"/> <path d="M321.4,233.2 L333.3,238.2 " stroke="rgb( 0, 245, 255)"/> <path d="M333.3,238.2 L345.2,243.1 " stroke="rgb( 0, 212, 255)"/> <path d="M345.2,243.1 L357.1,248.0 " stroke="rgb( 0, 164, 255)"/> <path d="M357.1,248.0 L369.1,252.9 " stroke="rgb( 0, 132, 255)"/> <path d="M369.1,252.9 L381.0,257.8 " stroke="rgb( 0, 99, 255)"/> <path d="M381.0,257.8 L392.9,262.8 " stroke="rgb( 0, 67, 255)"/> <path d="M392.9,262.8 L404.9,267.7 " stroke="rgb( 0, 34, 255)"/> <path d="M404.9,267.7 L416.8,272.6 " stroke="rgb( 0, 0, 241)"/> <path d="M128.5,159.6 L140.4,164.5 " stroke="rgb(192, 0, 0)"/> <path d="M140.4,164.5 L152.4,169.5 " stroke="rgb(225, 0, 0)"/> <path d="M152.4,169.5 L164.3,174.4 " stroke="rgb(255, 18, 0)"/> <path d="M164.3,174.4 L176.2,179.3 " stroke="rgb(255, 51, 0)"/> <path d="M176.2,179.3 L188.1,184.2 " stroke="rgb(255, 83, 0)"/> <path d="M188.1,184.2 L200.1,189.1 " stroke="rgb(255, 115, 0)"/> <path d="M200.1,189.1 L212.0,194.1 " stroke="rgb(255, 148, 0)"/> <path d="M212.0,194.1 L223.9,199.0 " stroke="rgb(255, 196, 0)"/> <path d="M223.9,199.0 L235.9,203.8 " stroke="rgb(255, 229, 0)"/> <path d="M235.9,203.8 L247.8,208.7 " stroke="rgb(249, 255, 6)"/> <path d="M247.8,208.7 L259.7,213.6 " stroke="rgb(217, 255, 38)"/> <path d="M259.7,213.6 L271.6,218.5 " stroke="rgb(168, 255, 87)"/> <path d="M271.6,218.5 L283.5,223.5 " stroke="rgb(136, 255, 119)"/> <path d="M283.5,223.5 L295.4,228.4 " stroke="rgb(103, 255, 152)"/> <path d="M295.4,228.4 L307.3,233.3 " stroke="rgb( 71, 255, 184)"/> <path d="M307.3,233.3 L319.3,238.2 " stroke="rgb( 38, 255, 217)"/> <path d="M319.3,238.2 L331.2,243.1 " stroke="rgb( 0, 245, 255)"/> <path d="M331.2,243.1 L343.1,248.1 " stroke="rgb( 0, 212, 255)"/> <path d="M343.1,248.1 L355.0,253.0 " stroke="rgb( 0, 180, 255)"/> <path d="M355.0,253.0 L367.0,257.9 " stroke="rgb( 0, 148, 255)"/> <path d="M367.0,257.9 L378.9,262.8 " stroke="rgb( 0, 99, 255)"/> <path d="M378.9,262.8 L390.8,267.7 " stroke="rgb( 0, 67, 255)"/> <path d="M390.8,267.7 L402.8,272.7 " stroke="rgb( 0, 34, 255)"/> <path d="M402.8,272.7 L414.7,277.6 " stroke="rgb( 0, 2, 255)"/> <path d="M126.4,164.6 L138.3,169.5 " stroke="rgb(192, 0, 0)"/> <path d="M138.3,169.5 L150.2,174.4 " stroke="rgb(225, 0, 0)"/> <path d="M150.2,174.4 L162.2,179.4 " stroke="rgb(255, 2, 0)"/> <path d="M162.2,179.4 L174.1,184.3 " stroke="rgb(255, 34, 0)"/> <path d="M174.1,184.3 L186.0,189.2 " stroke="rgb(255, 83, 0)"/> <path d="M186.0,189.2 L198.0,194.1 " stroke="rgb(255, 115, 0)"/> <path d="M198.0,194.1 L209.9,199.0 " stroke="rgb(255, 148, 0)"/> <path d="M209.9,199.0 L221.8,203.9 " stroke="rgb(255, 180, 0)"/> <path d="M221.8,203.9 L233.7,208.8 " stroke="rgb(255, 212, 0)"/> <path d="M233.7,208.8 L245.7,213.7 " stroke="rgb(249, 255, 6)"/> <path d="M245.7,213.7 L257.6,218.6 " stroke="rgb(217, 255, 38)"/> <path d="M257.6,218.6 L269.5,223.5 " stroke="rgb(184, 255, 71)"/> <path d="M269.5,223.5 L281.4,228.5 " stroke="rgb(152, 255, 103)"/> <path d="M281.4,228.5 L293.3,233.4 " stroke="rgb(103, 255, 152)"/> <path d="M293.3,233.4 L305.2,238.3 " stroke="rgb( 71, 255, 184)"/> <path d="M305.2,238.3 L317.1,243.2 " stroke="rgb( 38, 255, 217)"/> <path d="M317.1,243.2 L329.1,248.1 " stroke="rgb( 6, 255, 249)"/> <path d="M329.1,248.1 L341.0,253.0 " stroke="rgb( 0, 229, 255)"/> <path d="M341.0,253.0 L352.9,258.0 " stroke="rgb( 0, 180, 255)"/> <path d="M352.9,258.0 L364.9,262.9 " stroke="rgb( 0, 148, 255)"/> <path d="M364.9,262.9 L376.8,267.8 " stroke="rgb( 0, 115, 255)"/> <path d="M376.8,267.8 L388.7,272.7 " stroke="rgb( 0, 83, 255)"/> <path d="M388.7,272.7 L400.6,277.6 " stroke="rgb( 0, 34, 255)"/> <path d="M400.6,277.6 L412.6,282.6 " stroke="rgb( 0, 2, 255)"/> <path d="M124.3,169.6 L136.2,174.5 " stroke="rgb(176, 0, 0)"/> <path d="M136.2,174.5 L148.1,179.4 " stroke="rgb(208, 0, 0)"/> <path d="M148.1,179.4 L160.1,184.3 " stroke="rgb(255, 2, 0)"/> <path d="M160.1,184.3 L172.0,189.3 " stroke="rgb(255, 34, 0)"/> <path d="M172.0,189.3 L183.9,194.2 " stroke="rgb(255, 67, 0)"/> <path d="M183.9,194.2 L195.9,199.1 " stroke="rgb(255, 99, 0)"/> <path d="M195.9,199.1 L207.8,203.9 " stroke="rgb(255, 148, 0)"/> <path d="M207.8,203.9 L219.7,208.8 " stroke="rgb(255, 180, 0)"/> <path d="M219.7,208.8 L231.6,213.8 " stroke="rgb(255, 212, 0)"/> <path d="M231.6,213.8 L243.6,218.7 " stroke="rgb(255, 245, 0)"/> <path d="M243.6,218.7 L255.5,223.6 " stroke="rgb(233, 255, 22)"/> <path d="M255.5,223.6 L267.4,228.5 " stroke="rgb(184, 255, 71)"/> <path d="M267.4,228.5 L279.4,233.4 " stroke="rgb(152, 255, 103)"/> <path d="M279.4,233.4 L291.2,238.4 " stroke="rgb(119, 255, 136)"/> <path d="M291.2,238.4 L303.1,243.3 " stroke="rgb( 87, 255, 168)"/> <path d="M303.1,243.3 L315.0,248.2 " stroke="rgb( 38, 255, 217)"/> <path d="M315.0,248.2 L327.0,253.1 " stroke="rgb( 6, 255, 249)"/> <path d="M327.0,253.1 L338.9,258.0 " stroke="rgb( 0, 229, 255)"/> <path d="M338.9,258.0 L350.8,263.0 " stroke="rgb( 0, 196, 255)"/> <path d="M350.8,263.0 L362.8,267.9 " stroke="rgb( 0, 164, 255)"/> <path d="M362.8,267.9 L374.7,272.8 " stroke="rgb( 0, 115, 255)"/> <path d="M374.7,272.8 L386.6,277.7 " stroke="rgb( 0, 83, 255)"/> <path d="M386.6,277.7 L398.5,282.6 " stroke="rgb( 0, 51, 255)"/> <path d="M398.5,282.6 L410.5,287.5 " stroke="rgb( 0, 18, 255)"/> <path d="M122.2,174.6 L134.1,179.5 " stroke="rgb(176, 0, 0)"/> <path d="M134.1,179.5 L146.0,184.4 " stroke="rgb(208, 0, 0)"/> <path d="M146.0,184.4 L158.0,189.3 " stroke="rgb(241, 0, 0)"/> <path d="M158.0,189.3 L169.9,194.2 " stroke="rgb(255, 18, 0)"/> <path d="M169.9,194.2 L181.8,199.2 " stroke="rgb(255, 67, 0)"/> <path d="M181.8,199.2 L193.8,204.0 " stroke="rgb(255, 99, 0)"/> <path d="M193.8,204.0 L205.7,208.9 " stroke="rgb(255, 132, 0)"/> <path d="M205.7,208.9 L217.6,213.8 " stroke="rgb(255, 164, 0)"/> <path d="M217.6,213.8 L229.5,218.7 " stroke="rgb(255, 212, 0)"/> <path d="M229.5,218.7 L241.5,223.7 " stroke="rgb(255, 245, 0)"/> <path d="M241.5,223.7 L253.4,228.6 " stroke="rgb(233, 255, 22)"/> <path d="M253.4,228.6 L265.3,233.5 " stroke="rgb(200, 255, 55)"/> <path d="M265.3,233.5 L277.3,238.4 " stroke="rgb(168, 255, 87)"/> <path d="M277.3,238.4 L289.1,243.3 " stroke="rgb(119, 255, 136)"/> <path d="M289.1,243.3 L301.0,248.3 " stroke="rgb( 87, 255, 168)"/> <path d="M301.0,248.3 L312.9,253.2 " stroke="rgb( 55, 255, 200)"/> <path d="M312.9,253.2 L324.9,258.1 " stroke="rgb( 22, 255, 233)"/> <path d="M324.9,258.1 L336.8,263.0 " stroke="rgb( 0, 229, 255)"/> <path d="M336.8,263.0 L348.7,267.9 " stroke="rgb( 0, 196, 255)"/> <path d="M348.7,267.9 L360.7,272.9 " stroke="rgb( 0, 164, 255)"/> <path d="M360.7,272.9 L372.6,277.8 " stroke="rgb( 0, 132, 255)"/> <path d="M372.6,277.8 L384.5,282.7 " stroke="rgb( 0, 99, 255)"/> <path d="M384.5,282.7 L396.4,287.6 " stroke="rgb( 0, 51, 255)"/> <path d="M396.4,287.6 L408.4,292.5 " stroke="rgb( 0, 18, 255)"/> <path d="M120.1,179.6 L132.0,184.5 " stroke="rgb(160, 0, 0)"/> <path d="M132.0,184.5 L143.9,189.4 " stroke="rgb(208, 0, 0)"/> <path d="M143.9,189.4 L155.9,194.3 " stroke="rgb(241, 0, 0)"/> <path d="M155.9,194.3 L167.8,199.2 " stroke="rgb(255, 18, 0)"/> <path d="M167.8,199.2 L179.7,204.1 " stroke="rgb(255, 51, 0)"/> <path d="M179.7,204.1 L191.7,209.0 " stroke="rgb(255, 83, 0)"/> <path d="M191.7,209.0 L203.6,213.9 " stroke="rgb(255, 132, 0)"/> <path d="M203.6,213.9 L215.5,218.8 " stroke="rgb(255, 164, 0)"/> <path d="M215.5,218.8 L227.4,223.7 " stroke="rgb(255, 196, 0)"/> <path d="M227.4,223.7 L239.4,228.6 " stroke="rgb(255, 229, 0)"/> <path d="M239.4,228.6 L251.3,233.6 " stroke="rgb(233, 255, 22)"/> <path d="M251.3,233.6 L263.2,238.5 " stroke="rgb(200, 255, 55)"/> <path d="M263.2,238.5 L275.2,243.4 " stroke="rgb(168, 255, 87)"/> <path d="M275.2,243.4 L287.0,248.3 " stroke="rgb(136, 255, 119)"/> <path d="M287.0,248.3 L298.9,253.2 " stroke="rgb(103, 255, 152)"/> <path d="M298.9,253.2 L310.8,258.2 " stroke="rgb( 55, 255, 200)"/> <path d="M310.8,258.2 L322.8,263.1 " stroke="rgb( 22, 255, 233)"/> <path d="M322.8,263.1 L334.7,268.0 " stroke="rgb( 0, 245, 255)"/> <path d="M334.7,268.0 L346.6,272.9 " stroke="rgb( 0, 212, 255)"/> <path d="M346.6,272.9 L358.6,277.8 " stroke="rgb( 0, 164, 255)"/> <path d="M358.6,277.8 L370.5,282.8 " stroke="rgb( 0, 132, 255)"/> <path d="M370.5,282.8 L382.4,287.7 " stroke="rgb( 0, 99, 255)"/> <path d="M382.4,287.7 L394.3,292.6 " stroke="rgb( 0, 67, 255)"/> <path d="M394.3,292.6 L406.3,297.5 " stroke="rgb( 0, 34, 255)"/> <path d="M118.0,184.5 L129.9,189.5 " stroke="rgb(160, 0, 0)"/> <path d="M129.9,189.5 L141.8,194.4 " stroke="rgb(192, 0, 0)"/> <path d="M141.8,194.4 L153.8,199.3 " stroke="rgb(225, 0, 0)"/> <path d="M153.8,199.3 L165.7,204.1 " stroke="rgb(255, 18, 0)"/> <path d="M165.7,204.1 L177.6,209.0 " stroke="rgb(255, 51, 0)"/> <path d="M177.6,209.0 L189.5,214.0 " stroke="rgb(255, 83, 0)"/> <path d="M189.5,214.0 L201.5,218.9 " stroke="rgb(255, 115, 0)"/> <path d="M201.5,218.9 L213.4,223.8 " stroke="rgb(255, 148, 0)"/> <path d="M213.4,223.8 L225.3,228.7 " stroke="rgb(255, 196, 0)"/> <path d="M225.3,228.7 L237.3,233.6 " stroke="rgb(255, 229, 0)"/> <path d="M237.3,233.6 L249.2,238.6 " stroke="rgb(249, 255, 6)"/> <path d="M249.2,238.6 L261.1,243.5 " stroke="rgb(217, 255, 38)"/> <path d="M261.1,243.5 L273.0,248.4 " stroke="rgb(168, 255, 87)"/> <path d="M273.0,248.4 L284.9,253.3 " stroke="rgb(136, 255, 119)"/> <path d="M284.9,253.3 L296.8,258.2 " stroke="rgb(103, 255, 152)"/> <path d="M296.8,258.2 L308.7,263.1 " stroke="rgb( 71, 255, 184)"/> <path d="M308.7,263.1 L320.7,268.1 " stroke="rgb( 38, 255, 217)"/> <path d="M320.7,268.1 L332.6,273.0 " stroke="rgb( 0, 245, 255)"/> <path d="M332.6,273.0 L344.5,277.9 " stroke="rgb( 0, 212, 255)"/> <path d="M344.5,277.9 L356.4,282.8 " stroke="rgb( 0, 180, 255)"/> <path d="M356.4,282.8 L368.4,287.7 " stroke="rgb( 0, 148, 255)"/> <path d="M368.4,287.7 L380.3,292.7 " stroke="rgb( 0, 99, 255)"/> <path d="M380.3,292.7 L392.2,297.6 " stroke="rgb( 0, 67, 255)"/> <path d="M392.2,297.6 L404.2,302.5 " stroke="rgb( 0, 34, 255)"/> <path d="M115.9,189.5 L127.8,194.4 " stroke="rgb(144, 0, 0)"/> <path d="M127.8,194.4 L139.7,199.4 " stroke="rgb(192, 0, 0)"/> <path d="M139.7,199.4 L151.7,204.2 " stroke="rgb(225, 0, 0)"/> <path d="M151.7,204.2 L163.6,209.1 " stroke="rgb(255, 2, 0)"/> <path d="M163.6,209.1 L175.5,214.0 " stroke="rgb(255, 34, 0)"/> <path d="M175.5,214.0 L187.4,218.9 " stroke="rgb(255, 83, 0)"/> <path d="M187.4,218.9 L199.4,223.9 " stroke="rgb(255, 115, 0)"/> <path d="M199.4,223.9 L211.3,228.8 " stroke="rgb(255, 148, 0)"/> <path d="M211.3,228.8 L223.2,233.7 " stroke="rgb(255, 180, 0)"/> <path d="M223.2,233.7 L235.2,238.6 " stroke="rgb(255, 212, 0)"/> <path d="M235.2,238.6 L247.1,243.5 " stroke="rgb(249, 255, 6)"/> <path d="M247.1,243.5 L259.0,248.5 " stroke="rgb(217, 255, 38)"/> <path d="M259.0,248.5 L270.9,253.4 " stroke="rgb(184, 255, 71)"/> <path d="M270.9,253.4 L282.8,258.3 " stroke="rgb(152, 255, 103)"/> <path d="M282.8,258.3 L294.7,263.2 " stroke="rgb(103, 255, 152)"/> <path d="M294.7,263.2 L306.6,268.1 " stroke="rgb( 71, 255, 184)"/> <path d="M306.6,268.1 L318.6,273.1 " stroke="rgb( 38, 255, 217)"/> <path d="M318.6,273.1 L330.5,278.0 " stroke="rgb( 6, 255, 249)"/> <path d="M330.5,278.0 L342.4,282.9 " stroke="rgb( 0, 229, 255)"/> <path d="M342.4,282.9 L354.3,287.8 " stroke="rgb( 0, 180, 255)"/> <path d="M354.3,287.8 L366.3,292.7 " stroke="rgb( 0, 148, 255)"/> <path d="M366.3,292.7 L378.2,297.6 " stroke="rgb( 0, 115, 255)"/> <path d="M378.2,297.6 L390.1,302.6 " stroke="rgb( 0, 83, 255)"/> <path d="M390.1,302.6 L402.1,307.5 " stroke="rgb( 0, 34, 255)"/> <path d="M113.8,194.5 L125.7,199.4 " stroke="rgb(144, 0, 0)"/> <path d="M125.7,199.4 L137.6,204.2 " stroke="rgb(176, 0, 0)"/> <path d="M137.6,204.2 L149.6,209.2 " stroke="rgb(208, 0, 0)"/> <path d="M149.6,209.2 L161.5,214.1 " stroke="rgb(255, 2, 0)"/> <path d="M161.5,214.1 L173.4,219.0 " stroke="rgb(255, 34, 0)"/> <path d="M173.4,219.0 L185.3,223.9 " stroke="rgb(255, 67, 0)"/> <path d="M185.3,223.9 L197.3,228.8 " stroke="rgb(255, 99, 0)"/> <path d="M197.3,228.8 L209.2,233.8 " stroke="rgb(255, 148, 0)"/> <path d="M209.2,233.8 L221.1,238.7 " stroke="rgb(255, 180, 0)"/> <path d="M221.1,238.7 L233.1,243.6 " stroke="rgb(255, 212, 0)"/> <path d="M233.1,243.6 L245.0,248.5 " stroke="rgb(255, 245, 0)"/> <path d="M245.0,248.5 L256.9,253.4 " stroke="rgb(233, 255, 22)"/> <path d="M256.9,253.4 L268.8,258.4 " stroke="rgb(184, 255, 71)"/> <path d="M268.8,258.4 L280.7,263.3 " stroke="rgb(152, 255, 103)"/> <path d="M280.7,263.3 L292.6,268.2 " stroke="rgb(119, 255, 136)"/> <path d="M292.6,268.2 L304.5,273.1 " stroke="rgb( 87, 255, 168)"/> <path d="M304.5,273.1 L316.5,278.0 " stroke="rgb( 38, 255, 217)"/> <path d="M316.5,278.0 L328.4,283.0 " stroke="rgb( 6, 255, 249)"/> <path d="M328.4,283.0 L340.3,287.9 " stroke="rgb( 0, 229, 255)"/> <path d="M340.3,287.9 L352.2,292.8 " stroke="rgb( 0, 196, 255)"/> <path d="M352.2,292.8 L364.2,297.7 " stroke="rgb( 0, 164, 255)"/> <path d="M364.2,297.7 L376.1,302.6 " stroke="rgb( 0, 115, 255)"/> <path d="M376.1,302.6 L388.0,307.6 " stroke="rgb( 0, 83, 255)"/> <path d="M388.0,307.6 L400.0,312.5 " stroke="rgb( 0, 51, 255)"/> <path d="M111.7,199.5 L123.6,204.3 " stroke="rgb(144, 0, 0)"/> <path d="M123.6,204.3 L135.5,209.2 " stroke="rgb(176, 0, 0)"/> <path d="M135.5,209.2 L147.5,214.2 " stroke="rgb(208, 0, 0)"/> <path d="M147.5,214.2 L159.4,219.1 " stroke="rgb(241, 0, 0)"/> <path d="M159.4,219.1 L171.3,224.0 " stroke="rgb(255, 18, 0)"/> <path d="M171.3,224.0 L183.2,228.9 " stroke="rgb(255, 67, 0)"/> <path d="M183.2,228.9 L195.2,233.8 " stroke="rgb(255, 99, 0)"/> <path d="M195.2,233.8 L207.1,238.7 " stroke="rgb(255, 132, 0)"/> <path d="M207.1,238.7 L219.0,243.7 " stroke="rgb(255, 164, 0)"/> <path d="M219.0,243.7 L231.0,248.6 " stroke="rgb(255, 212, 0)"/> <path d="M231.0,248.6 L242.9,253.5 " stroke="rgb(255, 245, 0)"/> <path d="M242.9,253.5 L254.8,258.4 " stroke="rgb(233, 255, 22)"/> <path d="M254.8,258.4 L266.7,263.3 " stroke="rgb(200, 255, 55)"/> <path d="M266.7,263.3 L278.7,268.3 " stroke="rgb(168, 255, 87)"/> <path d="M278.7,268.3 L290.5,273.2 " stroke="rgb(119, 255, 136)"/> <path d="M290.5,273.2 L302.4,278.1 " stroke="rgb( 87, 255, 168)"/> <path d="M302.4,278.1 L314.4,283.0 " stroke="rgb( 55, 255, 200)"/> <path d="M314.4,283.0 L326.3,287.9 " stroke="rgb( 22, 255, 233)"/> <path d="M326.3,287.9 L338.2,292.9 " stroke="rgb( 0, 229, 255)"/> <path d="M338.2,292.9 L350.1,297.8 " stroke="rgb( 0, 196, 255)"/> <path d="M350.1,297.8 L362.1,302.7 " stroke="rgb( 0, 164, 255)"/> <path d="M362.1,302.7 L374.0,307.6 " stroke="rgb( 0, 132, 255)"/> <path d="M374.0,307.6 L385.9,312.5 " stroke="rgb( 0, 99, 255)"/> <path d="M385.9,312.5 L397.9,317.5 " stroke="rgb( 0, 51, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>gnuplot_plot_2a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M162.1,112.6 L160.0,118.0 " stroke="rgb(168, 255, 87)"/> <path d="M160.0,118.0 L157.9,123.4 L155.8,128.8 L153.7,134.1 L151.6,139.5 L149.5,144.9 " stroke="rgb(184, 255, 71)"/> <path d="M149.5,144.9 L147.4,150.3 L145.3,155.6 L143.2,161.0 L141.1,166.4 " stroke="rgb(200, 255, 55)"/> <path d="M141.1,166.4 L139.0,171.8 L136.9,177.1 L134.8,182.5 L132.7,187.9 L130.6,193.3 " stroke="rgb(217, 255, 38)"/> <path d="M130.6,193.3 L128.5,198.6 L126.4,203.9 L124.3,209.3 L122.2,214.7 " stroke="rgb(233, 255, 22)"/> <path d="M122.2,214.7 L120.1,220.0 L118.0,225.4 L115.9,230.8 L113.8,236.2 L111.7,241.5 " stroke="rgb(249, 255, 6)"/> <path d="M174.1,114.4 L172.0,119.8 L169.9,125.2 L167.8,130.6 " stroke="rgb(168, 255, 87)"/> <path d="M167.8,130.6 L165.7,135.9 L163.6,141.3 L161.5,146.7 L159.4,152.1 L157.2,157.4 " stroke="rgb(184, 255, 71)"/> <path d="M157.2,157.4 L155.1,162.8 L153.0,168.2 L150.9,173.6 L148.8,178.9 " stroke="rgb(200, 255, 55)"/> <path d="M148.8,178.9 L146.7,184.3 L144.6,189.7 L142.5,195.1 L140.4,200.4 L138.3,205.7 " stroke="rgb(217, 255, 38)"/> <path d="M138.3,205.7 L136.2,211.1 L134.1,216.5 L132.0,221.8 L129.9,227.2 " stroke="rgb(233, 255, 22)"/> <path d="M129.9,227.2 L127.8,232.6 L125.7,238.0 L123.6,243.3 " stroke="rgb(249, 255, 6)"/> <path d="M186.0,116.2 L183.9,121.6 " stroke="rgb(152, 255, 103)"/> <path d="M183.9,121.6 L181.8,127.0 L179.7,132.4 L177.6,137.7 L175.5,143.1 " stroke="rgb(168, 255, 87)"/> <path d="M175.5,143.1 L173.4,148.5 L171.3,153.9 L169.2,159.2 L167.1,164.6 L165.0,170.0 " stroke="rgb(184, 255, 71)"/> <path d="M165.0,170.0 L162.9,175.4 L160.8,180.7 L158.7,186.1 L156.6,191.5 " stroke="rgb(200, 255, 55)"/> <path d="M156.6,191.5 L154.5,196.9 L152.4,202.1 L150.2,207.5 L148.1,212.9 L146.0,218.3 " stroke="rgb(217, 255, 38)"/> <path d="M146.0,218.3 L143.9,223.6 L141.8,229.0 L139.7,234.4 L137.6,239.8 " stroke="rgb(233, 255, 22)"/> <path d="M137.6,239.8 L135.5,245.1 " stroke="rgb(249, 255, 6)"/> <path d="M197.9,118.0 L195.8,123.4 L193.7,128.8 L191.6,134.2 " stroke="rgb(152, 255, 103)"/> <path d="M191.6,134.2 L189.5,139.5 L187.4,144.9 L185.3,150.3 L183.2,155.7 " stroke="rgb(168, 255, 87)"/> <path d="M183.2,155.7 L181.1,161.0 L179.0,166.4 L176.9,171.8 L174.8,177.2 L172.7,182.5 " stroke="rgb(184, 255, 71)"/> <path d="M172.7,182.5 L170.6,187.9 L168.5,193.3 L166.4,198.7 L164.3,203.9 " stroke="rgb(200, 255, 55)"/> <path d="M164.3,203.9 L162.2,209.3 L160.1,214.7 L158.0,220.1 L155.9,225.4 L153.8,230.8 " stroke="rgb(217, 255, 38)"/> <path d="M153.8,230.8 L151.7,236.2 L149.6,241.6 L147.5,246.9 " stroke="rgb(233, 255, 22)"/> <path d="M209.9,119.8 L207.8,125.2 L205.7,130.6 L203.6,136.0 L201.4,141.3 L199.3,146.7 " stroke="rgb(152, 255, 103)"/> <path d="M199.3,146.7 L197.2,152.1 L195.1,157.5 L193.0,162.8 L190.9,168.2 " stroke="rgb(168, 255, 87)"/> <path d="M190.9,168.2 L188.8,173.6 L186.7,179.0 L184.6,184.3 L182.5,189.7 L180.4,195.1 " stroke="rgb(184, 255, 71)"/> <path d="M180.4,195.1 L178.3,200.5 L176.2,205.7 L174.1,211.1 L172.0,216.5 " stroke="rgb(200, 255, 55)"/> <path d="M172.0,216.5 L169.9,221.9 L167.8,227.2 L165.7,232.6 L163.6,238.0 L161.5,243.4 " stroke="rgb(217, 255, 38)"/> <path d="M161.5,243.4 L159.4,248.7 " stroke="rgb(233, 255, 22)"/> <path d="M221.8,121.6 L219.7,127.0 L217.6,132.4 " stroke="rgb(136, 255, 119)"/> <path d="M217.6,132.4 L215.5,137.8 L213.4,143.1 L211.3,148.5 L209.2,153.9 L207.1,159.3 " stroke="rgb(152, 255, 103)"/> <path d="M207.1,159.3 L205.0,164.6 L202.9,170.0 L200.8,175.4 L198.7,180.8 " stroke="rgb(168, 255, 87)"/> <path d="M198.7,180.8 L196.6,186.1 L194.4,191.5 L192.3,196.9 L190.2,202.2 L188.1,207.5 " stroke="rgb(184, 255, 71)"/> <path d="M188.1,207.5 L186.0,212.9 L183.9,218.3 L181.8,223.7 L179.7,229.0 " stroke="rgb(200, 255, 55)"/> <path d="M179.7,229.0 L177.6,234.4 L175.5,239.8 L173.4,245.2 L171.3,250.5 " stroke="rgb(217, 255, 38)"/> <path d="M233.7,123.4 L231.6,128.8 L229.5,134.2 L227.4,139.6 L225.3,144.9 " stroke="rgb(136, 255, 119)"/> <path d="M225.3,144.9 L223.2,150.3 L221.1,155.7 L219.0,161.1 L216.9,166.4 L214.8,171.8 " stroke="rgb(152, 255, 103)"/> <path d="M214.8,171.8 L212.7,177.2 L210.6,182.6 L208.5,187.9 L206.4,193.3 " stroke="rgb(168, 255, 87)"/> <path d="M206.4,193.3 L204.3,198.7 L202.2,204.0 L200.1,209.3 L198.0,214.7 L195.9,220.1 " stroke="rgb(184, 255, 71)"/> <path d="M195.9,220.1 L193.8,225.5 L191.7,230.8 L189.5,236.2 L187.4,241.6 " stroke="rgb(200, 255, 55)"/> <path d="M187.4,241.6 L185.3,247.0 L183.2,252.3 " stroke="rgb(217, 255, 38)"/> <path d="M245.6,125.2 L243.5,130.6 L241.4,136.0 " stroke="rgb(119, 255, 136)"/> <path d="M241.4,136.0 L239.3,141.3 L237.2,146.7 L235.1,152.1 L233.0,157.5 " stroke="rgb(136, 255, 119)"/> <path d="M233.0,157.5 L230.9,162.8 L228.8,168.2 L226.7,173.6 L224.6,179.0 L222.5,184.3 " stroke="rgb(152, 255, 103)"/> <path d="M222.5,184.3 L220.4,189.7 L218.3,195.1 L216.2,200.5 L214.1,205.7 " stroke="rgb(168, 255, 87)"/> <path d="M214.1,205.7 L212.0,211.1 L209.9,216.5 L207.8,221.9 L205.7,227.2 L203.6,232.6 " stroke="rgb(184, 255, 71)"/> <path d="M203.6,232.6 L201.5,238.0 L199.4,243.4 L197.3,248.7 L195.2,254.1 " stroke="rgb(200, 255, 55)"/> <path d="M257.6,127.0 L255.5,132.4 L253.4,137.8 L251.3,143.1 L249.2,148.5 " stroke="rgb(119, 255, 136)"/> <path d="M249.2,148.5 L247.1,153.9 L245.0,159.3 L242.9,164.6 L240.7,170.0 " stroke="rgb(136, 255, 119)"/> <path d="M240.7,170.0 L238.6,175.4 L236.5,180.8 L234.4,186.1 L232.3,191.5 L230.2,196.9 " stroke="rgb(152, 255, 103)"/> <path d="M230.2,196.9 L228.1,202.2 L226.0,207.5 L223.9,212.9 L221.8,218.3 " stroke="rgb(168, 255, 87)"/> <path d="M221.8,218.3 L219.7,223.7 L217.6,229.0 L215.5,234.4 L213.4,239.8 L211.3,245.2 " stroke="rgb(184, 255, 71)"/> <path d="M211.3,245.2 L209.2,250.5 L207.1,255.9 " stroke="rgb(200, 255, 55)"/> <path d="M269.5,128.8 L267.4,134.2 " stroke="rgb(103, 255, 152)"/> <path d="M267.4,134.2 L265.3,139.6 L263.2,144.9 L261.1,150.3 L259.0,155.7 L256.9,161.1 " stroke="rgb(119, 255, 136)"/> <path d="M256.9,161.1 L254.8,166.4 L252.7,171.8 L250.6,177.2 L248.5,182.6 " stroke="rgb(136, 255, 119)"/> <path d="M248.5,182.6 L246.4,187.9 L244.3,193.3 L242.2,198.7 L240.1,204.0 L238.0,209.3 " stroke="rgb(152, 255, 103)"/> <path d="M238.0,209.3 L235.9,214.7 L233.7,220.1 L231.6,225.5 L229.5,230.8 " stroke="rgb(168, 255, 87)"/> <path d="M229.5,230.8 L227.4,236.2 L225.3,241.6 L223.2,247.0 L221.1,252.3 L219.0,257.7 " stroke="rgb(184, 255, 71)"/> <path d="M281.3,130.6 L279.3,136.0 L277.2,141.4 L275.1,146.7 " stroke="rgb(103, 255, 152)"/> <path d="M275.1,146.7 L273.0,152.1 L270.9,157.5 L268.8,162.9 L266.7,168.2 L264.6,173.6 " stroke="rgb(119, 255, 136)"/> <path d="M264.6,173.6 L262.5,179.0 L260.4,184.4 L258.3,189.7 L256.2,195.1 " stroke="rgb(136, 255, 119)"/> <path d="M256.2,195.1 L254.1,200.5 L252.0,205.8 L249.9,211.1 L247.8,216.5 L245.7,221.9 " stroke="rgb(152, 255, 103)"/> <path d="M245.7,221.9 L243.6,227.3 L241.5,232.6 L239.4,238.0 L237.3,243.4 " stroke="rgb(168, 255, 87)"/> <path d="M237.3,243.4 L235.2,248.8 L233.1,254.1 L231.0,259.5 " stroke="rgb(184, 255, 71)"/> <path d="M293.3,132.4 L291.2,137.8 " stroke="rgb( 87, 255, 168)"/> <path d="M291.2,137.8 L289.1,143.2 L287.0,148.5 L284.8,153.9 L282.7,159.3 " stroke="rgb(103, 255, 152)"/> <path d="M282.7,159.3 L280.6,164.7 L278.6,170.0 L276.5,175.4 L274.4,180.8 L272.3,186.2 " stroke="rgb(119, 255, 136)"/> <path d="M272.3,186.2 L270.2,191.5 L268.1,196.9 L266.0,202.2 L263.9,207.6 " stroke="rgb(136, 255, 119)"/> <path d="M263.9,207.6 L261.8,212.9 L259.7,218.3 L257.6,223.7 L255.5,229.1 L253.4,234.4 " stroke="rgb(152, 255, 103)"/> <path d="M253.4,234.4 L251.3,239.8 L249.2,245.2 L247.1,250.6 L245.0,255.9 " stroke="rgb(168, 255, 87)"/> <path d="M245.0,255.9 L242.9,261.3 " stroke="rgb(184, 255, 71)"/> <path d="M305.2,134.2 L303.1,139.6 L301.0,145.0 L298.9,150.3 " stroke="rgb( 87, 255, 168)"/> <path d="M298.9,150.3 L296.8,155.7 L294.7,161.1 L292.6,166.5 L290.5,171.8 " stroke="rgb(103, 255, 152)"/> <path d="M290.5,171.8 L288.4,177.2 L286.3,182.6 L284.2,188.0 L282.1,193.3 L280.0,198.7 " stroke="rgb(119, 255, 136)"/> <path d="M280.0,198.7 L277.9,204.0 L275.8,209.4 L273.7,214.7 L271.6,220.1 " stroke="rgb(136, 255, 119)"/> <path d="M271.6,220.1 L269.5,225.5 L267.4,230.9 L265.3,236.2 L263.2,241.6 L261.1,247.0 " stroke="rgb(152, 255, 103)"/> <path d="M261.1,247.0 L259.0,252.4 L256.9,257.7 L254.8,263.1 " stroke="rgb(168, 255, 87)"/> <path d="M317.1,136.0 L315.0,141.4 L312.9,146.8 L310.8,152.1 L308.7,157.5 L306.6,162.9 " stroke="rgb( 87, 255, 168)"/> <path d="M306.6,162.9 L304.5,168.3 L302.4,173.6 L300.3,179.0 L298.2,184.4 " stroke="rgb(103, 255, 152)"/> <path d="M298.2,184.4 L296.1,189.8 L294.0,195.1 L291.9,200.5 L289.8,205.8 L287.7,211.2 " stroke="rgb(119, 255, 136)"/> <path d="M287.7,211.2 L285.6,216.5 L283.5,221.9 L281.4,227.3 L279.4,232.7 " stroke="rgb(136, 255, 119)"/> <path d="M279.4,232.7 L277.3,238.0 L275.2,243.4 L273.0,248.8 L270.9,254.2 L268.8,259.5 " stroke="rgb(152, 255, 103)"/> <path d="M268.8,259.5 L266.7,264.9 " stroke="rgb(168, 255, 87)"/> <path d="M329.0,137.8 L326.9,143.2 L324.8,148.6 " stroke="rgb( 71, 255, 184)"/> <path d="M324.8,148.6 L322.7,153.9 L320.6,159.3 L318.5,164.7 L316.4,170.1 L314.3,175.4 " stroke="rgb( 87, 255, 168)"/> <path d="M314.3,175.4 L312.2,180.8 L310.1,186.2 L308.0,191.6 L305.9,196.9 " stroke="rgb(103, 255, 152)"/> <path d="M305.9,196.9 L303.8,202.2 L301.7,207.6 L299.6,213.0 L297.5,218.3 L295.4,223.7 " stroke="rgb(119, 255, 136)"/> <path d="M295.4,223.7 L293.3,229.1 L291.2,234.5 L289.1,239.8 L287.0,245.2 " stroke="rgb(136, 255, 119)"/> <path d="M287.0,245.2 L284.9,250.6 L282.8,256.0 L280.7,261.3 L278.7,266.7 " stroke="rgb(152, 255, 103)"/> <path d="M341.0,139.6 L338.9,145.0 L336.8,150.3 L334.7,155.7 L332.6,161.1 " stroke="rgb( 71, 255, 184)"/> <path d="M332.6,161.1 L330.5,166.5 L328.4,171.8 L326.3,177.2 L324.1,182.6 L322.0,188.0 " stroke="rgb( 87, 255, 168)"/> <path d="M322.0,188.0 L319.9,193.3 L317.8,198.7 L315.7,204.0 L313.6,209.4 " stroke="rgb(103, 255, 152)"/> <path d="M313.6,209.4 L311.5,214.7 L309.4,220.1 L307.3,225.5 L305.2,230.9 L303.1,236.2 " stroke="rgb(119, 255, 136)"/> <path d="M303.1,236.2 L301.0,241.6 L298.9,247.0 L296.8,252.4 L294.7,257.8 " stroke="rgb(136, 255, 119)"/> <path d="M294.7,257.8 L292.6,263.1 L290.5,268.5 " stroke="rgb(152, 255, 103)"/> <path d="M352.9,141.4 L350.8,146.8 L348.7,152.1 " stroke="rgb( 55, 255, 200)"/> <path d="M348.7,152.1 L346.6,157.5 L344.5,162.9 L342.4,168.3 L340.3,173.6 " stroke="rgb( 71, 255, 184)"/> <path d="M340.3,173.6 L338.2,179.0 L336.1,184.4 L334.0,189.8 L331.9,195.1 L329.8,200.5 " stroke="rgb( 87, 255, 168)"/> <path d="M329.8,200.5 L327.7,205.8 L325.6,211.2 L323.5,216.5 L321.4,221.9 " stroke="rgb(103, 255, 152)"/> <path d="M321.4,221.9 L319.3,227.3 L317.1,232.7 L315.0,238.0 L312.9,243.4 L310.8,248.8 " stroke="rgb(119, 255, 136)"/> <path d="M310.8,248.8 L308.7,254.2 L306.6,259.5 L304.5,264.9 L302.4,270.3 " stroke="rgb(136, 255, 119)"/> <path d="M364.8,143.2 L362.7,148.6 L360.6,153.9 L358.5,159.3 L356.4,164.7 " stroke="rgb( 55, 255, 200)"/> <path d="M356.4,164.7 L354.3,170.1 L352.2,175.4 L350.1,180.8 L348.0,186.2 " stroke="rgb( 71, 255, 184)"/> <path d="M348.0,186.2 L345.9,191.6 L343.8,196.9 L341.7,202.2 L339.6,207.6 L337.5,213.0 " stroke="rgb( 87, 255, 168)"/> <path d="M337.5,213.0 L335.4,218.3 L333.3,223.7 L331.2,229.1 L329.1,234.5 " stroke="rgb(103, 255, 152)"/> <path d="M329.1,234.5 L327.0,239.8 L324.9,245.2 L322.8,250.6 L320.7,256.0 L318.6,261.3 " stroke="rgb(119, 255, 136)"/> <path d="M318.6,261.3 L316.5,266.7 L314.4,272.1 " stroke="rgb(136, 255, 119)"/> <path d="M376.8,145.0 L374.7,150.4 " stroke="rgb( 38, 255, 217)"/> <path d="M374.7,150.4 L372.6,155.7 L370.5,161.1 L368.3,166.5 L366.2,171.9 L364.1,177.2 " stroke="rgb( 55, 255, 200)"/> <path d="M364.1,177.2 L362.0,182.6 L359.9,188.0 L357.8,193.4 L355.7,198.7 " stroke="rgb( 71, 255, 184)"/> <path d="M355.7,198.7 L353.6,204.0 L351.5,209.4 L349.4,214.8 L347.3,220.1 L345.2,225.5 " stroke="rgb( 87, 255, 168)"/> <path d="M345.2,225.5 L343.1,230.9 L341.0,236.3 L338.9,241.6 L336.8,247.0 " stroke="rgb(103, 255, 152)"/> <path d="M336.8,247.0 L334.7,252.4 L332.6,257.8 L330.5,263.1 L328.4,268.5 L326.3,273.9 " stroke="rgb(119, 255, 136)"/> <path d="M388.7,146.8 L386.6,152.2 L384.5,157.5 L382.4,162.9 " stroke="rgb( 38, 255, 217)"/> <path d="M382.4,162.9 L380.3,168.3 L378.2,173.7 L376.1,179.0 L374.0,184.4 L371.9,189.8 " stroke="rgb( 55, 255, 200)"/> <path d="M371.9,189.8 L369.8,195.2 L367.7,200.5 L365.6,205.8 L363.4,211.2 " stroke="rgb( 71, 255, 184)"/> <path d="M363.4,211.2 L361.3,216.6 L359.2,221.9 L357.1,227.3 L355.0,232.7 L352.9,238.1 " stroke="rgb( 87, 255, 168)"/> <path d="M352.9,238.1 L350.8,243.4 L348.7,248.8 L346.6,254.2 L344.5,259.6 " stroke="rgb(103, 255, 152)"/> <path d="M344.5,259.6 L342.4,264.9 L340.3,270.3 L338.2,275.7 " stroke="rgb(119, 255, 136)"/> <path d="M400.6,148.6 L398.5,154.0 " stroke="rgb( 22, 255, 233)"/> <path d="M398.5,154.0 L396.4,159.3 L394.3,164.7 L392.2,170.1 L390.1,175.5 " stroke="rgb( 38, 255, 217)"/> <path d="M390.1,175.5 L388.0,180.8 L385.9,186.2 L383.8,191.6 L381.7,197.0 L379.6,202.2 " stroke="rgb( 55, 255, 200)"/> <path d="M379.6,202.2 L377.5,207.6 L375.4,213.0 L373.3,218.4 L371.2,223.7 " stroke="rgb( 71, 255, 184)"/> <path d="M371.2,223.7 L369.1,229.1 L367.0,234.5 L364.9,239.9 L362.8,245.2 L360.7,250.6 " stroke="rgb( 87, 255, 168)"/> <path d="M360.7,250.6 L358.6,256.0 L356.4,261.4 L354.3,266.7 L352.2,272.1 " stroke="rgb(103, 255, 152)"/> <path d="M352.2,272.1 L350.1,277.5 " stroke="rgb(119, 255, 136)"/> <path d="M412.5,150.4 L410.4,155.8 L408.3,161.1 L406.2,166.5 " stroke="rgb( 22, 255, 233)"/> <path d="M406.2,166.5 L404.1,171.9 L402.0,177.3 L399.9,182.6 L397.8,188.0 " stroke="rgb( 38, 255, 217)"/> <path d="M397.8,188.0 L395.7,193.4 L393.6,198.8 L391.5,204.0 L389.4,209.4 L387.3,214.8 " stroke="rgb( 55, 255, 200)"/> <path d="M387.3,214.8 L385.2,220.2 L383.1,225.5 L381.0,230.9 L378.9,236.3 " stroke="rgb( 71, 255, 184)"/> <path d="M378.9,236.3 L376.8,241.7 L374.7,247.0 L372.6,252.4 L370.5,257.8 L368.4,263.2 " stroke="rgb( 87, 255, 168)"/> <path d="M368.4,263.2 L366.3,268.5 L364.2,273.9 L362.1,279.3 " stroke="rgb(103, 255, 152)"/> <path d="M424.5,152.2 L422.4,157.6 L420.3,162.9 L418.2,168.3 L416.1,173.7 L414.0,179.1 " stroke="rgb( 22, 255, 233)"/> <path d="M414.0,179.1 L411.9,184.4 L409.8,189.8 L407.6,195.2 L405.5,200.6 " stroke="rgb( 38, 255, 217)"/> <path d="M405.5,200.6 L403.4,205.8 L401.3,211.2 L399.2,216.6 L397.1,222.0 L395.0,227.3 " stroke="rgb( 55, 255, 200)"/> <path d="M395.0,227.3 L392.9,232.7 L390.8,238.1 L388.7,243.5 L386.6,248.8 " stroke="rgb( 71, 255, 184)"/> <path d="M386.6,248.8 L384.5,254.2 L382.4,259.6 L380.3,265.0 L378.2,270.3 L376.1,275.7 " stroke="rgb( 87, 255, 168)"/> <path d="M376.1,275.7 L374.0,281.1 " stroke="rgb(103, 255, 152)"/> <path d="M436.4,154.0 L434.3,159.4 L432.2,164.7 " stroke="rgb( 6, 255, 249)"/> <path d="M432.2,164.7 L430.1,170.1 L428.0,175.5 L425.9,180.9 L423.8,186.2 L421.7,191.6 " stroke="rgb( 22, 255, 233)"/> <path d="M421.7,191.6 L419.6,197.0 L417.5,202.3 L415.4,207.6 L413.3,213.0 " stroke="rgb( 38, 255, 217)"/> <path d="M413.3,213.0 L411.2,218.4 L409.1,223.8 L407.0,229.1 L404.9,234.5 L402.8,239.9 " stroke="rgb( 55, 255, 200)"/> <path d="M402.8,239.9 L400.6,245.3 L398.5,250.6 L396.4,256.0 L394.3,261.4 " stroke="rgb( 71, 255, 184)"/> <path d="M394.3,261.4 L392.2,266.8 L390.1,272.1 L388.0,277.5 L385.9,282.9 " stroke="rgb( 87, 255, 168)"/> <path d="M448.3,155.8 L446.2,161.1 L444.1,166.5 L442.0,171.9 L439.9,177.3 " stroke="rgb( 6, 255, 249)"/> <path d="M439.9,177.3 L437.8,182.6 L435.7,188.0 L433.6,193.4 L431.5,198.8 L429.4,204.0 " stroke="rgb( 22, 255, 233)"/> <path d="M429.4,204.0 L427.3,209.4 L425.2,214.8 L423.1,220.2 L421.0,225.5 " stroke="rgb( 38, 255, 217)"/> <path d="M421.0,225.5 L418.9,230.9 L416.8,236.3 L414.7,241.7 L412.6,247.0 L410.5,252.4 " stroke="rgb( 55, 255, 200)"/> <path d="M410.5,252.4 L408.4,257.8 L406.3,263.2 L404.2,268.5 L402.1,273.9 " stroke="rgb( 71, 255, 184)"/> <path d="M402.1,273.9 L400.0,279.3 L397.9,284.7 " stroke="rgb( 87, 255, 168)"/> <path d="M162.1,112.6 L174.1,114.4 L186.0,116.2 " stroke="rgb(168, 255, 87)"/> <path d="M186.0,116.2 L197.9,118.0 L209.9,119.8 " stroke="rgb(152, 255, 103)"/> <path d="M209.9,119.8 L221.8,121.6 L233.7,123.4 " stroke="rgb(136, 255, 119)"/> <path d="M233.7,123.4 L245.6,125.2 L257.6,127.0 " stroke="rgb(119, 255, 136)"/> <path d="M257.6,127.0 L269.5,128.8 L281.3,130.6 L293.3,132.4 " stroke="rgb(103, 255, 152)"/> <path d="M293.3,132.4 L305.2,134.2 L317.1,136.0 " stroke="rgb( 87, 255, 168)"/> <path d="M317.1,136.0 L329.0,137.8 L341.0,139.6 " stroke="rgb( 71, 255, 184)"/> <path d="M341.0,139.6 L352.9,141.4 L364.8,143.2 " stroke="rgb( 55, 255, 200)"/> <path d="M364.8,143.2 L376.8,145.0 L388.7,146.8 L400.6,148.6 " stroke="rgb( 38, 255, 217)"/> <path d="M400.6,148.6 L412.5,150.4 L424.5,152.2 " stroke="rgb( 22, 255, 233)"/> <path d="M424.5,152.2 L436.4,154.0 L448.3,155.8 " stroke="rgb( 6, 255, 249)"/> <path d="M160.0,118.0 L172.0,119.8 L183.9,121.6 " stroke="rgb(168, 255, 87)"/> <path d="M183.9,121.6 L195.8,123.4 L207.8,125.2 " stroke="rgb(152, 255, 103)"/> <path d="M207.8,125.2 L219.7,127.0 L231.6,128.8 L243.5,130.6 " stroke="rgb(136, 255, 119)"/> <path d="M243.5,130.6 L255.5,132.4 L267.4,134.2 " stroke="rgb(119, 255, 136)"/> <path d="M267.4,134.2 L279.3,136.0 L291.2,137.8 " stroke="rgb(103, 255, 152)"/> <path d="M291.2,137.8 L303.1,139.6 L315.0,141.4 " stroke="rgb( 87, 255, 168)"/> <path d="M315.0,141.4 L326.9,143.2 L338.9,145.0 L350.8,146.8 " stroke="rgb( 71, 255, 184)"/> <path d="M350.8,146.8 L362.7,148.6 L374.7,150.4 " stroke="rgb( 55, 255, 200)"/> <path d="M374.7,150.4 L386.6,152.2 L398.5,154.0 " stroke="rgb( 38, 255, 217)"/> <path d="M398.5,154.0 L410.4,155.8 L422.4,157.6 " stroke="rgb( 22, 255, 233)"/> <path d="M422.4,157.6 L434.3,159.4 L446.2,161.1 " stroke="rgb( 6, 255, 249)"/> <path d="M157.9,123.4 L169.9,125.2 L181.8,127.0 L193.7,128.8 " stroke="rgb(168, 255, 87)"/> <path d="M193.7,128.8 L205.7,130.6 L217.6,132.4 " stroke="rgb(152, 255, 103)"/> <path d="M217.6,132.4 L229.5,134.2 L241.4,136.0 " stroke="rgb(136, 255, 119)"/> <path d="M241.4,136.0 L253.4,137.8 L265.3,139.6 " stroke="rgb(119, 255, 136)"/> <path d="M265.3,139.6 L277.2,141.4 L289.1,143.2 L301.0,145.0 " stroke="rgb(103, 255, 152)"/> <path d="M301.0,145.0 L312.9,146.8 L324.8,148.6 " stroke="rgb( 87, 255, 168)"/> <path d="M324.8,148.6 L336.8,150.3 L348.7,152.1 " stroke="rgb( 71, 255, 184)"/> <path d="M348.7,152.1 L360.6,153.9 L372.6,155.7 " stroke="rgb( 55, 255, 200)"/> <path d="M372.6,155.7 L384.5,157.5 L396.4,159.3 L408.3,161.1 " stroke="rgb( 38, 255, 217)"/> <path d="M408.3,161.1 L420.3,162.9 L432.2,164.7 " stroke="rgb( 22, 255, 233)"/> <path d="M432.2,164.7 L444.1,166.5 " stroke="rgb( 6, 255, 249)"/> <path d="M155.8,128.8 L167.8,130.6 " stroke="rgb(184, 255, 71)"/> <path d="M167.8,130.6 L179.7,132.4 L191.6,134.2 " stroke="rgb(168, 255, 87)"/> <path d="M191.6,134.2 L203.6,136.0 L215.5,137.8 " stroke="rgb(152, 255, 103)"/> <path d="M215.5,137.8 L227.4,139.6 L239.3,141.3 L251.3,143.1 " stroke="rgb(136, 255, 119)"/> <path d="M251.3,143.1 L263.2,144.9 L275.1,146.7 " stroke="rgb(119, 255, 136)"/> <path d="M275.1,146.7 L287.0,148.5 L298.9,150.3 " stroke="rgb(103, 255, 152)"/> <path d="M298.9,150.3 L310.8,152.1 L322.7,153.9 " stroke="rgb( 87, 255, 168)"/> <path d="M322.7,153.9 L334.7,155.7 L346.6,157.5 L358.5,159.3 " stroke="rgb( 71, 255, 184)"/> <path d="M358.5,159.3 L370.5,161.1 L382.4,162.9 " stroke="rgb( 55, 255, 200)"/> <path d="M382.4,162.9 L394.3,164.7 L406.2,166.5 " stroke="rgb( 38, 255, 217)"/> <path d="M406.2,166.5 L418.2,168.3 L430.1,170.1 " stroke="rgb( 22, 255, 233)"/> <path d="M430.1,170.1 L442.0,171.9 " stroke="rgb( 6, 255, 249)"/> <path d="M153.7,134.1 L165.7,135.9 " stroke="rgb(184, 255, 71)"/> <path d="M165.7,135.9 L177.6,137.7 L189.5,139.5 L201.4,141.3 " stroke="rgb(168, 255, 87)"/> <path d="M201.4,141.3 L213.4,143.1 L225.3,144.9 " stroke="rgb(152, 255, 103)"/> <path d="M225.3,144.9 L237.2,146.7 L249.2,148.5 " stroke="rgb(136, 255, 119)"/> <path d="M249.2,148.5 L261.1,150.3 L273.0,152.1 " stroke="rgb(119, 255, 136)"/> <path d="M273.0,152.1 L284.8,153.9 L296.8,155.7 L308.7,157.5 " stroke="rgb(103, 255, 152)"/> <path d="M308.7,157.5 L320.6,159.3 L332.6,161.1 " stroke="rgb( 87, 255, 168)"/> <path d="M332.6,161.1 L344.5,162.9 L356.4,164.7 " stroke="rgb( 71, 255, 184)"/> <path d="M356.4,164.7 L368.3,166.5 L380.3,168.3 " stroke="rgb( 55, 255, 200)"/> <path d="M380.3,168.3 L392.2,170.1 L404.1,171.9 L416.1,173.7 " stroke="rgb( 38, 255, 217)"/> <path d="M416.1,173.7 L428.0,175.5 L439.9,177.3 " stroke="rgb( 22, 255, 233)"/> <path d="M151.6,139.5 L163.6,141.3 L175.5,143.1 " stroke="rgb(184, 255, 71)"/> <path d="M175.5,143.1 L187.4,144.9 L199.3,146.7 " stroke="rgb(168, 255, 87)"/> <path d="M199.3,146.7 L211.3,148.5 L223.2,150.3 " stroke="rgb(152, 255, 103)"/> <path d="M223.2,150.3 L235.1,152.1 L247.1,153.9 L259.0,155.7 " stroke="rgb(136, 255, 119)"/> <path d="M259.0,155.7 L270.9,157.5 L282.7,159.3 " stroke="rgb(119, 255, 136)"/> <path d="M282.7,159.3 L294.7,161.1 L306.6,162.9 " stroke="rgb(103, 255, 152)"/> <path d="M306.6,162.9 L318.5,164.7 L330.5,166.5 " stroke="rgb( 87, 255, 168)"/> <path d="M330.5,166.5 L342.4,168.3 L354.3,170.1 L366.2,171.9 " stroke="rgb( 71, 255, 184)"/> <path d="M366.2,171.9 L378.2,173.7 L390.1,175.5 " stroke="rgb( 55, 255, 200)"/> <path d="M390.1,175.5 L402.0,177.3 L414.0,179.1 " stroke="rgb( 38, 255, 217)"/> <path d="M414.0,179.1 L425.9,180.9 L437.8,182.6 " stroke="rgb( 22, 255, 233)"/> <path d="M149.5,144.9 L161.5,146.7 L173.4,148.5 " stroke="rgb(184, 255, 71)"/> <path d="M173.4,148.5 L185.3,150.3 L197.2,152.1 L209.2,153.9 " stroke="rgb(168, 255, 87)"/> <path d="M209.2,153.9 L221.1,155.7 L233.0,157.5 " stroke="rgb(152, 255, 103)"/> <path d="M233.0,157.5 L245.0,159.3 L256.9,161.1 " stroke="rgb(136, 255, 119)"/> <path d="M256.9,161.1 L268.8,162.9 L280.6,164.7 " stroke="rgb(119, 255, 136)"/> <path d="M280.6,164.7 L292.6,166.5 L304.5,168.3 L316.4,170.1 " stroke="rgb(103, 255, 152)"/> <path d="M316.4,170.1 L328.4,171.8 L340.3,173.6 " stroke="rgb( 87, 255, 168)"/> <path d="M340.3,173.6 L352.2,175.4 L364.1,177.2 " stroke="rgb( 71, 255, 184)"/> <path d="M364.1,177.2 L376.1,179.0 L388.0,180.8 " stroke="rgb( 55, 255, 200)"/> <path d="M388.0,180.8 L399.9,182.6 L411.9,184.4 L423.8,186.2 " stroke="rgb( 38, 255, 217)"/> <path d="M423.8,186.2 L435.7,188.0 " stroke="rgb( 22, 255, 233)"/> <path d="M147.4,150.3 L159.4,152.1 " stroke="rgb(200, 255, 55)"/> <path d="M159.4,152.1 L171.3,153.9 L183.2,155.7 " stroke="rgb(184, 255, 71)"/> <path d="M183.2,155.7 L195.1,157.5 L207.1,159.3 " stroke="rgb(168, 255, 87)"/> <path d="M207.1,159.3 L219.0,161.1 L230.9,162.8 " stroke="rgb(152, 255, 103)"/> <path d="M230.9,162.8 L242.9,164.6 L254.8,166.4 L266.7,168.2 " stroke="rgb(136, 255, 119)"/> <path d="M266.7,168.2 L278.6,170.0 L290.5,171.8 " stroke="rgb(119, 255, 136)"/> <path d="M290.5,171.8 L302.4,173.6 L314.3,175.4 " stroke="rgb(103, 255, 152)"/> <path d="M314.3,175.4 L326.3,177.2 L338.2,179.0 " stroke="rgb( 87, 255, 168)"/> <path d="M338.2,179.0 L350.1,180.8 L362.0,182.6 L374.0,184.4 " stroke="rgb( 71, 255, 184)"/> <path d="M374.0,184.4 L385.9,186.2 L397.8,188.0 " stroke="rgb( 55, 255, 200)"/> <path d="M397.8,188.0 L409.8,189.8 L421.7,191.6 " stroke="rgb( 38, 255, 217)"/> <path d="M421.7,191.6 L433.6,193.4 " stroke="rgb( 22, 255, 233)"/> <path d="M145.3,155.6 L157.2,157.4 " stroke="rgb(200, 255, 55)"/> <path d="M157.2,157.4 L169.2,159.2 L181.1,161.0 " stroke="rgb(184, 255, 71)"/> <path d="M181.1,161.0 L193.0,162.8 L205.0,164.6 L216.9,166.4 " stroke="rgb(168, 255, 87)"/> <path d="M216.9,166.4 L228.8,168.2 L240.7,170.0 " stroke="rgb(152, 255, 103)"/> <path d="M240.7,170.0 L252.7,171.8 L264.6,173.6 " stroke="rgb(136, 255, 119)"/> <path d="M264.6,173.6 L276.5,175.4 L288.4,177.2 " stroke="rgb(119, 255, 136)"/> <path d="M288.4,177.2 L300.3,179.0 L312.2,180.8 L324.1,182.6 " stroke="rgb(103, 255, 152)"/> <path d="M324.1,182.6 L336.1,184.4 L348.0,186.2 " stroke="rgb( 87, 255, 168)"/> <path d="M348.0,186.2 L359.9,188.0 L371.9,189.8 " stroke="rgb( 71, 255, 184)"/> <path d="M371.9,189.8 L383.8,191.6 L395.7,193.4 " stroke="rgb( 55, 255, 200)"/> <path d="M395.7,193.4 L407.6,195.2 L419.6,197.0 L431.5,198.8 " stroke="rgb( 38, 255, 217)"/> <path d="M143.2,161.0 L155.1,162.8 L167.1,164.6 " stroke="rgb(200, 255, 55)"/> <path d="M167.1,164.6 L179.0,166.4 L190.9,168.2 " stroke="rgb(184, 255, 71)"/> <path d="M190.9,168.2 L202.9,170.0 L214.8,171.8 " stroke="rgb(168, 255, 87)"/> <path d="M214.8,171.8 L226.7,173.6 L238.6,175.4 " stroke="rgb(152, 255, 103)"/> <path d="M238.6,175.4 L250.6,177.2 L262.5,179.0 L274.4,180.8 " stroke="rgb(136, 255, 119)"/> <path d="M274.4,180.8 L286.3,182.6 L298.2,184.4 " stroke="rgb(119, 255, 136)"/> <path d="M298.2,184.4 L310.1,186.2 L322.0,188.0 " stroke="rgb(103, 255, 152)"/> <path d="M322.0,188.0 L334.0,189.8 L345.9,191.6 " stroke="rgb( 87, 255, 168)"/> <path d="M345.9,191.6 L357.8,193.4 L369.8,195.2 L381.7,197.0 " stroke="rgb( 71, 255, 184)"/> <path d="M381.7,197.0 L393.6,198.8 L405.5,200.6 " stroke="rgb( 55, 255, 200)"/> <path d="M405.5,200.6 L417.5,202.3 L429.4,204.0 " stroke="rgb( 38, 255, 217)"/> <path d="M141.1,166.4 L153.0,168.2 L165.0,170.0 " stroke="rgb(200, 255, 55)"/> <path d="M165.0,170.0 L176.9,171.8 L188.8,173.6 " stroke="rgb(184, 255, 71)"/> <path d="M188.8,173.6 L200.8,175.4 L212.7,177.2 L224.6,179.0 " stroke="rgb(168, 255, 87)"/> <path d="M224.6,179.0 L236.5,180.8 L248.5,182.6 " stroke="rgb(152, 255, 103)"/> <path d="M248.5,182.6 L260.4,184.4 L272.3,186.2 " stroke="rgb(136, 255, 119)"/> <path d="M272.3,186.2 L284.2,188.0 L296.1,189.8 " stroke="rgb(119, 255, 136)"/> <path d="M296.1,189.8 L308.0,191.6 L319.9,193.3 L331.9,195.1 " stroke="rgb(103, 255, 152)"/> <path d="M331.9,195.1 L343.8,196.9 L355.7,198.7 " stroke="rgb( 87, 255, 168)"/> <path d="M355.7,198.7 L367.7,200.5 L379.6,202.2 " stroke="rgb( 71, 255, 184)"/> <path d="M379.6,202.2 L391.5,204.0 L403.4,205.8 " stroke="rgb( 55, 255, 200)"/> <path d="M403.4,205.8 L415.4,207.6 L427.3,209.4 " stroke="rgb( 38, 255, 217)"/> <path d="M139.0,171.8 L150.9,173.6 L162.9,175.4 L174.8,177.2 " stroke="rgb(200, 255, 55)"/> <path d="M174.8,177.2 L186.7,179.0 L198.7,180.8 " stroke="rgb(184, 255, 71)"/> <path d="M198.7,180.8 L210.6,182.6 L222.5,184.3 " stroke="rgb(168, 255, 87)"/> <path d="M222.5,184.3 L234.4,186.1 L246.4,187.9 " stroke="rgb(152, 255, 103)"/> <path d="M246.4,187.9 L258.3,189.7 L270.2,191.5 L282.1,193.3 " stroke="rgb(136, 255, 119)"/> <path d="M282.1,193.3 L294.0,195.1 L305.9,196.9 " stroke="rgb(119, 255, 136)"/> <path d="M305.9,196.9 L317.8,198.7 L329.8,200.5 " stroke="rgb(103, 255, 152)"/> <path d="M329.8,200.5 L341.7,202.2 L353.6,204.0 " stroke="rgb( 87, 255, 168)"/> <path d="M353.6,204.0 L365.6,205.8 L377.5,207.6 L389.4,209.4 " stroke="rgb( 71, 255, 184)"/> <path d="M389.4,209.4 L401.3,211.2 L413.3,213.0 " stroke="rgb( 55, 255, 200)"/> <path d="M413.3,213.0 L425.2,214.8 " stroke="rgb( 38, 255, 217)"/> <path d="M136.9,177.1 L148.8,178.9 " stroke="rgb(217, 255, 38)"/> <path d="M148.8,178.9 L160.8,180.7 L172.7,182.5 " stroke="rgb(200, 255, 55)"/> <path d="M172.7,182.5 L184.6,184.3 L196.6,186.1 " stroke="rgb(184, 255, 71)"/> <path d="M196.6,186.1 L208.5,187.9 L220.4,189.7 L232.3,191.5 " stroke="rgb(168, 255, 87)"/> <path d="M232.3,191.5 L244.3,193.3 L256.2,195.1 " stroke="rgb(152, 255, 103)"/> <path d="M256.2,195.1 L268.1,196.9 L280.0,198.7 " stroke="rgb(136, 255, 119)"/> <path d="M280.0,198.7 L291.9,200.5 L303.8,202.2 " stroke="rgb(119, 255, 136)"/> <path d="M303.8,202.2 L315.7,204.0 L327.7,205.8 L339.6,207.6 " stroke="rgb(103, 255, 152)"/> <path d="M339.6,207.6 L351.5,209.4 L363.4,211.2 " stroke="rgb( 87, 255, 168)"/> <path d="M363.4,211.2 L375.4,213.0 L387.3,214.8 " stroke="rgb( 71, 255, 184)"/> <path d="M387.3,214.8 L399.2,216.6 L411.2,218.4 " stroke="rgb( 55, 255, 200)"/> <path d="M411.2,218.4 L423.1,220.2 " stroke="rgb( 38, 255, 217)"/> <path d="M134.8,182.5 L146.7,184.3 " stroke="rgb(217, 255, 38)"/> <path d="M146.7,184.3 L158.7,186.1 L170.6,187.9 L182.5,189.7 " stroke="rgb(200, 255, 55)"/> <path d="M182.5,189.7 L194.4,191.5 L206.4,193.3 " stroke="rgb(184, 255, 71)"/> <path d="M206.4,193.3 L218.3,195.1 L230.2,196.9 " stroke="rgb(168, 255, 87)"/> <path d="M230.2,196.9 L242.2,198.7 L254.1,200.5 " stroke="rgb(152, 255, 103)"/> <path d="M254.1,200.5 L266.0,202.2 L277.9,204.0 L289.8,205.8 " stroke="rgb(136, 255, 119)"/> <path d="M289.8,205.8 L301.7,207.6 L313.6,209.4 " stroke="rgb(119, 255, 136)"/> <path d="M313.6,209.4 L325.6,211.2 L337.5,213.0 " stroke="rgb(103, 255, 152)"/> <path d="M337.5,213.0 L349.4,214.8 L361.3,216.6 " stroke="rgb( 87, 255, 168)"/> <path d="M361.3,216.6 L373.3,218.4 L385.2,220.2 L397.1,222.0 " stroke="rgb( 71, 255, 184)"/> <path d="M397.1,222.0 L409.1,223.8 L421.0,225.5 " stroke="rgb( 55, 255, 200)"/> <path d="M132.7,187.9 L144.6,189.7 L156.6,191.5 " stroke="rgb(217, 255, 38)"/> <path d="M156.6,191.5 L168.5,193.3 L180.4,195.1 " stroke="rgb(200, 255, 55)"/> <path d="M180.4,195.1 L192.3,196.9 L204.3,198.7 " stroke="rgb(184, 255, 71)"/> <path d="M204.3,198.7 L216.2,200.5 L228.1,202.2 L240.1,204.0 " stroke="rgb(168, 255, 87)"/> <path d="M240.1,204.0 L252.0,205.8 L263.9,207.6 " stroke="rgb(152, 255, 103)"/> <path d="M263.9,207.6 L275.8,209.4 L287.7,211.2 " stroke="rgb(136, 255, 119)"/> <path d="M287.7,211.2 L299.6,213.0 L311.5,214.7 " stroke="rgb(119, 255, 136)"/> <path d="M311.5,214.7 L323.5,216.5 L335.4,218.3 L347.3,220.1 " stroke="rgb(103, 255, 152)"/> <path d="M347.3,220.1 L359.2,221.9 L371.2,223.7 " stroke="rgb( 87, 255, 168)"/> <path d="M371.2,223.7 L383.1,225.5 L395.0,227.3 " stroke="rgb( 71, 255, 184)"/> <path d="M395.0,227.3 L407.0,229.1 L418.9,230.9 " stroke="rgb( 55, 255, 200)"/> <path d="M130.6,193.3 L142.5,195.1 L154.5,196.9 " stroke="rgb(217, 255, 38)"/> <path d="M154.5,196.9 L166.4,198.7 L178.3,200.5 L190.2,202.2 " stroke="rgb(200, 255, 55)"/> <path d="M190.2,202.2 L202.2,204.0 L214.1,205.7 " stroke="rgb(184, 255, 71)"/> <path d="M214.1,205.7 L226.0,207.5 L238.0,209.3 " stroke="rgb(168, 255, 87)"/> <path d="M238.0,209.3 L249.9,211.1 L261.8,212.9 " stroke="rgb(152, 255, 103)"/> <path d="M261.8,212.9 L273.7,214.7 L285.6,216.5 L297.5,218.3 " stroke="rgb(136, 255, 119)"/> <path d="M297.5,218.3 L309.4,220.1 L321.4,221.9 " stroke="rgb(119, 255, 136)"/> <path d="M321.4,221.9 L333.3,223.7 L345.2,225.5 " stroke="rgb(103, 255, 152)"/> <path d="M345.2,225.5 L357.1,227.3 L369.1,229.1 " stroke="rgb( 87, 255, 168)"/> <path d="M369.1,229.1 L381.0,230.9 L392.9,232.7 L404.9,234.5 " stroke="rgb( 71, 255, 184)"/> <path d="M404.9,234.5 L416.8,236.3 " stroke="rgb( 55, 255, 200)"/> <path d="M128.5,198.6 L140.4,200.4 " stroke="rgb(233, 255, 22)"/> <path d="M140.4,200.4 L152.4,202.1 L164.3,203.9 " stroke="rgb(217, 255, 38)"/> <path d="M164.3,203.9 L176.2,205.7 L188.1,207.5 " stroke="rgb(200, 255, 55)"/> <path d="M188.1,207.5 L200.1,209.3 L212.0,211.1 " stroke="rgb(184, 255, 71)"/> <path d="M212.0,211.1 L223.9,212.9 L235.9,214.7 L247.8,216.5 " stroke="rgb(168, 255, 87)"/> <path d="M247.8,216.5 L259.7,218.3 L271.6,220.1 " stroke="rgb(152, 255, 103)"/> <path d="M271.6,220.1 L283.5,221.9 L295.4,223.7 " stroke="rgb(136, 255, 119)"/> <path d="M295.4,223.7 L307.3,225.5 L319.3,227.3 " stroke="rgb(119, 255, 136)"/> <path d="M319.3,227.3 L331.2,229.1 L343.1,230.9 L355.0,232.7 " stroke="rgb(103, 255, 152)"/> <path d="M355.0,232.7 L367.0,234.5 L378.9,236.3 " stroke="rgb( 87, 255, 168)"/> <path d="M378.9,236.3 L390.8,238.1 L402.8,239.9 " stroke="rgb( 71, 255, 184)"/> <path d="M402.8,239.9 L414.7,241.7 " stroke="rgb( 55, 255, 200)"/> <path d="M126.4,203.9 L138.3,205.7 " stroke="rgb(233, 255, 22)"/> <path d="M138.3,205.7 L150.2,207.5 L162.2,209.3 " stroke="rgb(217, 255, 38)"/> <path d="M162.2,209.3 L174.1,211.1 L186.0,212.9 L198.0,214.7 " stroke="rgb(200, 255, 55)"/> <path d="M198.0,214.7 L209.9,216.5 L221.8,218.3 " stroke="rgb(184, 255, 71)"/> <path d="M221.8,218.3 L233.7,220.1 L245.7,221.9 " stroke="rgb(168, 255, 87)"/> <path d="M245.7,221.9 L257.6,223.7 L269.5,225.5 " stroke="rgb(152, 255, 103)"/> <path d="M269.5,225.5 L281.4,227.3 L293.3,229.1 L305.2,230.9 " stroke="rgb(136, 255, 119)"/> <path d="M305.2,230.9 L317.1,232.7 L329.1,234.5 " stroke="rgb(119, 255, 136)"/> <path d="M329.1,234.5 L341.0,236.3 L352.9,238.1 " stroke="rgb(103, 255, 152)"/> <path d="M352.9,238.1 L364.9,239.9 L376.8,241.7 " stroke="rgb( 87, 255, 168)"/> <path d="M376.8,241.7 L388.7,243.5 L400.6,245.3 L412.6,247.0 " stroke="rgb( 71, 255, 184)"/> <path d="M124.3,209.3 L136.2,211.1 L148.1,212.9 " stroke="rgb(233, 255, 22)"/> <path d="M148.1,212.9 L160.1,214.7 L172.0,216.5 " stroke="rgb(217, 255, 38)"/> <path d="M172.0,216.5 L183.9,218.3 L195.9,220.1 " stroke="rgb(200, 255, 55)"/> <path d="M195.9,220.1 L207.8,221.9 L219.7,223.7 " stroke="rgb(184, 255, 71)"/> <path d="M219.7,223.7 L231.6,225.5 L243.6,227.3 L255.5,229.1 " stroke="rgb(168, 255, 87)"/> <path d="M255.5,229.1 L267.4,230.9 L279.4,232.7 " stroke="rgb(152, 255, 103)"/> <path d="M279.4,232.7 L291.2,234.5 L303.1,236.2 " stroke="rgb(136, 255, 119)"/> <path d="M303.1,236.2 L315.0,238.0 L327.0,239.8 " stroke="rgb(119, 255, 136)"/> <path d="M327.0,239.8 L338.9,241.6 L350.8,243.4 L362.8,245.2 " stroke="rgb(103, 255, 152)"/> <path d="M362.8,245.2 L374.7,247.0 L386.6,248.8 " stroke="rgb( 87, 255, 168)"/> <path d="M386.6,248.8 L398.5,250.6 L410.5,252.4 " stroke="rgb( 71, 255, 184)"/> <path d="M122.2,214.7 L134.1,216.5 L146.0,218.3 " stroke="rgb(233, 255, 22)"/> <path d="M146.0,218.3 L158.0,220.1 L169.9,221.9 " stroke="rgb(217, 255, 38)"/> <path d="M169.9,221.9 L181.8,223.7 L193.8,225.5 L205.7,227.2 " stroke="rgb(200, 255, 55)"/> <path d="M205.7,227.2 L217.6,229.0 L229.5,230.8 " stroke="rgb(184, 255, 71)"/> <path d="M229.5,230.8 L241.5,232.6 L253.4,234.4 " stroke="rgb(168, 255, 87)"/> <path d="M253.4,234.4 L265.3,236.2 L277.3,238.0 " stroke="rgb(152, 255, 103)"/> <path d="M277.3,238.0 L289.1,239.8 L301.0,241.6 L312.9,243.4 " stroke="rgb(136, 255, 119)"/> <path d="M312.9,243.4 L324.9,245.2 L336.8,247.0 " stroke="rgb(119, 255, 136)"/> <path d="M336.8,247.0 L348.7,248.8 L360.7,250.6 " stroke="rgb(103, 255, 152)"/> <path d="M360.7,250.6 L372.6,252.4 L384.5,254.2 " stroke="rgb( 87, 255, 168)"/> <path d="M384.5,254.2 L396.4,256.0 L408.4,257.8 " stroke="rgb( 71, 255, 184)"/> <path d="M120.1,220.0 L132.0,221.8 L143.9,223.6 L155.9,225.4 " stroke="rgb(233, 255, 22)"/> <path d="M155.9,225.4 L167.8,227.2 L179.7,229.0 " stroke="rgb(217, 255, 38)"/> <path d="M179.7,229.0 L191.7,230.8 L203.6,232.6 " stroke="rgb(200, 255, 55)"/> <path d="M203.6,232.6 L215.5,234.4 L227.4,236.2 " stroke="rgb(184, 255, 71)"/> <path d="M227.4,236.2 L239.4,238.0 L251.3,239.8 L263.2,241.6 " stroke="rgb(168, 255, 87)"/> <path d="M263.2,241.6 L275.2,243.4 L287.0,245.2 " stroke="rgb(152, 255, 103)"/> <path d="M287.0,245.2 L298.9,247.0 L310.8,248.8 " stroke="rgb(136, 255, 119)"/> <path d="M310.8,248.8 L322.8,250.6 L334.7,252.4 " stroke="rgb(119, 255, 136)"/> <path d="M334.7,252.4 L346.6,254.2 L358.6,256.0 L370.5,257.8 " stroke="rgb(103, 255, 152)"/> <path d="M370.5,257.8 L382.4,259.6 L394.3,261.4 " stroke="rgb( 87, 255, 168)"/> <path d="M394.3,261.4 L406.3,263.2 " stroke="rgb( 71, 255, 184)"/> <path d="M118.0,225.4 L129.9,227.2 " stroke="rgb(249, 255, 6)"/> <path d="M129.9,227.2 L141.8,229.0 L153.8,230.8 " stroke="rgb(233, 255, 22)"/> <path d="M153.8,230.8 L165.7,232.6 L177.6,234.4 " stroke="rgb(217, 255, 38)"/> <path d="M177.6,234.4 L189.5,236.2 L201.5,238.0 L213.4,239.8 " stroke="rgb(200, 255, 55)"/> <path d="M213.4,239.8 L225.3,241.6 L237.3,243.4 " stroke="rgb(184, 255, 71)"/> <path d="M237.3,243.4 L249.2,245.2 L261.1,247.0 " stroke="rgb(168, 255, 87)"/> <path d="M261.1,247.0 L273.0,248.8 L284.9,250.6 " stroke="rgb(152, 255, 103)"/> <path d="M284.9,250.6 L296.8,252.4 L308.7,254.2 L320.7,256.0 " stroke="rgb(136, 255, 119)"/> <path d="M320.7,256.0 L332.6,257.8 L344.5,259.6 " stroke="rgb(119, 255, 136)"/> <path d="M344.5,259.6 L356.4,261.4 L368.4,263.2 " stroke="rgb(103, 255, 152)"/> <path d="M368.4,263.2 L380.3,265.0 L392.2,266.8 " stroke="rgb( 87, 255, 168)"/> <path d="M392.2,266.8 L404.2,268.5 " stroke="rgb( 71, 255, 184)"/> <path d="M115.9,230.8 L127.8,232.6 " stroke="rgb(249, 255, 6)"/> <path d="M127.8,232.6 L139.7,234.4 L151.7,236.2 L163.6,238.0 " stroke="rgb(233, 255, 22)"/> <path d="M163.6,238.0 L175.5,239.8 L187.4,241.6 " stroke="rgb(217, 255, 38)"/> <path d="M187.4,241.6 L199.4,243.4 L211.3,245.2 " stroke="rgb(200, 255, 55)"/> <path d="M211.3,245.2 L223.2,247.0 L235.2,248.8 " stroke="rgb(184, 255, 71)"/> <path d="M235.2,248.8 L247.1,250.6 L259.0,252.4 L270.9,254.2 " stroke="rgb(168, 255, 87)"/> <path d="M270.9,254.2 L282.8,256.0 L294.7,257.8 " stroke="rgb(152, 255, 103)"/> <path d="M294.7,257.8 L306.6,259.5 L318.6,261.3 " stroke="rgb(136, 255, 119)"/> <path d="M318.6,261.3 L330.5,263.1 L342.4,264.9 " stroke="rgb(119, 255, 136)"/> <path d="M342.4,264.9 L354.3,266.7 L366.3,268.5 L378.2,270.3 " stroke="rgb(103, 255, 152)"/> <path d="M378.2,270.3 L390.1,272.1 L402.1,273.9 " stroke="rgb( 87, 255, 168)"/> <path d="M113.8,236.2 L125.7,238.0 L137.6,239.8 " stroke="rgb(249, 255, 6)"/> <path d="M137.6,239.8 L149.6,241.6 L161.5,243.4 " stroke="rgb(233, 255, 22)"/> <path d="M161.5,243.4 L173.4,245.2 L185.3,247.0 " stroke="rgb(217, 255, 38)"/> <path d="M185.3,247.0 L197.3,248.7 L209.2,250.5 L221.1,252.3 " stroke="rgb(200, 255, 55)"/> <path d="M221.1,252.3 L233.1,254.1 L245.0,255.9 " stroke="rgb(184, 255, 71)"/> <path d="M245.0,255.9 L256.9,257.7 L268.8,259.5 " stroke="rgb(168, 255, 87)"/> <path d="M268.8,259.5 L280.7,261.3 L292.6,263.1 " stroke="rgb(152, 255, 103)"/> <path d="M292.6,263.1 L304.5,264.9 L316.5,266.7 L328.4,268.5 " stroke="rgb(136, 255, 119)"/> <path d="M328.4,268.5 L340.3,270.3 L352.2,272.1 " stroke="rgb(119, 255, 136)"/> <path d="M352.2,272.1 L364.2,273.9 L376.1,275.7 " stroke="rgb(103, 255, 152)"/> <path d="M376.1,275.7 L388.0,277.5 L400.0,279.3 " stroke="rgb( 87, 255, 168)"/> <path d="M111.7,241.5 L123.6,243.3 L135.5,245.1 " stroke="rgb(249, 255, 6)"/> <path d="M135.5,245.1 L147.5,246.9 L159.4,248.7 L171.3,250.5 " stroke="rgb(233, 255, 22)"/> <path d="M171.3,250.5 L183.2,252.3 L195.2,254.1 " stroke="rgb(217, 255, 38)"/> <path d="M195.2,254.1 L207.1,255.9 L219.0,257.7 " stroke="rgb(200, 255, 55)"/> <path d="M219.0,257.7 L231.0,259.5 L242.9,261.3 " stroke="rgb(184, 255, 71)"/> <path d="M242.9,261.3 L254.8,263.1 L266.7,264.9 L278.7,266.7 " stroke="rgb(168, 255, 87)"/> <path d="M278.7,266.7 L290.5,268.5 L302.4,270.3 " stroke="rgb(152, 255, 103)"/> <path d="M302.4,270.3 L314.4,272.1 L326.3,273.9 " stroke="rgb(136, 255, 119)"/> <path d="M326.3,273.9 L338.2,275.7 L350.1,277.5 " stroke="rgb(119, 255, 136)"/> <path d="M350.1,277.5 L362.1,279.3 L374.0,281.1 L385.9,282.9 " stroke="rgb(103, 255, 152)"/> <path d="M385.9,282.9 L397.9,284.7 " stroke="rgb( 87, 255, 168)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>gnuplot_plot_3a</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M162.1,119.9 L160.0,125.6 L157.9,131.3 L155.8,137.0 L153.7,142.7 L151.6,148.3 L149.5,154.0 L147.4,159.7 L145.3,165.4 L143.2,171.1 L141.1,176.8 " stroke="rgb(103, 255, 152)"/> <path d="M141.1,176.8 L139.0,182.5 L136.9,188.1 L134.8,193.8 L132.7,199.5 L130.6,205.1 L128.5,210.8 L126.4,216.5 L124.3,222.2 L122.2,227.9 L120.1,233.5 L118.0,239.2 L115.9,244.9 L113.8,250.6 L111.7,256.3 " stroke="rgb(119, 255, 136)"/> <path d="M174.1,121.0 L172.0,126.6 L169.9,132.3 L167.8,138.0 L165.7,143.7 L163.6,149.4 L161.5,155.1 L159.4,160.8 L157.2,166.5 L155.1,172.1 L153.0,177.8 L150.9,183.5 " stroke="rgb(103, 255, 152)"/> <path d="M150.9,183.5 L148.8,189.2 L146.7,194.9 L144.6,200.6 L142.5,206.2 L140.4,211.9 L138.3,217.5 L136.2,223.2 L134.1,228.9 L132.0,234.6 L129.9,240.3 L127.8,246.0 L125.7,251.7 L123.6,257.4 " stroke="rgb(119, 255, 136)"/> <path d="M186.0,122.0 L183.9,127.7 L181.8,133.4 L179.7,139.1 L177.6,144.8 L175.5,150.4 L173.4,156.1 L171.3,161.8 L169.2,167.5 L167.1,173.2 L165.0,178.9 L162.9,184.6 " stroke="rgb(103, 255, 152)"/> <path d="M162.9,184.6 L160.8,190.3 L158.7,195.9 L156.6,201.5 L154.5,207.2 L152.4,212.9 L150.2,218.6 L148.1,224.3 L146.0,230.0 L143.9,235.7 L141.8,241.3 L139.7,247.0 L137.6,252.7 L135.5,258.4 " stroke="rgb(119, 255, 136)"/> <path d="M197.9,123.1 L195.8,128.8 L193.7,134.4 L191.6,140.1 L189.5,145.8 L187.4,151.5 L185.3,157.2 L183.2,162.9 L181.1,168.6 L179.0,174.3 L176.9,179.9 L174.8,185.6 L172.7,191.3 " stroke="rgb(103, 255, 152)"/> <path d="M172.7,191.3 L170.6,197.0 L168.5,202.6 L166.4,208.3 L164.3,214.0 L162.2,219.7 L160.1,225.3 L158.0,231.0 L155.9,236.7 L153.8,242.4 L151.7,248.1 L149.6,253.8 L147.5,259.5 " stroke="rgb(119, 255, 136)"/> <path d="M209.9,124.1 L207.8,129.8 L205.7,135.5 L203.6,141.2 L201.4,146.9 L199.3,152.6 L197.2,158.2 L195.1,163.9 L193.0,169.6 L190.9,175.3 L188.8,181.0 L186.7,186.7 L184.6,192.4 " stroke="rgb(103, 255, 152)"/> <path d="M184.6,192.4 L182.5,198.1 L180.4,203.6 L178.3,209.3 L176.2,215.0 L174.1,220.7 L172.0,226.4 L169.9,232.1 L167.8,237.8 L165.7,243.5 L163.6,249.1 L161.5,254.8 L159.4,260.5 " stroke="rgb(119, 255, 136)"/> <path d="M221.8,125.2 L219.7,130.9 L217.6,136.6 L215.5,142.2 L213.4,147.9 L211.3,153.6 L209.2,159.3 L207.1,165.0 L205.0,170.7 L202.9,176.4 L200.8,182.1 L198.7,187.7 L196.6,193.4 L194.4,199.1 " stroke="rgb(103, 255, 152)"/> <path d="M194.4,199.1 L192.3,204.7 L190.2,210.4 L188.1,216.1 L186.0,221.8 L183.9,227.5 L181.8,233.1 L179.7,238.8 L177.6,244.5 L175.5,250.2 L173.4,255.9 L171.3,261.6 " stroke="rgb(119, 255, 136)"/> <path d="M233.7,126.2 L231.6,131.9 L229.5,137.6 L227.4,143.3 L225.3,149.0 L223.2,154.7 L221.1,160.4 L219.0,166.0 L216.9,171.7 L214.8,177.4 L212.7,183.1 L210.6,188.8 L208.5,194.5 L206.4,200.2 " stroke="rgb(103, 255, 152)"/> <path d="M206.4,200.2 L204.3,205.8 L202.2,211.4 L200.1,217.1 L198.0,222.8 L195.9,228.5 L193.8,234.2 L191.7,239.9 L189.5,245.6 L187.4,251.3 L185.3,256.9 L183.2,262.6 " stroke="rgb(119, 255, 136)"/> <path d="M245.6,127.3 L243.5,133.0 L241.4,138.7 L239.3,144.4 L237.2,150.0 L235.1,155.7 L233.0,161.4 L230.9,167.1 L228.8,172.8 L226.7,178.5 L224.6,184.2 L222.5,189.9 L220.4,195.5 L218.3,201.1 L216.2,206.8 " stroke="rgb(103, 255, 152)"/> <path d="M216.2,206.8 L214.1,212.5 L212.0,218.2 L209.9,223.9 L207.8,229.6 L205.7,235.2 L203.6,240.9 L201.5,246.6 L199.4,252.3 L197.3,258.0 L195.2,263.7 " stroke="rgb(119, 255, 136)"/> <path d="M257.6,128.3 L255.5,134.0 L253.4,139.7 L251.3,145.4 L249.2,151.1 L247.1,156.8 L245.0,162.5 L242.9,168.2 L240.7,173.8 L238.6,179.5 L236.5,185.2 L234.4,190.9 L232.3,196.6 L230.2,202.2 L228.1,207.9 " stroke="rgb(103, 255, 152)"/> <path d="M228.1,207.9 L226.0,213.6 L223.9,219.2 L221.8,224.9 L219.7,230.6 L217.6,236.3 L215.5,242.0 L213.4,247.7 L211.3,253.4 L209.2,259.1 L207.1,264.7 " stroke="rgb(119, 255, 136)"/> <path d="M269.5,129.4 L267.4,135.1 L265.3,140.8 L263.2,146.5 L261.1,152.2 L259.0,157.8 L256.9,163.5 L254.8,169.2 L252.7,174.9 L250.6,180.6 L248.5,186.3 L246.4,192.0 L244.3,197.6 L242.2,203.2 L240.1,208.9 L238.0,214.6 " stroke="rgb(103, 255, 152)"/> <path d="M238.0,214.6 L235.9,220.3 L233.7,226.0 L231.6,231.7 L229.5,237.4 L227.4,243.0 L225.3,248.7 L223.2,254.4 L221.1,260.1 L219.0,265.8 " stroke="rgb(119, 255, 136)"/> <path d="M281.3,130.5 L279.3,136.1 L277.2,141.8 L275.1,147.5 L273.0,153.2 L270.9,158.9 L268.8,164.6 L266.7,170.3 L264.6,176.0 L262.5,181.6 L260.4,187.3 L258.3,193.0 L256.2,198.7 L254.1,204.3 L252.0,210.0 L249.9,215.7 " stroke="rgb(103, 255, 152)"/> <path d="M249.9,215.7 L247.8,221.4 L245.7,227.0 L243.6,232.7 L241.5,238.4 L239.4,244.1 L237.3,249.8 L235.2,255.5 L233.1,261.2 L231.0,266.9 " stroke="rgb(119, 255, 136)"/> <path d="M293.3,131.5 L291.2,137.2 L289.1,142.9 L287.0,148.6 L284.8,154.3 L282.7,159.9 L280.6,165.6 L278.6,171.3 L276.5,177.0 L274.4,182.7 L272.3,188.4 L270.2,194.1 L268.1,199.8 L266.0,205.3 L263.9,211.0 L261.8,216.7 L259.7,222.4 " stroke="rgb(103, 255, 152)"/> <path d="M259.7,222.4 L257.6,228.1 L255.5,233.8 L253.4,239.5 L251.3,245.2 L249.2,250.8 L247.1,256.5 L245.0,262.2 L242.9,267.9 " stroke="rgb(119, 255, 136)"/> <path d="M305.2,132.6 L303.1,138.3 L301.0,143.9 L298.9,149.6 L296.8,155.3 L294.7,161.0 L292.6,166.7 L290.5,172.4 L288.4,178.1 L286.3,183.8 L284.2,189.4 L282.1,195.1 L280.0,200.8 L277.9,206.4 L275.8,212.1 L273.7,217.8 L271.6,223.5 " stroke="rgb(103, 255, 152)"/> <path d="M271.6,223.5 L269.5,229.2 L267.4,234.8 L265.3,240.5 L263.2,246.2 L261.1,251.9 L259.0,257.6 L256.9,263.3 L254.8,269.0 " stroke="rgb(119, 255, 136)"/> <path d="M317.1,133.6 L315.0,139.3 L312.9,145.0 L310.8,150.7 L308.7,156.4 L306.6,162.1 L304.5,167.7 L302.4,173.4 L300.3,179.1 L298.2,184.8 L296.1,190.5 L294.0,196.2 L291.9,201.8 L289.8,207.5 L287.7,213.1 L285.6,218.8 L283.5,224.5 L281.4,230.2 " stroke="rgb(103, 255, 152)"/> <path d="M281.4,230.2 L279.4,235.9 L277.3,241.6 L275.2,247.3 L273.0,253.0 L270.9,258.6 L268.8,264.3 L266.7,270.0 " stroke="rgb(119, 255, 136)"/> <path d="M329.0,134.7 L326.9,140.4 L324.8,146.1 L322.7,151.7 L320.6,157.4 L318.5,163.1 L316.4,168.8 L314.3,174.5 L312.2,180.2 L310.1,185.9 L308.0,191.6 L305.9,197.2 L303.8,202.8 L301.7,208.5 L299.6,214.2 L297.5,219.9 L295.4,225.6 L293.3,231.3 " stroke="rgb(103, 255, 152)"/> <path d="M293.3,231.3 L291.2,237.0 L289.1,242.6 L287.0,248.3 L284.9,254.0 L282.8,259.7 L280.7,265.4 L278.7,271.1 " stroke="rgb(119, 255, 136)"/> <path d="M341.0,135.7 L338.9,141.4 L336.8,147.1 L334.7,152.8 L332.6,158.5 L330.5,164.2 L328.4,169.9 L326.3,175.5 L324.1,181.2 L322.0,186.9 L319.9,192.6 L317.8,198.3 L315.7,203.9 L313.6,209.6 L311.5,215.3 L309.4,220.9 L307.3,226.6 L305.2,232.3 L303.1,238.0 " stroke="rgb(103, 255, 152)"/> <path d="M303.1,238.0 L301.0,243.7 L298.9,249.4 L296.8,255.1 L294.7,260.8 L292.6,266.4 L290.5,272.1 " stroke="rgb(119, 255, 136)"/> <path d="M352.9,136.8 L350.8,142.5 L348.7,148.2 L346.6,153.9 L344.5,159.5 L342.4,165.2 L340.3,170.9 L338.2,176.6 L336.1,182.3 L334.0,188.0 L331.9,193.7 L329.8,199.4 L327.7,204.9 L325.6,210.6 L323.5,216.3 L321.4,222.0 L319.3,227.7 L317.1,233.4 L315.0,239.1 " stroke="rgb(103, 255, 152)"/> <path d="M315.0,239.1 L312.9,244.7 L310.8,250.4 L308.7,256.1 L306.6,261.8 L304.5,267.5 L302.4,273.2 " stroke="rgb(119, 255, 136)"/> <path d="M364.8,137.8 L362.7,143.5 L360.6,149.2 L358.5,154.9 L356.4,160.6 L354.3,166.3 L352.2,172.0 L350.1,177.7 L348.0,183.3 L345.9,189.0 L343.8,194.7 L341.7,200.4 L339.6,206.0 L337.5,211.7 L335.4,217.4 L333.3,223.1 L331.2,228.7 L329.1,234.4 L327.0,240.1 L324.9,245.8 " stroke="rgb(103, 255, 152)"/> <path d="M324.9,245.8 L322.8,251.5 L320.7,257.2 L318.6,262.9 L316.5,268.6 L314.4,274.2 " stroke="rgb(119, 255, 136)"/> <path d="M376.8,138.9 L374.7,144.6 L372.6,150.3 L370.5,156.0 L368.3,161.7 L366.2,167.3 L364.1,173.0 L362.0,178.7 L359.9,184.4 L357.8,190.1 L355.7,195.8 L353.6,201.4 L351.5,207.0 L349.4,212.7 L347.3,218.4 L345.2,224.1 L343.1,229.8 L341.0,235.5 L338.9,241.2 L336.8,246.9 " stroke="rgb(103, 255, 152)"/> <path d="M336.8,246.9 L334.7,252.5 L332.6,258.2 L330.5,263.9 L328.4,269.6 L326.3,275.3 " stroke="rgb(119, 255, 136)"/> <path d="M388.7,140.0 L386.6,145.6 L384.5,151.3 L382.4,157.0 L380.3,162.7 L378.2,168.4 L376.1,174.1 L374.0,179.8 L371.9,185.5 L369.8,191.1 L367.7,196.8 L365.6,202.4 L363.4,208.1 L361.3,213.8 L359.2,219.5 L357.1,225.2 L355.0,230.9 L352.9,236.5 L350.8,242.2 L348.7,247.9 L346.6,253.6 " stroke="rgb(103, 255, 152)"/> <path d="M346.6,253.6 L344.5,259.3 L342.4,265.0 L340.3,270.7 L338.2,276.4 " stroke="rgb(119, 255, 136)"/> <path d="M400.6,141.0 L398.5,146.7 L396.4,152.4 L394.3,158.1 L392.2,163.8 L390.1,169.4 L388.0,175.1 L385.9,180.8 L383.8,186.5 L381.7,192.2 L379.6,197.9 L377.5,203.5 L375.4,209.2 L373.3,214.8 L371.2,220.5 L369.1,226.2 L367.0,231.9 L364.9,237.6 L362.8,243.3 L360.7,249.0 L358.6,254.7 " stroke="rgb(103, 255, 152)"/> <path d="M358.6,254.7 L356.4,260.3 L354.3,266.0 L352.2,271.7 L350.1,277.4 " stroke="rgb(119, 255, 136)"/> <path d="M412.5,142.1 L410.4,147.8 L408.3,153.4 L406.2,159.1 L404.1,164.8 L402.0,170.5 L399.9,176.2 L397.8,181.9 L395.7,187.6 L393.6,193.3 L391.5,198.9 L389.4,204.5 L387.3,210.2 L385.2,215.9 L383.1,221.6 L381.0,227.3 L378.9,233.0 L376.8,238.7 L374.7,244.3 L372.6,250.0 L370.5,255.7 L368.4,261.4 " stroke="rgb(103, 255, 152)"/> <path d="M368.4,261.4 L366.3,267.1 L364.2,272.8 L362.1,278.5 " stroke="rgb(119, 255, 136)"/> <path d="M424.5,143.1 L422.4,148.8 L420.3,154.5 L418.2,160.2 L416.1,165.9 L414.0,171.6 L411.9,177.2 L409.8,182.9 L407.6,188.6 L405.5,194.3 L403.4,200.0 L401.3,205.6 L399.2,211.3 L397.1,217.0 L395.0,222.6 L392.9,228.3 L390.8,234.0 L388.7,239.7 L386.6,245.4 L384.5,251.1 L382.4,256.8 L380.3,262.5 " stroke="rgb(103, 255, 152)"/> <path d="M380.3,262.5 L378.2,268.1 L376.1,273.8 L374.0,279.5 " stroke="rgb(119, 255, 136)"/> <path d="M436.4,144.2 L434.3,149.9 L432.2,155.6 L430.1,161.2 L428.0,166.9 L425.9,172.6 L423.8,178.3 L421.7,184.0 L419.6,189.7 L417.5,195.4 L415.4,201.0 L413.3,206.6 L411.2,212.3 L409.1,218.0 L407.0,223.7 L404.9,229.4 L402.8,235.1 L400.6,240.8 L398.5,246.5 L396.4,252.1 L394.3,257.8 L392.2,263.5 L390.1,269.2 " stroke="rgb(103, 255, 152)"/> <path d="M390.1,269.2 L388.0,274.9 L385.9,280.6 " stroke="rgb(119, 255, 136)"/> <path d="M448.3,145.2 L446.2,150.9 L444.1,156.6 L442.0,162.3 L439.9,168.0 L437.8,173.7 L435.7,179.4 L433.6,185.0 L431.5,190.7 L429.4,196.4 L427.3,202.0 L425.2,207.7 L423.1,213.4 L421.0,219.1 L418.9,224.8 L416.8,230.4 L414.7,236.1 L412.6,241.8 L410.5,247.5 L408.4,253.2 L406.3,258.9 L404.2,264.6 L402.1,270.3 " stroke="rgb(103, 255, 152)"/> <path d="M402.1,270.3 L400.0,275.9 L397.9,281.6 " stroke="rgb(119, 255, 136)"/> <path d="M162.1,119.9 L174.1,121.0 L186.0,122.0 L197.9,123.1 L209.9,124.1 L221.8,125.2 L233.7,126.2 L245.6,127.3 L257.6,128.3 L269.5,129.4 L281.3,130.5 L293.3,131.5 L305.2,132.6 L317.1,133.6 L329.0,134.7 L341.0,135.7 L352.9,136.8 L364.8,137.8 L376.8,138.9 L388.7,140.0 L400.6,141.0 L412.5,142.1 L424.5,143.1 L436.4,144.2 L448.3,145.2 M160.0,125.6 L172.0,126.6 L183.9,127.7 L195.8,128.8 L207.8,129.8 L219.7,130.9 L231.6,131.9 L243.5,133.0 L255.5,134.0 L267.4,135.1 L279.3,136.1 L291.2,137.2 L303.1,138.3 L315.0,139.3 L326.9,140.4 L338.9,141.4 L350.8,142.5 L362.7,143.5 L374.7,144.6 L386.6,145.6 L398.5,146.7 L410.4,147.8 L422.4,148.8 L434.3,149.9 L446.2,150.9 M157.9,131.3 L169.9,132.3 L181.8,133.4 L193.7,134.4 L205.7,135.5 L217.6,136.6 L229.5,137.6 L241.4,138.7 L253.4,139.7 L265.3,140.8 L277.2,141.8 L289.1,142.9 L301.0,143.9 L312.9,145.0 L324.8,146.1 L336.8,147.1 L348.7,148.2 L360.6,149.2 L372.6,150.3 L384.5,151.3 L396.4,152.4 L408.3,153.4 L420.3,154.5 L432.2,155.6 L444.1,156.6 M155.8,137.0 L167.8,138.0 L179.7,139.1 L191.6,140.1 L203.6,141.2 L215.5,142.2 L227.4,143.3 L239.3,144.4 L251.3,145.4 L263.2,146.5 L275.1,147.5 L287.0,148.6 L298.9,149.6 L310.8,150.7 L322.7,151.7 L334.7,152.8 L346.6,153.9 L358.5,154.9 L370.5,156.0 L382.4,157.0 L394.3,158.1 L406.2,159.1 L418.2,160.2 L430.1,161.2 L442.0,162.3 M153.7,142.7 L165.7,143.7 L177.6,144.8 L189.5,145.8 L201.4,146.9 L213.4,147.9 L225.3,149.0 L237.2,150.0 L249.2,151.1 L261.1,152.2 L273.0,153.2 L284.8,154.3 L296.8,155.3 L308.7,156.4 L320.6,157.4 L332.6,158.5 L344.5,159.5 L356.4,160.6 L368.3,161.7 L380.3,162.7 L392.2,163.8 L404.1,164.8 L416.1,165.9 L428.0,166.9 L439.9,168.0 M151.6,148.3 L163.6,149.4 L175.5,150.4 L187.4,151.5 L199.3,152.6 L211.3,153.6 L223.2,154.7 L235.1,155.7 L247.1,156.8 L259.0,157.8 L270.9,158.9 L282.7,159.9 L294.7,161.0 L306.6,162.1 L318.5,163.1 L330.5,164.2 L342.4,165.2 L354.3,166.3 L366.2,167.3 L378.2,168.4 L390.1,169.4 L402.0,170.5 L414.0,171.6 L425.9,172.6 L437.8,173.7 M149.5,154.0 L161.5,155.1 L173.4,156.1 L185.3,157.2 L197.2,158.2 L209.2,159.3 L221.1,160.4 L233.0,161.4 L245.0,162.5 L256.9,163.5 L268.8,164.6 L280.6,165.6 L292.6,166.7 L304.5,167.7 L316.4,168.8 L328.4,169.9 L340.3,170.9 L352.2,172.0 L364.1,173.0 L376.1,174.1 L388.0,175.1 L399.9,176.2 L411.9,177.2 L423.8,178.3 L435.7,179.4 M147.4,159.7 L159.4,160.8 L171.3,161.8 L183.2,162.9 L195.1,163.9 L207.1,165.0 L219.0,166.0 L230.9,167.1 L242.9,168.2 L254.8,169.2 L266.7,170.3 L278.6,171.3 L290.5,172.4 L302.4,173.4 L314.3,174.5 L326.3,175.5 L338.2,176.6 L350.1,177.7 L362.0,178.7 L374.0,179.8 L385.9,180.8 L397.8,181.9 L409.8,182.9 L421.7,184.0 L433.6,185.0 M145.3,165.4 L157.2,166.5 L169.2,167.5 L181.1,168.6 L193.0,169.6 L205.0,170.7 L216.9,171.7 L228.8,172.8 L240.7,173.8 L252.7,174.9 L264.6,176.0 L276.5,177.0 L288.4,178.1 L300.3,179.1 L312.2,180.2 L324.1,181.2 L336.1,182.3 L348.0,183.3 L359.9,184.4 L371.9,185.5 L383.8,186.5 L395.7,187.6 L407.6,188.6 L419.6,189.7 L431.5,190.7 M143.2,171.1 L155.1,172.1 L167.1,173.2 L179.0,174.3 L190.9,175.3 L202.9,176.4 L214.8,177.4 L226.7,178.5 L238.6,179.5 L250.6,180.6 L262.5,181.6 L274.4,182.7 L286.3,183.8 L298.2,184.8 L310.1,185.9 L322.0,186.9 L334.0,188.0 L345.9,189.0 L357.8,190.1 L369.8,191.1 L381.7,192.2 L393.6,193.3 L405.5,194.3 L417.5,195.4 L429.4,196.4 M141.1,176.8 L153.0,177.8 L165.0,178.9 L176.9,179.9 L188.8,181.0 L200.8,182.1 L212.7,183.1 L224.6,184.2 L236.5,185.2 L248.5,186.3 L260.4,187.3 L272.3,188.4 L284.2,189.4 L296.1,190.5 L308.0,191.6 L319.9,192.6 L331.9,193.7 L343.8,194.7 L355.7,195.8 L367.7,196.8 L379.6,197.9 L391.5,198.9 L403.4,200.0 L415.4,201.0 L427.3,202.0 " stroke="rgb(103, 255, 152)"/> <path d="M139.0,182.5 L150.9,183.5 " stroke="rgb(119, 255, 136)"/> <path d="M150.9,183.5 L162.9,184.6 L174.8,185.6 L186.7,186.7 L198.7,187.7 L210.6,188.8 L222.5,189.9 L234.4,190.9 L246.4,192.0 L258.3,193.0 L270.2,194.1 L282.1,195.1 L294.0,196.2 L305.9,197.2 L317.8,198.3 L329.8,199.4 L341.7,200.4 L353.6,201.4 L365.6,202.4 L377.5,203.5 L389.4,204.5 L401.3,205.6 L413.3,206.6 L425.2,207.7 " stroke="rgb(103, 255, 152)"/> <path d="M136.9,188.1 L148.8,189.2 L160.8,190.3 L172.7,191.3 " stroke="rgb(119, 255, 136)"/> <path d="M172.7,191.3 L184.6,192.4 L196.6,193.4 L208.5,194.5 L220.4,195.5 L232.3,196.6 L244.3,197.6 L256.2,198.7 L268.1,199.8 L280.0,200.8 L291.9,201.8 L303.8,202.8 L315.7,203.9 L327.7,204.9 L339.6,206.0 L351.5,207.0 L363.4,208.1 L375.4,209.2 L387.3,210.2 L399.2,211.3 L411.2,212.3 L423.1,213.4 " stroke="rgb(103, 255, 152)"/> <path d="M134.8,193.8 L146.7,194.9 L158.7,195.9 L170.6,197.0 L182.5,198.1 L194.4,199.1 " stroke="rgb(119, 255, 136)"/> <path d="M194.4,199.1 L206.4,200.2 L218.3,201.1 L230.2,202.2 L242.2,203.2 L254.1,204.3 L266.0,205.3 L277.9,206.4 L289.8,207.5 L301.7,208.5 L313.6,209.6 L325.6,210.6 L337.5,211.7 L349.4,212.7 L361.3,213.8 L373.3,214.8 L385.2,215.9 L397.1,217.0 L409.1,218.0 L421.0,219.1 " stroke="rgb(103, 255, 152)"/> <path d="M132.7,199.5 L144.6,200.6 L156.6,201.5 L168.5,202.6 L180.4,203.6 L192.3,204.7 L204.3,205.8 L216.2,206.8 " stroke="rgb(119, 255, 136)"/> <path d="M216.2,206.8 L228.1,207.9 L240.1,208.9 L252.0,210.0 L263.9,211.0 L275.8,212.1 L287.7,213.1 L299.6,214.2 L311.5,215.3 L323.5,216.3 L335.4,217.4 L347.3,218.4 L359.2,219.5 L371.2,220.5 L383.1,221.6 L395.0,222.6 L407.0,223.7 L418.9,224.8 " stroke="rgb(103, 255, 152)"/> <path d="M130.6,205.1 L142.5,206.2 L154.5,207.2 L166.4,208.3 L178.3,209.3 L190.2,210.4 L202.2,211.4 L214.1,212.5 L226.0,213.6 L238.0,214.6 " stroke="rgb(119, 255, 136)"/> <path d="M238.0,214.6 L249.9,215.7 L261.8,216.7 L273.7,217.8 L285.6,218.8 L297.5,219.9 L309.4,220.9 L321.4,222.0 L333.3,223.1 L345.2,224.1 L357.1,225.2 L369.1,226.2 L381.0,227.3 L392.9,228.3 L404.9,229.4 L416.8,230.4 " stroke="rgb(103, 255, 152)"/> <path d="M128.5,210.8 L140.4,211.9 L152.4,212.9 L164.3,214.0 L176.2,215.0 L188.1,216.1 L200.1,217.1 L212.0,218.2 L223.9,219.2 L235.9,220.3 L247.8,221.4 L259.7,222.4 " stroke="rgb(119, 255, 136)"/> <path d="M259.7,222.4 L271.6,223.5 L283.5,224.5 L295.4,225.6 L307.3,226.6 L319.3,227.7 L331.2,228.7 L343.1,229.8 L355.0,230.9 L367.0,231.9 L378.9,233.0 L390.8,234.0 L402.8,235.1 L414.7,236.1 " stroke="rgb(103, 255, 152)"/> <path d="M126.4,216.5 L138.3,217.5 L150.2,218.6 L162.2,219.7 L174.1,220.7 L186.0,221.8 L198.0,222.8 L209.9,223.9 L221.8,224.9 L233.7,226.0 L245.7,227.0 L257.6,228.1 L269.5,229.2 L281.4,230.2 " stroke="rgb(119, 255, 136)"/> <path d="M281.4,230.2 L293.3,231.3 L305.2,232.3 L317.1,233.4 L329.1,234.4 L341.0,235.5 L352.9,236.5 L364.9,237.6 L376.8,238.7 L388.7,239.7 L400.6,240.8 L412.6,241.8 " stroke="rgb(103, 255, 152)"/> <path d="M124.3,222.2 L136.2,223.2 L148.1,224.3 L160.1,225.3 L172.0,226.4 L183.9,227.5 L195.9,228.5 L207.8,229.6 L219.7,230.6 L231.6,231.7 L243.6,232.7 L255.5,233.8 L267.4,234.8 L279.4,235.9 L291.2,237.0 L303.1,238.0 " stroke="rgb(119, 255, 136)"/> <path d="M303.1,238.0 L315.0,239.1 L327.0,240.1 L338.9,241.2 L350.8,242.2 L362.8,243.3 L374.7,244.3 L386.6,245.4 L398.5,246.5 L410.5,247.5 " stroke="rgb(103, 255, 152)"/> <path d="M122.2,227.9 L134.1,228.9 L146.0,230.0 L158.0,231.0 L169.9,232.1 L181.8,233.1 L193.8,234.2 L205.7,235.2 L217.6,236.3 L229.5,237.4 L241.5,238.4 L253.4,239.5 L265.3,240.5 L277.3,241.6 L289.1,242.6 L301.0,243.7 L312.9,244.7 L324.9,245.8 " stroke="rgb(119, 255, 136)"/> <path d="M324.9,245.8 L336.8,246.9 L348.7,247.9 L360.7,249.0 L372.6,250.0 L384.5,251.1 L396.4,252.1 L408.4,253.2 " stroke="rgb(103, 255, 152)"/> <path d="M120.1,233.5 L132.0,234.6 L143.9,235.7 L155.9,236.7 L167.8,237.8 L179.7,238.8 L191.7,239.9 L203.6,240.9 L215.5,242.0 L227.4,243.0 L239.4,244.1 L251.3,245.2 L263.2,246.2 L275.2,247.3 L287.0,248.3 L298.9,249.4 L310.8,250.4 L322.8,251.5 L334.7,252.5 L346.6,253.6 " stroke="rgb(119, 255, 136)"/> <path d="M346.6,253.6 L358.6,254.7 L370.5,255.7 L382.4,256.8 L394.3,257.8 L406.3,258.9 " stroke="rgb(103, 255, 152)"/> <path d="M118.0,239.2 L129.9,240.3 L141.8,241.3 L153.8,242.4 L165.7,243.5 L177.6,244.5 L189.5,245.6 L201.5,246.6 L213.4,247.7 L225.3,248.7 L237.3,249.8 L249.2,250.8 L261.1,251.9 L273.0,253.0 L284.9,254.0 L296.8,255.1 L308.7,256.1 L320.7,257.2 L332.6,258.2 L344.5,259.3 L356.4,260.3 L368.4,261.4 " stroke="rgb(119, 255, 136)"/> <path d="M368.4,261.4 L380.3,262.5 L392.2,263.5 L404.2,264.6 " stroke="rgb(103, 255, 152)"/> <path d="M115.9,244.9 L127.8,246.0 L139.7,247.0 L151.7,248.1 L163.6,249.1 L175.5,250.2 L187.4,251.3 L199.4,252.3 L211.3,253.4 L223.2,254.4 L235.2,255.5 L247.1,256.5 L259.0,257.6 L270.9,258.6 L282.8,259.7 L294.7,260.8 L306.6,261.8 L318.6,262.9 L330.5,263.9 L342.4,265.0 L354.3,266.0 L366.3,267.1 L378.2,268.1 L390.1,269.2 " stroke="rgb(119, 255, 136)"/> <path d="M390.1,269.2 L402.1,270.3 " stroke="rgb(103, 255, 152)"/> <path d="M113.8,250.6 L125.7,251.7 L137.6,252.7 L149.6,253.8 L161.5,254.8 L173.4,255.9 L185.3,256.9 L197.3,258.0 L209.2,259.1 L221.1,260.1 L233.1,261.2 L245.0,262.2 L256.9,263.3 L268.8,264.3 L280.7,265.4 L292.6,266.4 L304.5,267.5 L316.5,268.6 L328.4,269.6 L340.3,270.7 L352.2,271.7 L364.2,272.8 L376.1,273.8 L388.0,274.9 L400.0,275.9 M111.7,256.3 L123.6,257.4 L135.5,258.4 L147.5,259.5 L159.4,260.5 L171.3,261.6 L183.2,262.6 L195.2,263.7 L207.1,264.7 L219.0,265.8 L231.0,266.9 L242.9,267.9 L254.8,269.0 L266.7,270.0 L278.7,271.1 L290.5,272.1 L302.4,273.2 L314.4,274.2 L326.3,275.3 L338.2,276.4 L350.1,277.4 L362.1,278.5 L374.0,279.5 L385.9,280.6 L397.9,281.6 " stroke="rgb(119, 255, 136)"/></g> + </g> + <g id="gnuplot_plot_4a"><title>gnuplot_plot_4a</title> +<g color="white" fill="none" stroke="rgb(119, 255, 136)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <use color="rgb( 0, 0, 255)" transform="translate(285.8,145.0) scale(9.00)" xlink:href="#gpPt5"/> +</g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 0, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M448.3,214.2 L397.9,352.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M111.7,328.2 L397.9,352.6 " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M397.9,352.6 L397.9,281.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(239.0,389.8)"> + <text><tspan font-family="{}">x1</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(507.1,296.6)"> + <text><tspan font-family="{}">x2</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(59.6,257.9) rotate(-90)"> + <text><tspan font-family="{}">x3</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_10/nohup.out b/lecture_10/nohup.out new file mode 100644 index 0000000..e69de29 diff --git a/lecture_10/octave-workspace b/lecture_10/octave-workspace new file mode 100644 index 0000000..8a9aba2 Binary files /dev/null and b/lecture_10/octave-workspace differ diff --git a/lecture_11/.ipynb_checkpoints/lecture_11-checkpoint.ipynb b/lecture_11/.ipynb_checkpoints/lecture_11-checkpoint.ipynb new file mode 100644 index 0000000..e2aa425 --- /dev/null +++ b/lecture_11/.ipynb_checkpoints/lecture_11-checkpoint.ipynb @@ -0,0 +1,699 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 18, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 19, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "What is the determinant of A?\n", + "\n", + "$A=\\left[ \\begin{array}{ccc}\n", + "10 & 2 & 1 \\\\\n", + "0 & 1 & 1 \\\\\n", + "0 & 0 & 10\\end{array} \\right]$\n", + "\n", + "" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# LU Decomposition\n", + "### efficient storage of matrices for solutions\n", + "\n", + "Considering the same solution set:\n", + "\n", + "$y=Ax$\n", + "\n", + "Assume that we can perform Gauss elimination and achieve this formula:\n", + "\n", + "$Ux=d$ \n", + "\n", + "Where, $U$ is an upper triangular matrix that we derived from Gauss elimination and $d$ is the set of dependent variables after Gauss elimination. \n", + "\n", + "Assume there is a lower triangular matrix, $L$, with ones on the diagonal and same dimensions of $U$ and the following is true:\n", + "\n", + "$L(Ux-d)=Ax-y=0$\n", + "\n", + "Now, $Ax=LUx$, so $A=LU$, and $y=Ld$.\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "1 & 3 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "f21=0.5\n", + "\n", + "A(2,1)=1-1 = 0 \n", + "\n", + "A(2,2)=3-0.5=2.5\n", + "\n", + "y(2)=1-0.5=0.5\n", + "\n", + "$L(Ux-d)=\n", + "\\left[ \\begin{array}{cc}\n", + "1 & 0 \\\\\n", + "0.5 & 1 \\end{array} \\right]\n", + "\\left(\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "0 & 2.5 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]-\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "0.5\\end{array}\\right]\\right)=0$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000\n", + " 0.50000 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 1.00000\n", + " 0.00000 2.50000\n", + "\n", + "ans =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "d =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + "\n", + "y =\n", + "\n", + " 1\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "L=[1,0;0.5,1]\n", + "U=[2,1;0,2.5]\n", + "L*U\n", + "\n", + "d=[1;0.5]\n", + "y=L*d" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Pivoting for LU factorization\n", + "\n", + "LU factorization uses the same method as Gauss elimination so it is also necessary to perform partial pivoting when creating the lower and upper triangular matrices. \n", + "\n", + "Matlab and Octave use pivoting in the command \n", + "\n", + "`[L,U,P]=lu(A)`\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "'lu' is a built-in function from the file libinterp/corefcn/lu.cc\n", + "\n", + " -- Built-in Function: [L, U] = lu (A)\n", + " -- Built-in Function: [L, U, P] = lu (A)\n", + " -- Built-in Function: [L, U, P, Q] = lu (S)\n", + " -- Built-in Function: [L, U, P, Q, R] = lu (S)\n", + " -- Built-in Function: [...] = lu (S, THRES)\n", + " -- Built-in Function: Y = lu (...)\n", + " -- Built-in Function: [...] = lu (..., \"vector\")\n", + " Compute the LU decomposition of A.\n", + "\n", + " If A is full subroutines from LAPACK are used and if A is sparse\n", + " then UMFPACK is used.\n", + "\n", + " The result is returned in a permuted form, according to the\n", + " optional return value P. For example, given the matrix 'a = [1, 2;\n", + " 3, 4]',\n", + "\n", + " [l, u, p] = lu (A)\n", + "\n", + " returns\n", + "\n", + " l =\n", + "\n", + " 1.00000 0.00000\n", + " 0.33333 1.00000\n", + "\n", + " u =\n", + "\n", + " 3.00000 4.00000\n", + " 0.00000 0.66667\n", + "\n", + " p =\n", + "\n", + " 0 1\n", + " 1 0\n", + "\n", + " The matrix is not required to be square.\n", + "\n", + " When called with two or three output arguments and a spare input\n", + " matrix, 'lu' does not attempt to perform sparsity preserving column\n", + " permutations. Called with a fourth output argument, the sparsity\n", + " preserving column transformation Q is returned, such that 'P * A *\n", + " Q = L * U'.\n", + "\n", + " Called with a fifth output argument and a sparse input matrix, 'lu'\n", + " attempts to use a scaling factor R on the input matrix such that 'P\n", + " * (R \\ A) * Q = L * U'. This typically leads to a sparser and more\n", + " stable factorization.\n", + "\n", + " An additional input argument THRES, that defines the pivoting\n", + " threshold can be given. THRES can be a scalar, in which case it\n", + " defines the UMFPACK pivoting tolerance for both symmetric and\n", + " unsymmetric cases. If THRES is a 2-element vector, then the first\n", + " element defines the pivoting tolerance for the unsymmetric UMFPACK\n", + " pivoting strategy and the second for the symmetric strategy. By\n", + " default, the values defined by 'spparms' are used ([0.1, 0.001]).\n", + "\n", + " Given the string argument \"vector\", 'lu' returns the values of P\n", + " and Q as vector values, such that for full matrix, 'A (P,:) = L *\n", + " U', and 'R(P,:) * A (:, Q) = L * U'.\n", + "\n", + " With two output arguments, returns the permuted forms of the upper\n", + " and lower triangular matrices, such that 'A = L * U'. With one\n", + " output argument Y, then the matrix returned by the LAPACK routines\n", + " is returned. If the input matrix is sparse then the matrix L is\n", + " embedded into U to give a return value similar to the full case.\n", + " For both full and sparse matrices, 'lu' loses the permutation\n", + " information.\n", + "\n", + " See also: luupdate, ilu, chol, hess, qr, qz, schur, svd.\n", + "\n", + "Additional help for built-in functions and operators is\n", + "available in the online version of the manual. Use the command\n", + "'doc <topic>' to search the manual index.\n", + "\n", + "Help and information about Octave is also available on the WWW\n", + "at http://www.octave.org and via the help@octave.org\n", + "mailing list.\n" + ] + } + ], + "source": [ + "help lu" + ] + }, + { + "cell_type": "code", + "execution_count": 22, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"78.8,384.0 534.9,384.0 534.9,16.8 78.8,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,384.0 L91.3,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,322.8 L91.3,322.8 M535.0,322.8 L522.5,322.8 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,328.8)\">\n", + "\t\t<text><tspan font-family=\"{}\">5e-05</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,261.6 L91.3,261.6 M535.0,261.6 L522.5,261.6 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,267.6)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,200.3 L91.3,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.00015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,139.1 L91.3,139.1 M535.0,139.1 L522.5,139.1 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,145.1)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,77.9 L91.3,77.9 M535.0,77.9 L522.5,77.9 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,83.9)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.00025</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,16.7 L91.3,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(70.5,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0003</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,384.0 L78.8,371.5 M78.8,16.7 L78.8,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(78.8,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M170.0,384.0 L170.0,371.5 M170.0,16.7 L170.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(170.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M261.3,384.0 L261.3,371.5 M261.3,16.7 L261.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(261.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M352.5,384.0 L352.5,371.5 M352.5,16.7 L352.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(352.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M443.8,384.0 L443.8,371.5 M443.8,16.7 L443.8,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(443.8,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M78.8,16.7 L78.8,384.0 L535.0,384.0 L535.0,16.7 L78.8,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>LU decomp</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">LU decomp</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,49.7 L414.7,49.7 M83.4,330.3 L87.9,244.5 L92.5,289.7 L97.0,292.1 L101.6,288.5 L106.2,289.7 L110.7,287.1 L115.3,283.6 L119.9,279.8 L124.4,276.3 L129.0,276.3 L133.5,265.5 L138.1,269.0 L142.7,266.4 L147.2,261.7 L151.8,261.7 L156.4,271.3 L160.9,269.9 L165.5,274.8 L170.0,272.5 L174.6,268.7 L179.2,212.7 L183.7,256.7 L188.3,261.4 L192.9,260.2 L197.4,234.5 L202.0,270.2 L206.5,269.0 L211.1,249.4 L215.7,265.2 L220.2,303.1 L224.8,298.2 L229.3,300.8 L233.9,299.6 L238.5,292.3 L243.0,299.3 L247.6,298.2 L252.2,294.7 L256.7,284.8 L261.3,282.4 L265.8,306.9 L270.4,297.0 L275.0,303.1 L279.5,306.9 L284.1,299.3 L288.7,283.6 L293.2,294.4 L297.8,295.8 L302.3,292.3 L306.9,292.1 L311.5,283.6 L316.0,287.4 L320.6,286.2 L325.1,272.8 L329.7,293.2 L334.3,292.1 L338.8,294.7 L343.4,293.2 L348.0,292.1 L352.5,302.0 L357.1,302.0 L361.6,302.0 L366.2,299.6 L370.8,293.2 L375.3,277.5 L379.9,294.7 L384.5,292.1 L389.0,289.7 L393.6,289.7 L398.1,288.5 L402.7,286.2 L407.3,288.5 L411.8,234.5 L416.4,285.9 L421.0,282.4 L425.5,241.8 L430.1,241.8 L434.6,279.8 L439.2,266.4 L443.8,280.1 L448.3,259.1 L452.9,229.6 L457.4,277.7 L462.0,283.6 L466.6,276.3 L471.1,278.6 L475.7,277.5 L480.3,277.5 L484.8,274.8 L489.4,265.2 L493.9,270.2 L498.5,272.5 L503.1,259.1 L507.6,264.0 L512.2,264.0 L516.8,266.4 L521.3,261.4 L525.9,264.0 L530.4,247.1 L535.0,259.1 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>Octave \\\\</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Octave \\</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,97.7 L414.7,97.7 M83.4,359.5 L87.9,287.4 L92.5,306.6 L97.0,311.9 L101.6,305.8 L106.2,306.9 L110.7,305.5 L115.3,303.1 L119.9,293.2 L124.4,292.3 L129.0,262.6 L133.5,278.6 L138.1,272.8 L142.7,232.2 L147.2,265.2 L151.8,260.2 L156.4,275.1 L160.9,238.3 L165.5,231.9 L170.0,240.7 L174.6,221.1 L179.2,229.9 L183.7,221.1 L188.3,218.8 L192.9,198.9 L197.4,185.8 L202.0,218.8 L206.5,221.1 L211.1,216.2 L215.7,213.8 L220.2,265.2 L224.8,265.2 L229.3,269.9 L233.9,254.1 L238.5,256.7 L243.0,256.7 L247.6,249.1 L252.2,247.1 L256.7,241.8 L261.3,204.2 L265.8,265.2 L270.4,262.9 L275.0,243.3 L279.5,264.0 L284.1,252.9 L288.7,249.4 L293.2,247.1 L297.8,245.6 L302.3,241.0 L306.9,229.9 L311.5,205.4 L316.0,229.9 L320.6,205.1 L325.1,222.3 L329.7,241.0 L334.3,244.2 L338.8,238.3 L343.4,227.2 L348.0,218.5 L352.5,250.6 L357.1,250.6 L361.6,246.8 L366.2,232.2 L370.8,240.7 L375.3,238.3 L379.9,220.0 L384.5,207.7 L389.0,222.6 L393.6,217.6 L398.1,215.0 L402.7,212.7 L407.3,213.8 L411.8,223.5 L416.4,208.9 L421.0,205.4 L425.5,196.6 L430.1,184.6 L434.6,190.5 L439.2,195.4 L443.8,185.8 L448.3,177.0 L452.9,183.2 L457.4,180.8 L462.0,188.1 L466.6,164.8 L471.1,164.8 L475.7,175.9 L480.3,175.9 L484.8,169.7 L489.4,165.9 L493.9,161.0 L498.5,75.5 L503.1,150.2 L507.6,135.3 L512.2,150.2 L516.8,145.5 L521.3,147.6 L525.9,134.1 L530.4,126.8 L535.0,135.3 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 128, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "% time LU solution vs backslash\n", + "t_lu=zeros(100,1);\n", + "t_bs=zeros(100,1);\n", + "for N=1:100\n", + " A=rand(N,N);\n", + " y=rand(N,1);\n", + " [L,U,P]=lu(A);\n", + "\n", + " tic; d=L\\y; x=U\\d; t_lu(N)=toc;\n", + "\n", + " tic; x=A\\y; t_bs(N)=toc;\n", + "end\n", + "plot([1:100],t_lu,[1:100],t_bs) \n", + "legend('LU decomp','Octave \\\\')" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$\n", + "\n", + "$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "2k & -k & 0 & 0 \\\\\n", + "-k & 2k & -k & 0 \\\\\n", + "0 & -k & 2k & -k \\\\\n", + "0 & 0 & -k & k \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 24, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k=10; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "This matrix, K, is symmetric. \n", + "\n", + "`K(i,j)==K(j,i)`\n", + "\n", + "Now we can use,\n", + "\n", + "## Cholesky Factorization\n", + "\n", + "We can decompose the matrix, K into two matrices, $U$ and $U^{T}$, where\n", + "\n", + "$K=U^{T}U$\n", + "\n", + "each of the components of U can be calculated with the following equations:\n", + "\n", + "$u_{ii}=\\sqrt{a_{ii}-\\sum_{k=1}^{i-1}u_{ki}^{2}}$\n", + "\n", + "$u_{ij}=\\frac{a_{ij}-\\sum_{k=1}^{i-1}u_{ki}u_{kj}}{u_{ii}}$\n", + "\n", + "so for K" + ] + }, + { + "cell_type": "code", + "execution_count": 25, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n" + ] + } + ], + "source": [ + "K" + ] + }, + { + "cell_type": "code", + "execution_count": 26, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "u11 = 4.4721\n", + "u12 = -2.2361\n", + "u13 = 0\n", + "u14 = 0\n", + "u22 = 3.8730\n", + "u23 = -2.5820\n", + "u24 = 0\n", + "u33 = 3.6515\n", + "u34 = -2.7386\n", + "u44 = 1.5811\n", + "U =\n", + "\n", + " 4.47214 -2.23607 0.00000 0.00000\n", + " 0.00000 3.87298 -2.58199 0.00000\n", + " 0.00000 0.00000 3.65148 -2.73861\n", + " 0.00000 0.00000 0.00000 1.58114\n", + "\n" + ] + } + ], + "source": [ + "u11=sqrt(K(1,1))\n", + "u12=(K(1,2))/u11\n", + "u13=(K(1,3))/u11\n", + "u14=(K(1,4))/u11\n", + "u22=sqrt(K(2,2)-u12^2)\n", + "u23=(K(2,3)-u12*u13)/u22\n", + "u24=(K(2,4)-u12*u14)/u22\n", + "u33=sqrt(K(3,3)-u13^2-u23^2)\n", + "u34=(K(3,4)-u13*u14-u23*u24)/u33\n", + "u44=sqrt(K(4,4)-u14^2-u24^2-u34^2)\n", + "U=[u11,u12,u13,u14;0,u22,u23,u24;0,0,u33,u34;0,0,0,u44]" + ] + }, + { + "cell_type": "code", + "execution_count": 27, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 20.00000 -10.00000 0.00000 0.00000\n", + " -10.00000 20.00000 -10.00000 0.00000\n", + " 0.00000 -10.00000 20.00000 -10.00000\n", + " 0.00000 0.00000 -10.00000 10.00000\n", + "\n" + ] + } + ], + "source": [ + "U'*U" + ] + }, + { + "cell_type": "code", + "execution_count": 37, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "average time spent for Cholesky factored solution = 1.623154e-05+/-1.166726e-05\n", + "average time spent for backslash solution = 1.675844e-05+/-1.187234e-05\n" + ] + } + ], + "source": [ + "% time solution for Cholesky vs backslash\n", + "t_chol=zeros(1000,1);\n", + "t_bs=zeros(1000,1);\n", + "for i=1:1000\n", + " tic; d=U'*y; x=U\\d; t_chol(i)=toc;\n", + " tic; x=K\\y; t_bs(i)=toc;\n", + "end\n", + "fprintf('average time spent for Cholesky factored solution = %e+/-%e',mean(t_chol),std(t_chol))\n", + "\n", + "fprintf('average time spent for backslash solution = %e+/-%e',mean(t_bs),std(t_bs))" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_11/LU_naive.m b/lecture_11/LU_naive.m new file mode 100644 index 0000000..92efde6 --- /dev/null +++ b/lecture_11/LU_naive.m @@ -0,0 +1,27 @@ +function [L, U] = LU_naive(A) +% GaussNaive: naive Gauss elimination +% x = GaussNaive(A,b): Gauss elimination without pivoting. +% input: +% A = coefficient matrix +% y = right hand side vector +% output: +% x = solution vector +[m,n] = size(A); +if m~=n, error('Matrix A must be square'); end +nb = n; +L=diag(ones(n,1)); +U=A; +% forward elimination +for k = 1:n-1 + for i = k+1:n + fik = U(i,k)/U(k,k); + L(i,k)=fik; + U(i,k:nb) = U(i,k:nb)-fik*U(k,k:nb); + end +end +%% back substitution +%x = zeros(n,1); +%x(n) = Aug(n,nb)/Aug(n,n); +%for i = n-1:-1:1 +% x(i) = (Aug(i,nb)-Aug(i,i+1:n)*x(i+1:n))/Aug(i,i); +%end diff --git a/lecture_11/LU_pivot.m b/lecture_11/LU_pivot.m new file mode 100644 index 0000000..37abb26 --- /dev/null +++ b/lecture_11/LU_pivot.m @@ -0,0 +1,36 @@ +function [L,U,P] = LU_pivot(A) +% GaussPivot: Gauss elimination pivoting +% x = GaussPivot(A,b): Gauss elimination with pivoting. +% input: +% A = coefficient matrix +% b = right hand side vector +% output: +% x = solution vector +[m,n]=size(A); +if m~=n, error('Matrix A must be square'); end +nb = n; +L=diag(ones(n,1)); +U=A; +P=diag(ones(n,1)); +% forward elimination +for k = 1:n-1 + % partial pivoting + [big,i]=max(abs(U(k:n,k))); + ipr=i+k-1; + if ipr~=k + P([k,ipr],:)=P([ipr,k],:); % if the max is not the current index ipr, pivot count + %L([k,ipr],:)=L([ipr,k],:); + %U([k,ipr],:)=U([ipr,k],:); + end + for i = k+1:n + fik=U(i,k)/U(k,k); + L(i,k)=fik; + U(i,k:nb)=U(i,k:nb)-fik*U(k,k:nb); + end +end +% back substitution +%x=zeros(n,1); +%x(n)=Aug(n,nb)/Aug(n,n); +%for i = n-1:-1:1 +% x(i)=(Aug(i,nb)-Aug(i,i+1:n)*x(i+1:n))/Aug(i,i); +%end diff --git a/lecture_11/det_A.png b/lecture_11/det_A.png new file mode 100644 index 0000000..50f6ac1 Binary files /dev/null and b/lecture_11/det_A.png differ diff --git a/lecture_11/lecture_11.aux b/lecture_11/lecture_11.aux new file mode 100644 index 0000000..a9c4771 --- /dev/null +++ b/lecture_11/lecture_11.aux @@ -0,0 +1,38 @@ +\relax +\providecommand\hyper@newdestlabel[2]{} +\providecommand\HyperFirstAtBeginDocument{\AtBeginDocument} +\HyperFirstAtBeginDocument{\ifx\hyper@anchor\@undefined +\global\let\oldcontentsline\contentsline +\gdef\contentsline#1#2#3#4{\oldcontentsline{#1}{#2}{#3}} +\global\let\oldnewlabel\newlabel +\gdef\newlabel#1#2{\newlabelxx{#1}#2} +\gdef\newlabelxx#1#2#3#4#5#6{\oldnewlabel{#1}{{#2}{#3}}} +\AtEndDocument{\ifx\hyper@anchor\@undefined +\let\contentsline\oldcontentsline +\let\newlabel\oldnewlabel +\fi} +\fi} +\global\let\hyper@last\relax +\gdef\HyperFirstAtBeginDocument#1{#1} +\providecommand\HyField@AuxAddToFields[1]{} +\providecommand\HyField@AuxAddToCoFields[2]{} +\providecommand \oddpage@label [2]{} +\@writefile{toc}{\contentsline {subsection}{\numberline {0.1}My question from last class}{1}{subsection.0.1}} +\newlabel{my-question-from-last-class}{{0.1}{1}{My question from last class}{subsection.0.1}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {1}{\ignorespaces responses to determinant of A\relax }}{1}{figure.caption.1}} +\@writefile{toc}{\contentsline {subsection}{\numberline {0.2}Your questions from last class}{1}{subsection.0.2}} +\newlabel{your-questions-from-last-class}{{0.2}{1}{Your questions from last class}{subsection.0.2}{}} +\@writefile{toc}{\contentsline {subsection}{\numberline {0.3}Midterm preference}{2}{subsection.0.3}} +\newlabel{midterm-preference}{{0.3}{2}{Midterm preference}{subsection.0.3}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {2}{\ignorespaces responses to midterm date\relax }}{2}{figure.caption.2}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {0.3.1}Midterm Questions}{2}{subsubsection.0.3.1}} +\newlabel{midterm-questions}{{0.3.1}{2}{Midterm Questions}{subsubsection.0.3.1}{}} +\@writefile{toc}{\contentsline {section}{\numberline {1}LU Decomposition}{2}{section.1}} +\newlabel{lu-decomposition}{{1}{2}{LU Decomposition}{section.1}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.0.1}efficient storage of matrices for solutions}{2}{subsubsection.1.0.1}} +\newlabel{efficient-storage-of-matrices-for-solutions}{{1.0.1}{2}{efficient storage of matrices for solutions}{subsubsection.1.0.1}{}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.1}Pivoting for LU factorization}{4}{subsection.1.1}} +\newlabel{pivoting-for-lu-factorization}{{1.1}{4}{Pivoting for LU factorization}{subsection.1.1}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {3}{\ignorespaces Springs-masses\relax }}{7}{figure.caption.3}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.2}Cholesky Factorization}{8}{subsection.1.2}} +\newlabel{cholesky-factorization}{{1.2}{8}{Cholesky Factorization}{subsection.1.2}{}} diff --git a/lecture_11/lecture_11.bbl b/lecture_11/lecture_11.bbl new file mode 100644 index 0000000..e69de29 diff --git a/lecture_11/lecture_11.blg b/lecture_11/lecture_11.blg new file mode 100644 index 0000000..f6400af --- /dev/null +++ b/lecture_11/lecture_11.blg @@ -0,0 +1,48 @@ +This is BibTeX, Version 0.99d (TeX Live 2015/Debian) +Capacity: max_strings=35307, hash_size=35307, hash_prime=30011 +The top-level auxiliary file: lecture_11.aux +I found no \citation commands---while reading file lecture_11.aux +I found no \bibdata command---while reading file lecture_11.aux +I found no \bibstyle command---while reading file lecture_11.aux +You've used 0 entries, + 0 wiz_defined-function locations, + 83 strings with 494 characters, +and the built_in function-call counts, 0 in all, are: += -- 0 +> -- 0 +< -- 0 ++ -- 0 +- -- 0 +* -- 0 +:= -- 0 +add.period$ -- 0 +call.type$ -- 0 +change.case$ -- 0 +chr.to.int$ -- 0 +cite$ -- 0 +duplicate$ -- 0 +empty$ -- 0 +format.name$ -- 0 +if$ -- 0 +int.to.chr$ -- 0 +int.to.str$ -- 0 +missing$ -- 0 +newline$ -- 0 +num.names$ -- 0 +pop$ -- 0 +preamble$ -- 0 +purify$ -- 0 +quote$ -- 0 +skip$ -- 0 +stack$ -- 0 +substring$ -- 0 +swap$ -- 0 +text.length$ -- 0 +text.prefix$ -- 0 +top$ -- 0 +type$ -- 0 +warning$ -- 0 +while$ -- 0 +width$ -- 0 +write$ -- 0 +(There were 3 error messages) diff --git a/lecture_11/lecture_11.ipynb b/lecture_11/lecture_11.ipynb new file mode 100644 index 0000000..41f1870 --- /dev/null +++ b/lecture_11/lecture_11.ipynb @@ -0,0 +1,758 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## My question from last class \n", + "\n", + "$A=\\left[ \\begin{array}{ccc}\n", + "10 & 2 & 1 \\\\\n", + "0 & 1 & 1 \\\\\n", + "0 & 0 & 10\\end{array} \\right]$\n", + "\n", + "\n", + "\n", + "## Your questions from last class\n", + "\n", + "1. Need more linear algebra review\n", + " \n", + " -We will keep doing Linear Algebra, try the practice problems in 'linear_algebra'\n", + "\n", + "2. How do I do HW3? \n", + " \n", + " -demo today\n", + "\n", + "3. For hw4 is the spring constant (K) suppose to be given? \n", + " \n", + " -yes, its 30 N/m\n", + " \n", + "4. Deapool or Joker?\n", + "\n", + "\n", + "## Midterm preference\n", + "\n", + "\n", + "\n", + "### Midterm Questions\n", + "\n", + "1. Notes allowed\n", + " \n", + " -no\n", + "\n", + "2. Will there be a review/study sheet\n", + "\n", + " -yes" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# LU Decomposition\n", + "### efficient storage of matrices for solutions\n", + "\n", + "Considering the same solution set:\n", + "\n", + "$y=Ax$\n", + "\n", + "Assume that we can perform Gauss elimination and achieve this formula:\n", + "\n", + "$Ux=d$ \n", + "\n", + "Where, $U$ is an upper triangular matrix that we derived from Gauss elimination and $d$ is the set of dependent variables after Gauss elimination. \n", + "\n", + "Assume there is a lower triangular matrix, $L$, with ones on the diagonal and same dimensions of $U$ and the following is true:\n", + "\n", + "$L(Ux-d)=Ax-y=0$\n", + "\n", + "Now, $Ax=LUx$, so $A=LU$, and $y=Ld$.\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "1 & 3 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "f21=0.5\n", + "\n", + "A(2,1)=1-1 = 0 \n", + "\n", + "A(2,2)=3-0.5=2.5\n", + "\n", + "y(2)=1-0.5=0.5\n", + "\n", + "$L(Ux-d)=\n", + "\\left[ \\begin{array}{cc}\n", + "1 & 0 \\\\\n", + "0.5 & 1 \\end{array} \\right]\n", + "\\left(\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "0 & 2.5 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]-\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "0.5\\end{array}\\right]\\right)=0$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000\n", + " 0.50000 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 1.00000\n", + " 0.00000 2.50000\n", + "\n", + "ans =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "d =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + "\n", + "y =\n", + "\n", + " 1\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "L=[1,0;0.5,1]\n", + "U=[2,1;0,2.5]\n", + "L*U\n", + "\n", + "d=[1;0.5]\n", + "y=L*d" + ] + }, + { + "cell_type": "code", + "execution_count": 5, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = 5.0000\n", + "ans = 1\n", + "ans = 5\n", + "ans = 5\n", + "ans = 5.0000\n" + ] + } + ], + "source": [ + "% what is the determinant of L, U and A?\n", + "\n", + "det(A)\n", + "det(L)\n", + "det(U)\n", + "det(L)*det(U)\n", + "det(L*U)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Pivoting for LU factorization\n", + "\n", + "LU factorization uses the same method as Gauss elimination so it is also necessary to perform partial pivoting when creating the lower and upper triangular matrices. \n", + "\n", + "Matlab and Octave use pivoting in the command \n", + "\n", + "`[L,U,P]=lu(A)`\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "'lu' is a built-in function from the file libinterp/corefcn/lu.cc\n", + "\n", + " -- Built-in Function: [L, U] = lu (A)\n", + " -- Built-in Function: [L, U, P] = lu (A)\n", + " -- Built-in Function: [L, U, P, Q] = lu (S)\n", + " -- Built-in Function: [L, U, P, Q, R] = lu (S)\n", + " -- Built-in Function: [...] = lu (S, THRES)\n", + " -- Built-in Function: Y = lu (...)\n", + " -- Built-in Function: [...] = lu (..., \"vector\")\n", + " Compute the LU decomposition of A.\n", + "\n", + " If A is full subroutines from LAPACK are used and if A is sparse\n", + " then UMFPACK is used.\n", + "\n", + " The result is returned in a permuted form, according to the\n", + " optional return value P. For example, given the matrix 'a = [1, 2;\n", + " 3, 4]',\n", + "\n", + " [l, u, p] = lu (A)\n", + "\n", + " returns\n", + "\n", + " l =\n", + "\n", + " 1.00000 0.00000\n", + " 0.33333 1.00000\n", + "\n", + " u =\n", + "\n", + " 3.00000 4.00000\n", + " 0.00000 0.66667\n", + "\n", + " p =\n", + "\n", + " 0 1\n", + " 1 0\n", + "\n", + " The matrix is not required to be square.\n", + "\n", + " When called with two or three output arguments and a spare input\n", + " matrix, 'lu' does not attempt to perform sparsity preserving column\n", + " permutations. Called with a fourth output argument, the sparsity\n", + " preserving column transformation Q is returned, such that 'P * A *\n", + " Q = L * U'.\n", + "\n", + " Called with a fifth output argument and a sparse input matrix, 'lu'\n", + " attempts to use a scaling factor R on the input matrix such that 'P\n", + " * (R \\ A) * Q = L * U'. This typically leads to a sparser and more\n", + " stable factorization.\n", + "\n", + " An additional input argument THRES, that defines the pivoting\n", + " threshold can be given. THRES can be a scalar, in which case it\n", + " defines the UMFPACK pivoting tolerance for both symmetric and\n", + " unsymmetric cases. If THRES is a 2-element vector, then the first\n", + " element defines the pivoting tolerance for the unsymmetric UMFPACK\n", + " pivoting strategy and the second for the symmetric strategy. By\n", + " default, the values defined by 'spparms' are used ([0.1, 0.001]).\n", + "\n", + " Given the string argument \"vector\", 'lu' returns the values of P\n", + " and Q as vector values, such that for full matrix, 'A (P,:) = L *\n", + " U', and 'R(P,:) * A (:, Q) = L * U'.\n", + "\n", + " With two output arguments, returns the permuted forms of the upper\n", + " and lower triangular matrices, such that 'A = L * U'. With one\n", + " output argument Y, then the matrix returned by the LAPACK routines\n", + " is returned. If the input matrix is sparse then the matrix L is\n", + " embedded into U to give a return value similar to the full case.\n", + " For both full and sparse matrices, 'lu' loses the permutation\n", + " information.\n", + "\n", + " See also: luupdate, ilu, chol, hess, qr, qz, schur, svd.\n", + "\n", + "Additional help for built-in functions and operators is\n", + "available in the online version of the manual. Use the command\n", + "'doc <topic>' to search the manual index.\n", + "\n", + "Help and information about Octave is also available on the WWW\n", + "at http://www.octave.org and via the help@octave.org\n", + "mailing list.\n" + ] + } + ], + "source": [ + "help lu" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,298.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0005</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,114.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(70.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(163.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(256.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(349.2,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(442.1,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>LU decomp</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">LU decomp</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,49.7 L414.7,49.7 M75.1,357.4 L79.8,366.4 L84.4,370.3 L89.1,369.9 L93.7,363.8 L98.4,369.5 L103.0,369.5 L107.7,362.2 L112.3,368.4 L117.0,368.0 L121.6,360.8 L126.2,366.5 L130.9,366.6 L135.5,355.4 L140.2,355.5 L144.8,353.0 L149.5,346.7 L154.1,360.0 L158.8,362.3 L163.4,361.2 L168.0,362.3 L172.7,355.7 L177.3,360.3 L182.0,356.9 L186.6,355.1 L191.3,357.9 L195.9,351.3 L200.6,356.6 L205.2,355.0 L209.9,355.4 L214.5,362.2 L219.1,360.9 L223.8,360.8 L228.4,359.7 L233.1,359.0 L237.7,356.5 L242.4,358.3 L247.0,356.6 L251.7,360.7 L256.3,360.3 L260.9,360.0 L265.6,359.0 L270.2,359.0 L274.9,357.6 L279.5,357.4 L284.2,356.2 L288.8,354.2 L293.5,359.6 L298.1,358.5 L302.8,357.9 L307.4,356.5 L312.0,356.5 L316.7,355.9 L321.3,355.1 L326.0,353.9 L330.6,352.4 L335.3,357.0 L339.9,356.6 L344.6,355.9 L349.2,355.2 L353.8,354.1 L358.5,353.1 L363.1,352.6 L367.8,351.5 L372.4,335.7 L377.1,356.3 L381.7,356.6 L386.4,352.6 L391.0,355.5 L395.7,355.5 L400.3,354.6 L404.9,355.1 L409.6,224.4 L414.2,352.4 L418.9,338.8 L423.5,351.5 L428.2,350.8 L432.8,350.4 L437.5,349.7 L442.1,350.4 L446.7,348.4 L451.4,347.8 L456.0,346.2 L460.7,347.0 L465.3,340.7 L470.0,338.6 L474.6,346.2 L479.3,347.3 L483.9,344.2 L488.6,343.8 L493.2,342.5 L497.8,343.2 L502.5,341.2 L507.1,342.5 L511.8,338.8 L516.4,342.3 L521.1,337.9 L525.7,338.3 L530.4,337.8 L535.0,339.2 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>Octave \\\\</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Octave \\</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,97.7 L414.7,97.7 M75.1,371.7 L79.8,368.6 L84.4,372.8 L89.1,372.4 L93.7,371.3 L98.4,371.7 L103.0,371.3 L107.7,369.9 L112.3,370.3 L117.0,370.2 L121.6,368.6 L126.2,368.9 L130.9,364.9 L135.5,357.0 L140.2,358.5 L144.8,354.4 L149.5,353.0 L154.1,358.7 L158.8,359.8 L163.4,360.1 L168.0,360.7 L172.7,355.2 L177.3,353.7 L182.0,355.4 L186.6,337.5 L191.3,353.7 L195.9,349.1 L200.6,354.4 L205.2,350.4 L209.9,329.8 L214.5,357.6 L219.1,353.7 L223.8,357.6 L228.4,350.4 L233.1,354.4 L237.7,353.9 L242.4,352.4 L247.0,140.3 L251.7,355.1 L256.3,356.8 L260.9,355.5 L265.6,352.6 L270.2,353.3 L274.9,353.9 L279.5,351.7 L284.2,350.8 L288.8,341.2 L293.5,355.2 L298.1,353.0 L302.8,352.6 L307.4,350.6 L312.0,351.3 L316.7,343.8 L321.3,348.0 L326.0,347.3 L330.6,345.4 L335.3,351.5 L339.9,338.1 L344.6,348.7 L349.2,349.1 L353.8,347.3 L358.5,346.9 L363.1,343.2 L367.8,343.6 L372.4,343.2 L377.1,335.7 L381.7,342.7 L386.4,344.5 L391.0,345.8 L395.7,345.6 L400.3,332.4 L404.9,340.7 L409.6,341.9 L414.2,262.6 L418.9,340.1 L423.5,331.8 L428.2,339.4 L432.8,338.3 L437.5,334.6 L442.1,335.5 L446.7,328.7 L451.4,333.3 L456.0,328.7 L460.7,331.3 L465.3,329.7 L470.0,327.8 L474.6,323.0 L479.3,324.8 L483.9,114.6 L488.6,315.3 L493.2,314.0 L497.8,301.7 L502.5,315.3 L507.1,319.2 L511.8,314.6 L516.4,315.1 L521.1,311.6 L525.7,313.1 L530.4,302.3 L535.0,305.2 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 128, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "% time LU solution vs backslash\n", + "t_lu=zeros(100,1);\n", + "t_bs=zeros(100,1);\n", + "for N=1:100\n", + " A=rand(N,N);\n", + " y=rand(N,1);\n", + " [L,U,P]=lu(A);\n", + "\n", + " tic; d=inv(L)*y; x=inv(U)*d; t_lu(N)=toc;\n", + "\n", + " tic; x=inv(A)*y; t_bs(N)=toc;\n", + "end\n", + "plot([1:100],t_lu,[1:100],t_bs) \n", + "legend('LU decomp','Octave \\\\')" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$\n", + "\n", + "$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "2k & -k & 0 & 0 \\\\\n", + "-k & 2k & -k & 0 \\\\\n", + "0 & -k & 2k & -k \\\\\n", + "0 & 0 & -k & k \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k=10; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "This matrix, K, is symmetric. \n", + "\n", + "`K(i,j)==K(j,i)`\n", + "\n", + "Now we can use,\n", + "\n", + "## Cholesky Factorization\n", + "\n", + "We can decompose the matrix, K into two matrices, $U$ and $U^{T}$, where\n", + "\n", + "$K=U^{T}U$\n", + "\n", + "each of the components of U can be calculated with the following equations:\n", + "\n", + "$u_{ii}=\\sqrt{a_{ii}-\\sum_{k=1}^{i-1}u_{ki}^{2}}$\n", + "\n", + "$u_{ij}=\\frac{a_{ij}-\\sum_{k=1}^{i-1}u_{ki}u_{kj}}{u_{ii}}$\n", + "\n", + "so for K" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n" + ] + } + ], + "source": [ + "K" + ] + }, + { + "cell_type": "code", + "execution_count": 12, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "u11 = 4.4721\n", + "u12 = -2.2361\n", + "u13 = 0\n", + "u14 = 0\n", + "u22 = 3.8730\n", + "u23 = -2.5820\n", + "u24 = 0\n", + "u33 = 3.6515\n", + "u34 = -2.7386\n", + "u44 = 1.5811\n", + "U =\n", + "\n", + " 4.47214 -2.23607 0.00000 0.00000\n", + " 0.00000 3.87298 -2.58199 0.00000\n", + " 0.00000 0.00000 3.65148 -2.73861\n", + " 0.00000 0.00000 0.00000 1.58114\n", + "\n" + ] + } + ], + "source": [ + "u11=sqrt(K(1,1))\n", + "u12=(K(1,2))/u11\n", + "u13=(K(1,3))/u11\n", + "u14=(K(1,4))/u11\n", + "u22=sqrt(K(2,2)-u12^2)\n", + "u23=(K(2,3)-u12*u13)/u22\n", + "u24=(K(2,4)-u12*u14)/u22\n", + "u33=sqrt(K(3,3)-u13^2-u23^2)\n", + "u34=(K(3,4)-u13*u14-u23*u24)/u33\n", + "u44=sqrt(K(4,4)-u14^2-u24^2-u34^2)\n", + "U=[u11,u12,u13,u14;0,u22,u23,u24;0,0,u33,u34;0,0,0,u44]" + ] + }, + { + "cell_type": "code", + "execution_count": 17, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + "\n" + ] + } + ], + "source": [ + "(U'*U)'==U'*U" + ] + }, + { + "cell_type": "code", + "execution_count": 18, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "average time spent for Cholesky factored solution = 1.465964e-05+/-9.806001e-06\n", + "average time spent for backslash solution = 1.555967e-05+/-1.048561e-05\n" + ] + } + ], + "source": [ + "% time solution for Cholesky vs backslash\n", + "t_chol=zeros(1000,1);\n", + "t_bs=zeros(1000,1);\n", + "for i=1:1000\n", + " tic; d=U'*y; x=U\\d; t_chol(i)=toc;\n", + " tic; x=K\\y; t_bs(i)=toc;\n", + "end\n", + "fprintf('average time spent for Cholesky factored solution = %e+/-%e',mean(t_chol),std(t_chol))\n", + "\n", + "fprintf('average time spent for backslash solution = %e+/-%e',mean(t_bs),std(t_bs))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_11/lecture_11.log b/lecture_11/lecture_11.log new file mode 100644 index 0000000..981cd40 --- /dev/null +++ b/lecture_11/lecture_11.log @@ -0,0 +1,839 @@ +This is pdfTeX, Version 3.14159265-2.6-1.40.16 (TeX Live 2015/Debian) (preloaded format=pdflatex 2017.1.11) 27 FEB 2017 11:55 +entering extended mode + restricted \write18 enabled. + %&-line parsing enabled. +**lecture_11.tex +(./lecture_11.tex +LaTeX2e <2016/02/01> +Babel <3.9q> and hyphenation patterns for 81 language(s) loaded. +(/usr/share/texlive/texmf-dist/tex/latex/base/article.cls +Document Class: article 2014/09/29 v1.4h Standard LaTeX document class +(/usr/share/texlive/texmf-dist/tex/latex/base/size11.clo +File: size11.clo 2014/09/29 v1.4h Standard LaTeX file (size option) +) +\c@part=\count79 +\c@section=\count80 +\c@subsection=\count81 +\c@subsubsection=\count82 +\c@paragraph=\count83 +\c@subparagraph=\count84 +\c@figure=\count85 +\c@table=\count86 +\abovecaptionskip=\skip41 +\belowcaptionskip=\skip42 +\bibindent=\dimen102 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/fontenc.sty +Package: fontenc 2005/09/27 v1.99g Standard LaTeX package + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1enc.def +File: t1enc.def 2005/09/27 v1.99g Standard LaTeX file +LaTeX Font Info: Redeclaring font encoding T1 on input line 48. +)) +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/mathpazo.sty +Package: mathpazo 2005/04/12 PSNFSS-v9.2a Palatino w/ Pazo Math (D.Puga, WaS) +\symupright=\mathgroup4 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphicx.sty +Package: graphicx 2014/10/28 v1.0g Enhanced LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/keyval.sty +Package: keyval 2014/10/28 v1.15 key=value parser (DPC) +\KV@toks@=\toks14 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphics.sty +Package: graphics 2016/01/03 v1.0q Standard LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/trig.sty +Package: trig 2016/01/03 v1.10 sin cos tan (DPC) +) +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/graphics.cfg +File: graphics.cfg 2010/04/23 v1.9 graphics configuration of TeX Live +) +Package graphics Info: Driver file: pdftex.def on input line 95. + +(/usr/share/texlive/texmf-dist/tex/latex/pdftex-def/pdftex.def +File: pdftex.def 2011/05/27 v0.06d Graphics/color for pdfTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/infwarerr.sty +Package: infwarerr 2010/04/08 v1.3 Providing info/warning/error messages (HO) +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ltxcmds.sty +Package: ltxcmds 2011/11/09 v1.22 LaTeX kernel commands for general use (HO) +) +\Gread@gobject=\count87 +)) +\Gin@req@height=\dimen103 +\Gin@req@width=\dimen104 +) +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption.sty +Package: caption 2016/02/21 v3.3-144 Customizing captions (AR) + +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption3.sty +Package: caption3 2016/02/04 v1.7-139 caption3 kernel (AR) +Package caption3 Info: TeX engine: e-TeX on input line 67. +\captionmargin=\dimen105 +\captionmargin@=\dimen106 +\captionwidth=\dimen107 +\caption@tempdima=\dimen108 +\caption@indent=\dimen109 +\caption@parindent=\dimen110 +\caption@hangindent=\dimen111 +) +\c@ContinuedFloat=\count88 +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjustbox.sty +Package: adjustbox 2012/05/21 v1.0 Adjusting TeX boxes (trim, clip, ...) + +(/usr/share/texlive/texmf-dist/tex/latex/xkeyval/xkeyval.sty +Package: xkeyval 2014/12/03 v2.7a package option processing (HA) + +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkeyval.tex +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkvutils.tex +\XKV@toks=\toks15 +\XKV@tempa@toks=\toks16 +) +\XKV@depth=\count89 +File: xkeyval.tex 2014/12/03 v2.7a key=value parser (HA) +)) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjcalc.sty +Package: adjcalc 2012/05/16 v1.1 Provides advanced setlength with multiple back +-ends (calc, etex, pgfmath) +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/trimclip.sty +Package: trimclip 2012/05/16 v1.0 Trim and clip general TeX material + +(/usr/share/texlive/texmf-dist/tex/latex/collectbox/collectbox.sty +Package: collectbox 2012/05/17 v0.4b Collect macro arguments as boxes +\collectedbox=\box26 +) +\tc@llx=\dimen112 +\tc@lly=\dimen113 +\tc@urx=\dimen114 +\tc@ury=\dimen115 +Package trimclip Info: Using driver 'tc-pdftex.def'. + +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/tc-pdftex.def +File: tc-pdftex.def 2012/05/13 v1.0 Clipping driver for pdftex +)) +\adjbox@Width=\dimen116 +\adjbox@Height=\dimen117 +\adjbox@Depth=\dimen118 +\adjbox@Totalheight=\dimen119 + +(/usr/share/texlive/texmf-dist/tex/latex/ifoddpage/ifoddpage.sty +Package: ifoddpage 2011/09/13 v1.0 Conditionals for odd/even page detection +\c@checkoddpage=\count90 +) +(/usr/share/texlive/texmf-dist/tex/latex/varwidth/varwidth.sty +Package: varwidth 2009/03/30 ver 0.92; Variable-width minipages +\@vwid@box=\box27 +\sift@deathcycles=\count91 +\@vwid@loff=\dimen120 +\@vwid@roff=\dimen121 +)) +(/usr/share/texlive/texmf-dist/tex/latex/xcolor/xcolor.sty +Package: xcolor 2007/01/21 v2.11 LaTeX color extensions (UK) + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/color.cfg +File: color.cfg 2007/01/18 v1.5 color configuration of teTeX/TeXLive +) +Package xcolor Info: Driver file: pdftex.def on input line 225. +Package xcolor Info: Model `cmy' substituted by `cmy0' on input line 1337. +Package xcolor Info: Model `hsb' substituted by `rgb' on input line 1341. +Package xcolor Info: Model `RGB' extended on input line 1353. +Package xcolor Info: Model `HTML' substituted by `rgb' on input line 1355. +Package xcolor Info: Model `Hsb' substituted by `hsb' on input line 1356. +Package xcolor Info: Model `tHsb' substituted by `hsb' on input line 1357. +Package xcolor Info: Model `HSB' substituted by `hsb' on input line 1358. +Package xcolor Info: Model `Gray' substituted by `gray' on input line 1359. +Package xcolor Info: Model `wave' substituted by `hsb' on input line 1360. +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/enumerate.sty +Package: enumerate 2015/07/23 v3.00 enumerate extensions (DPC) +\@enLab=\toks17 +) +(/usr/share/texlive/texmf-dist/tex/latex/geometry/geometry.sty +Package: geometry 2010/09/12 v5.6 Page Geometry + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifpdf.sty +Package: ifpdf 2011/01/30 v2.3 Provides the ifpdf switch (HO) +Package ifpdf Info: pdfTeX in PDF mode is detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifvtex.sty +Package: ifvtex 2010/03/01 v1.5 Detect VTeX and its facilities (HO) +Package ifvtex Info: VTeX not detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/ifxetex/ifxetex.sty +Package: ifxetex 2010/09/12 v0.6 Provides ifxetex conditional +) +\Gm@cnth=\count92 +\Gm@cntv=\count93 +\c@Gm@tempcnt=\count94 +\Gm@bindingoffset=\dimen122 +\Gm@wd@mp=\dimen123 +\Gm@odd@mp=\dimen124 +\Gm@even@mp=\dimen125 +\Gm@layoutwidth=\dimen126 +\Gm@layoutheight=\dimen127 +\Gm@layouthoffset=\dimen128 +\Gm@layoutvoffset=\dimen129 +\Gm@dimlist=\toks18 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsmath.sty +Package: amsmath 2016/03/03 v2.15a AMS math features +\@mathmargin=\skip43 + +For additional information on amsmath, use the `?' option. +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amstext.sty +Package: amstext 2000/06/29 v2.01 AMS text + +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsgen.sty +File: amsgen.sty 1999/11/30 v2.0 generic functions +\@emptytoks=\toks19 +\ex@=\dimen130 +)) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsbsy.sty +Package: amsbsy 1999/11/29 v1.2d Bold Symbols +\pmbraise@=\dimen131 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsopn.sty +Package: amsopn 1999/12/14 v2.01 operator names +) +\inf@bad=\count95 +LaTeX Info: Redefining \frac on input line 199. +\uproot@=\count96 +\leftroot@=\count97 +LaTeX Info: Redefining \overline on input line 297. +\classnum@=\count98 +\DOTSCASE@=\count99 +LaTeX Info: Redefining \ldots on input line 394. +LaTeX Info: Redefining \dots on input line 397. +LaTeX Info: Redefining \cdots on input line 518. +\Mathstrutbox@=\box28 +\strutbox@=\box29 +\big@size=\dimen132 +LaTeX Font Info: Redeclaring font encoding OML on input line 630. +LaTeX Font Info: Redeclaring font encoding OMS on input line 631. +\macc@depth=\count100 +\c@MaxMatrixCols=\count101 +\dotsspace@=\muskip10 +\c@parentequation=\count102 +\dspbrk@lvl=\count103 +\tag@help=\toks20 +\row@=\count104 +\column@=\count105 +\maxfields@=\count106 +\andhelp@=\toks21 +\eqnshift@=\dimen133 +\alignsep@=\dimen134 +\tagshift@=\dimen135 +\tagwidth@=\dimen136 +\totwidth@=\dimen137 +\lineht@=\dimen138 +\@envbody=\toks22 +\multlinegap=\skip44 +\multlinetaggap=\skip45 +\mathdisplay@stack=\toks23 +LaTeX Info: Redefining \[ on input line 2735. +LaTeX Info: Redefining \] on input line 2736. +) +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amssymb.sty +Package: amssymb 2013/01/14 v3.01 AMS font symbols + +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amsfonts.sty +Package: amsfonts 2013/01/14 v3.01 Basic AMSFonts support +\symAMSa=\mathgroup5 +\symAMSb=\mathgroup6 +LaTeX Font Info: Overwriting math alphabet `\mathfrak' in version `bold' +(Font) U/euf/m/n --> U/euf/b/n on input line 106. +)) +(/usr/share/texlive/texmf-dist/tex/latex/base/textcomp.sty +Package: textcomp 2005/09/27 v1.99g Standard LaTeX package +Package textcomp Info: Sub-encoding information: +(textcomp) 5 = only ISO-Adobe without \textcurrency +(textcomp) 4 = 5 + \texteuro +(textcomp) 3 = 4 + \textohm +(textcomp) 2 = 3 + \textestimated + \textcurrency +(textcomp) 1 = TS1 - \textcircled - \t +(textcomp) 0 = TS1 (full) +(textcomp) Font families with sub-encoding setting implement +(textcomp) only a restricted character set as indicated. +(textcomp) Family '?' is the default used for unknown fonts. +(textcomp) See the documentation for details. +Package textcomp Info: Setting ? sub-encoding to TS1/1 on input line 79. + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1enc.def +File: ts1enc.def 2001/06/05 v3.0e (jk/car/fm) Standard LaTeX file +) +LaTeX Info: Redefining \oldstylenums on input line 334. +Package textcomp Info: Setting cmr sub-encoding to TS1/0 on input line 349. +Package textcomp Info: Setting cmss sub-encoding to TS1/0 on input line 350. +Package textcomp Info: Setting cmtt sub-encoding to TS1/0 on input line 351. +Package textcomp Info: Setting cmvtt sub-encoding to TS1/0 on input line 352. +Package textcomp Info: Setting cmbr sub-encoding to TS1/0 on input line 353. +Package textcomp Info: Setting cmtl sub-encoding to TS1/0 on input line 354. +Package textcomp Info: Setting ccr sub-encoding to TS1/0 on input line 355. +Package textcomp Info: Setting ptm sub-encoding to TS1/4 on input line 356. +Package textcomp Info: Setting pcr sub-encoding to TS1/4 on input line 357. +Package textcomp Info: Setting phv sub-encoding to TS1/4 on input line 358. +Package textcomp Info: Setting ppl sub-encoding to TS1/3 on input line 359. +Package textcomp Info: Setting pag sub-encoding to TS1/4 on input line 360. +Package textcomp Info: Setting pbk sub-encoding to TS1/4 on input line 361. +Package textcomp Info: Setting pnc sub-encoding to TS1/4 on input line 362. +Package textcomp Info: Setting pzc sub-encoding to TS1/4 on input line 363. +Package textcomp Info: Setting bch sub-encoding to TS1/4 on input line 364. +Package textcomp Info: Setting put sub-encoding to TS1/5 on input line 365. +Package textcomp Info: Setting uag sub-encoding to TS1/5 on input line 366. +Package textcomp Info: Setting ugq sub-encoding to TS1/5 on input line 367. +Package textcomp Info: Setting ul8 sub-encoding to TS1/4 on input line 368. +Package textcomp Info: Setting ul9 sub-encoding to TS1/4 on input line 369. +Package textcomp Info: Setting augie sub-encoding to TS1/5 on input line 370. +Package textcomp Info: Setting dayrom sub-encoding to TS1/3 on input line 371. +Package textcomp Info: Setting dayroms sub-encoding to TS1/3 on input line 372. + +Package textcomp Info: Setting pxr sub-encoding to TS1/0 on input line 373. +Package textcomp Info: Setting pxss sub-encoding to TS1/0 on input line 374. +Package textcomp Info: Setting pxtt sub-encoding to TS1/0 on input line 375. +Package textcomp Info: Setting txr sub-encoding to TS1/0 on input line 376. +Package textcomp Info: Setting txss sub-encoding to TS1/0 on input line 377. +Package textcomp Info: Setting txtt sub-encoding to TS1/0 on input line 378. +Package textcomp Info: Setting lmr sub-encoding to TS1/0 on input line 379. +Package textcomp Info: Setting lmdh sub-encoding to TS1/0 on input line 380. +Package textcomp Info: Setting lmss sub-encoding to TS1/0 on input line 381. +Package textcomp Info: Setting lmssq sub-encoding to TS1/0 on input line 382. +Package textcomp Info: Setting lmvtt sub-encoding to TS1/0 on input line 383. +Package textcomp Info: Setting lmtt sub-encoding to TS1/0 on input line 384. +Package textcomp Info: Setting qhv sub-encoding to TS1/0 on input line 385. +Package textcomp Info: Setting qag sub-encoding to TS1/0 on input line 386. +Package textcomp Info: Setting qbk sub-encoding to TS1/0 on input line 387. +Package textcomp Info: Setting qcr sub-encoding to TS1/0 on input line 388. +Package textcomp Info: Setting qcs sub-encoding to TS1/0 on input line 389. +Package textcomp Info: Setting qpl sub-encoding to TS1/0 on input line 390. +Package textcomp Info: Setting qtm sub-encoding to TS1/0 on input line 391. +Package textcomp Info: Setting qzc sub-encoding to TS1/0 on input line 392. +Package textcomp Info: Setting qhvc sub-encoding to TS1/0 on input line 393. +Package textcomp Info: Setting futs sub-encoding to TS1/4 on input line 394. +Package textcomp Info: Setting futx sub-encoding to TS1/4 on input line 395. +Package textcomp Info: Setting futj sub-encoding to TS1/4 on input line 396. +Package textcomp Info: Setting hlh sub-encoding to TS1/3 on input line 397. +Package textcomp Info: Setting hls sub-encoding to TS1/3 on input line 398. +Package textcomp Info: Setting hlst sub-encoding to TS1/3 on input line 399. +Package textcomp Info: Setting hlct sub-encoding to TS1/5 on input line 400. +Package textcomp Info: Setting hlx sub-encoding to TS1/5 on input line 401. +Package textcomp Info: Setting hlce sub-encoding to TS1/5 on input line 402. +Package textcomp Info: Setting hlcn sub-encoding to TS1/5 on input line 403. +Package textcomp Info: Setting hlcw sub-encoding to TS1/5 on input line 404. +Package textcomp Info: Setting hlcf sub-encoding to TS1/5 on input line 405. +Package textcomp Info: Setting pplx sub-encoding to TS1/3 on input line 406. +Package textcomp Info: Setting pplj sub-encoding to TS1/3 on input line 407. +Package textcomp Info: Setting ptmx sub-encoding to TS1/4 on input line 408. +Package textcomp Info: Setting ptmj sub-encoding to TS1/4 on input line 409. +) +(/usr/share/texlive/texmf-dist/tex/latex/upquote/upquote.sty +Package: upquote 2012/04/19 v1.3 upright-quote and grave-accent glyphs in verba +tim +) +(/usr/share/texlive/texmf-dist/tex/latex/eurosym/eurosym.sty +Package: eurosym 1998/08/06 v1.1 European currency symbol ``Euro'' +\@eurobox=\box30 +) +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucs.sty +Package: ucs 2013/05/11 v2.2 UCS: Unicode input support + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/data/uni-global.def +File: uni-global.def 2013/05/13 UCS: Unicode global data +) +\uc@secondtry=\count107 +\uc@combtoks=\toks24 +\uc@combtoksb=\toks25 +\uc@temptokena=\toks26 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/inputenc.sty +Package: inputenc 2015/03/17 v1.2c Input encoding file +\inpenc@prehook=\toks27 +\inpenc@posthook=\toks28 + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/utf8x.def +File: utf8x.def 2004/10/17 UCS: Input encoding UTF-8 +)) +(/usr/share/texlive/texmf-dist/tex/latex/fancyvrb/fancyvrb.sty +Package: fancyvrb 2008/02/07 + +Style option: `fancyvrb' v2.7a, with DG/SPQR fixes, and firstline=lastline fix +<2008/02/07> (tvz) +\FV@CodeLineNo=\count108 +\FV@InFile=\read1 +\FV@TabBox=\box31 +\c@FancyVerbLine=\count109 +\FV@StepNumber=\count110 +\FV@OutFile=\write3 +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grffile.sty +Package: grffile 2012/04/05 v1.16 Extended file name support for graphics (HO) + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/kvoptions.sty +Package: kvoptions 2011/06/30 v3.11 Key value format for package options (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/kvsetkeys.sty +Package: kvsetkeys 2012/04/25 v1.16 Key value parser (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/etexcmds.sty +Package: etexcmds 2011/02/16 v1.5 Avoid name clashes with e-TeX commands (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifluatex.sty +Package: ifluatex 2010/03/01 v1.3 Provides the ifluatex switch (HO) +Package ifluatex Info: LuaTeX not detected. +) +Package etexcmds Info: Could not find \expanded. +(etexcmds) That can mean that you are not using pdfTeX 1.50 or +(etexcmds) that some package has redefined \expanded. +(etexcmds) In the latter case, load this package earlier. +))) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/pdftexcmds.sty +Package: pdftexcmds 2011/11/29 v0.20 Utility functions of pdfTeX for LuaTeX (HO +) +Package pdftexcmds Info: LuaTeX not detected. +Package pdftexcmds Info: \pdf@primitive is available. +Package pdftexcmds Info: \pdf@ifprimitive is available. +Package pdftexcmds Info: \pdfdraftmode found. +) +Package grffile Info: Option `multidot' is set to `true'. +Package grffile Info: Option `extendedchars' is set to `false'. +Package grffile Info: Option `space' is set to `true'. +Package grffile Info: \Gin@ii of package `graphicx' fixed on input line 486. +) +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hyperref.sty +Package: hyperref 2012/11/06 v6.83m Hypertext links for LaTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-hyperref.sty +Package: hobsub-hyperref 2012/05/28 v1.13 Bundle oberdiek, subset hyperref (HO) + + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-generic.sty +Package: hobsub-generic 2012/05/28 v1.13 Bundle oberdiek, subset generic (HO) +Package: hobsub 2012/05/28 v1.13 Construct package bundles (HO) +Package hobsub Info: Skipping package `infwarerr' (already loaded). +Package hobsub Info: Skipping package `ltxcmds' (already loaded). +Package hobsub Info: Skipping package `ifluatex' (already loaded). +Package hobsub Info: Skipping package `ifvtex' (already loaded). +Package: intcalc 2007/09/27 v1.1 Expandable calculations with integers (HO) +Package hobsub Info: Skipping package `ifpdf' (already loaded). +Package hobsub Info: Skipping package `etexcmds' (already loaded). +Package hobsub Info: Skipping package `kvsetkeys' (already loaded). +Package: kvdefinekeys 2011/04/07 v1.3 Define keys (HO) +Package hobsub Info: Skipping package `pdftexcmds' (already loaded). +Package: pdfescape 2011/11/25 v1.13 Implements pdfTeX's escape features (HO) +Package: bigintcalc 2012/04/08 v1.3 Expandable calculations on big integers (HO +) +Package: bitset 2011/01/30 v1.1 Handle bit-vector datatype (HO) +Package: uniquecounter 2011/01/30 v1.2 Provide unlimited unique counter (HO) +) +Package hobsub Info: Skipping package `hobsub' (already loaded). +Package: letltxmacro 2010/09/02 v1.4 Let assignment for LaTeX macros (HO) +Package: hopatch 2012/05/28 v1.2 Wrapper for package hooks (HO) +Package: xcolor-patch 2011/01/30 xcolor patch +Package: atveryend 2011/06/30 v1.8 Hooks at the very end of document (HO) +Package atveryend Info: \enddocument detected (standard20110627). +Package: atbegshi 2011/10/05 v1.16 At begin shipout hook (HO) +Package: refcount 2011/10/16 v3.4 Data extraction from label references (HO) +Package: hycolor 2011/01/30 v1.7 Color options for hyperref/bookmark (HO) +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/auxhook.sty +Package: auxhook 2011/03/04 v1.3 Hooks for auxiliary files (HO) +) +\@linkdim=\dimen139 +\Hy@linkcounter=\count111 +\Hy@pagecounter=\count112 + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/pd1enc.def +File: pd1enc.def 2012/11/06 v6.83m Hyperref: PDFDocEncoding definition (HO) +) +\Hy@SavedSpaceFactor=\count113 + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/hyperref.cfg +File: hyperref.cfg 2002/06/06 v1.2 hyperref configuration of TeXLive +) +Package hyperref Info: Hyper figures OFF on input line 4443. +Package hyperref Info: Link nesting OFF on input line 4448. +Package hyperref Info: Hyper index ON on input line 4451. +Package hyperref Info: Plain pages OFF on input line 4458. +Package hyperref Info: Backreferencing OFF on input line 4463. +Package hyperref Info: Implicit mode ON; LaTeX internals redefined. +Package hyperref Info: Bookmarks ON on input line 4688. +\c@Hy@tempcnt=\count114 + +(/usr/share/texlive/texmf-dist/tex/latex/url/url.sty +\Urlmuskip=\muskip11 +Package: url 2013/09/16 ver 3.4 Verb mode for urls, etc. +) +LaTeX Info: Redefining \url on input line 5041. +\XeTeXLinkMargin=\dimen140 +\Fld@menulength=\count115 +\Field@Width=\dimen141 +\Fld@charsize=\dimen142 +Package hyperref Info: Hyper figures OFF on input line 6295. +Package hyperref Info: Link nesting OFF on input line 6300. +Package hyperref Info: Hyper index ON on input line 6303. +Package hyperref Info: backreferencing OFF on input line 6310. +Package hyperref Info: Link coloring OFF on input line 6315. +Package hyperref Info: Link coloring with OCG OFF on input line 6320. +Package hyperref Info: PDF/A mode OFF on input line 6325. +LaTeX Info: Redefining \ref on input line 6365. +LaTeX Info: Redefining \pageref on input line 6369. +\Hy@abspage=\count116 +\c@Item=\count117 +\c@Hfootnote=\count118 +) + +Package hyperref Message: Driver (autodetected): hpdftex. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hpdftex.def +File: hpdftex.def 2012/11/06 v6.83m Hyperref driver for pdfTeX +\Fld@listcount=\count119 +\c@bookmark@seq@number=\count120 + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/rerunfilecheck.sty +Package: rerunfilecheck 2011/04/15 v1.7 Rerun checks for auxiliary files (HO) +Package uniquecounter Info: New unique counter `rerunfilecheck' on input line 2 +82. +) +\Hy@SectionHShift=\skip46 +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/longtable.sty +Package: longtable 2014/10/28 v4.11 Multi-page Table package (DPC) +\LTleft=\skip47 +\LTright=\skip48 +\LTpre=\skip49 +\LTpost=\skip50 +\LTchunksize=\count121 +\LTcapwidth=\dimen143 +\LT@head=\box32 +\LT@firsthead=\box33 +\LT@foot=\box34 +\LT@lastfoot=\box35 +\LT@cols=\count122 +\LT@rows=\count123 +\c@LT@tables=\count124 +\c@LT@chunks=\count125 +\LT@p@ftn=\toks29 +) +(/usr/share/texlive/texmf-dist/tex/latex/booktabs/booktabs.sty +Package: booktabs 2005/04/14 v1.61803 publication quality tables +\heavyrulewidth=\dimen144 +\lightrulewidth=\dimen145 +\cmidrulewidth=\dimen146 +\belowrulesep=\dimen147 +\belowbottomsep=\dimen148 +\aboverulesep=\dimen149 +\abovetopsep=\dimen150 +\cmidrulesep=\dimen151 +\cmidrulekern=\dimen152 +\defaultaddspace=\dimen153 +\@cmidla=\count126 +\@cmidlb=\count127 +\@aboverulesep=\dimen154 +\@belowrulesep=\dimen155 +\@thisruleclass=\count128 +\@lastruleclass=\count129 +\@thisrulewidth=\dimen156 +) +(/usr/share/texlive/texmf-dist/tex/latex/enumitem/enumitem.sty +Package: enumitem 2011/09/28 v3.5.2 Customized lists +\labelindent=\skip51 +\enit@outerparindent=\dimen157 +\enit@toks=\toks30 +\enit@inbox=\box36 +\enitdp@description=\count130 +) +(/usr/share/texlive/texmf-dist/tex/generic/ulem/ulem.sty +\UL@box=\box37 +\UL@hyphenbox=\box38 +\UL@skip=\skip52 +\UL@hook=\toks31 +\UL@height=\dimen158 +\UL@pe=\count131 +\UL@pixel=\dimen159 +\ULC@box=\box39 +Package: ulem 2012/05/18 +\ULdepth=\dimen160 +) +Package hyperref Info: Option `breaklinks' set `true' on input line 264. +Package hyperref Info: Option `colorlinks' set `true' on input line 264. + (./lecture_11.aux) +\openout1 = `lecture_11.aux'. + +LaTeX Font Info: Checking defaults for OML/cmm/m/it on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for T1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OT1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMS/cmsy/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMX/cmex/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for U/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for TS1/cmr/m/n on input line 271. +LaTeX Font Info: Try loading font information for TS1+cmr on input line 271. + + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmr.fd +File: ts1cmr.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for PD1/pdf/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Try loading font information for T1+ppl on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/t1ppl.fd +File: t1ppl.fd 2001/06/04 font definitions for T1/ppl. +) +(/usr/share/texlive/texmf-dist/tex/context/base/supp-pdf.mkii +[Loading MPS to PDF converter (version 2006.09.02).] +\scratchcounter=\count132 +\scratchdimen=\dimen161 +\scratchbox=\box40 +\nofMPsegments=\count133 +\nofMParguments=\count134 +\everyMPshowfont=\toks32 +\MPscratchCnt=\count135 +\MPscratchDim=\dimen162 +\MPnumerator=\count136 +\makeMPintoPDFobject=\count137 +\everyMPtoPDFconversion=\toks33 +) (/usr/share/texlive/texmf-dist/tex/latex/oberdiek/epstopdf-base.sty +Package: epstopdf-base 2010/02/09 v2.5 Base part for package epstopdf + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grfext.sty +Package: grfext 2010/08/19 v1.1 Manage graphics extensions (HO) +) +Package grfext Info: Graphics extension search list: +(grfext) [.png,.pdf,.jpg,.mps,.jpeg,.jbig2,.jb2,.PNG,.PDF,.JPG,.JPE +G,.JBIG2,.JB2,.eps] +(grfext) \AppendGraphicsExtensions on input line 452. + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/epstopdf-sys.cfg +File: epstopdf-sys.cfg 2010/07/13 v1.3 Configuration of (r)epstopdf for TeX Liv +e +)) +Package caption Info: Begin \AtBeginDocument code. +Package caption Info: hyperref package is loaded. +Package caption Info: longtable package is loaded. + +(/usr/share/texlive/texmf-dist/tex/latex/caption/ltcaption.sty +Package: ltcaption 2013/06/09 v1.4-94 longtable captions (AR) +) +Package caption Info: End \AtBeginDocument code. + +*geometry* driver: auto-detecting +*geometry* detected driver: pdftex +*geometry* verbose mode - [ preamble ] result: +* driver: pdftex +* paper: <default> +* layout: <same size as paper> +* layoutoffset:(h,v)=(0.0pt,0.0pt) +* modes: +* h-part:(L,W,R)=(72.26999pt, 469.75502pt, 72.26999pt) +* v-part:(T,H,B)=(72.26999pt, 650.43001pt, 72.26999pt) +* \paperwidth=614.295pt +* \paperheight=794.96999pt +* \textwidth=469.75502pt +* \textheight=650.43001pt +* \oddsidemargin=0.0pt +* \evensidemargin=0.0pt +* \topmargin=-37.0pt +* \headheight=12.0pt +* \headsep=25.0pt +* \topskip=11.0pt +* \footskip=30.0pt +* \marginparwidth=59.0pt +* \marginparsep=10.0pt +* \columnsep=10.0pt +* \skip\footins=10.0pt plus 4.0pt minus 2.0pt +* \hoffset=0.0pt +* \voffset=0.0pt +* \mag=1000 +* \@twocolumnfalse +* \@twosidefalse +* \@mparswitchfalse +* \@reversemarginfalse +* (1in=72.27pt=25.4mm, 1cm=28.453pt) + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucsencs.def +File: ucsencs.def 2011/01/21 Fixes to fontencodings LGR, T3 +) +\AtBeginShipoutBox=\box41 +Package hyperref Info: Link coloring ON on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/nameref.sty +Package: nameref 2012/10/27 v2.43 Cross-referencing by name of section + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/gettitlestring.sty +Package: gettitlestring 2010/12/03 v1.4 Cleanup title references (HO) +) +\c@section@level=\count138 +) +LaTeX Info: Redefining \ref on input line 271. +LaTeX Info: Redefining \pageref on input line 271. +LaTeX Info: Redefining \nameref on input line 271. + +(./lecture_11.out) (./lecture_11.out) +\@outlinefile=\write4 +\openout4 = `lecture_11.out'. + +LaTeX Font Info: Try loading font information for OT1+ppl on input line 275. + + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1ppl.fd +File: ot1ppl.fd 2001/06/04 font definitions for OT1/ppl. +) +LaTeX Font Info: Try loading font information for OML+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omlzplm.fd +File: omlzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OML/zplm. +) +LaTeX Font Info: Try loading font information for OMS+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omszplm.fd +File: omszplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMS/zplm. +) +LaTeX Font Info: Try loading font information for OMX+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omxzplm.fd +File: omxzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMX/zplm. +) +LaTeX Font Info: Try loading font information for OT1+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1zplm.fd +File: ot1zplm.fd 2002/09/08 Fontinst v1.914 font definitions for OT1/zplm. +) +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. + + +LaTeX Warning: No \author given. + +LaTeX Font Info: Try loading font information for T1+cmtt on input line 279. + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1cmtt.fd +File: t1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <12> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 288. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 11.40997pt on input line 290. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 8.33606pt on input line 290. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 6.25204pt on input line 290. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 11.40997pt on input line 290. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 8.33606pt on input line 290. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 6.25204pt on input line 290. + +<det_A.png, id=36, 704.6325pt x 379.4175pt> +File: det_A.png Graphic file (type png) + <use det_A.png> +Package pdftex.def Info: det_A.png used on input line 294. +(pdftex.def) Requested size: 375.80544pt x 202.3582pt. + [1 + +{/var/lib/texmf/fonts/map/pdftex/updmap/pdftex.map} <./det_A.png>] +<midterm_date.png, id=55, 839.135pt x 383.4325pt> +File: midterm_date.png Graphic file (type png) + <use midterm_date.png> +Package pdftex.def Info: midterm_date.png used on input line 324. +(pdftex.def) Requested size: 375.80544pt x 171.71808pt. +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <10.95> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 328. +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <14.4> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 342. + + +Package hyperref Warning: Difference (2) between bookmark levels is greater +(hyperref) than one, level fixed on input line 345. + +[2 <./midterm_date.png>] [3] +LaTeX Font Info: Try loading font information for TS1+cmtt on input line 461 +. + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmtt.fd +File: ts1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) [4] [5] +LaTeX Font Info: Font shape `T1/cmtt/bx/n' in size <10.95> not available +(Font) Font shape `T1/cmtt/m/n' tried instead on input line 547. + +<lecture_11_files/lecture_11_8_0.pdf, id=79, 449.68pt x 337.26pt> +File: lecture_11_files/lecture_11_8_0.pdf Graphic file (type pdf) + +<use lecture_11_files/lecture_11_8_0.pdf> +Package pdftex.def Info: lecture_11_files/lecture_11_8_0.pdf used on input line + 561. +(pdftex.def) Requested size: 449.6789pt x 337.25917pt. + +Underfull \hbox (badness 10000) in paragraph at lines 563--564 + + [] + +<../lecture_09/mass_springs.png, id=80, 112.42pt x 190.7125pt> +File: ../lecture_09/mass_springs.png Graphic file (type png) + +<use ../lecture_09/mass_springs.png> +Package pdftex.def Info: ../lecture_09/mass_springs.png used on input line 571. + +(pdftex.def) Requested size: 89.93611pt x 152.576pt. + [6 <./lecture_11_files/lecture_11_8_0.pdf>] [7 <../lecture_09/mass_springs.png +>] [8] +Package atveryend Info: Empty hook `BeforeClearDocument' on input line 734. + [9] +Package atveryend Info: Empty hook `AfterLastShipout' on input line 734. + (./lecture_11.aux) +Package atveryend Info: Executing hook `AtVeryEndDocument' on input line 734. +Package atveryend Info: Executing hook `AtEndAfterFileList' on input line 734. +Package rerunfilecheck Info: File `lecture_11.out' has not changed. +(rerunfilecheck) Checksum: 41743ED7C91140C56E53FBD51DB19D65;568. +Package atveryend Info: Empty hook `AtVeryVeryEnd' on input line 734. + ) +Here is how much of TeX's memory you used: + 10955 strings out of 493029 + 163773 string characters out of 6136234 + 268999 words of memory out of 5000000 + 14228 multiletter control sequences out of 15000+600000 + 39052 words of font info for 103 fonts, out of 8000000 for 9000 + 1141 hyphenation exceptions out of 8191 + 36i,9n,77p,460b,465s stack positions out of 5000i,500n,10000p,200000b,80000s +{/usr/share/texmf/fonts/enc/dvips/cm-super/cm-super-ts1.enc}{/usr/share/texli +ve/texmf-dist/fonts/enc/dvips/base/8r.enc}{/usr/share/texmf/fonts/enc/dvips/cm- +super/cm-super-t1.enc}</usr/share/texlive/texmf-dist/fonts/type1/public/amsfont +s/cm/cmex10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/c +mr10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/cmsy10.p +fb></usr/share/texlive/texmf-dist/fonts/type1/public/mathpazo/fplmr.pfb></usr/s +hare/texmf/fonts/type1/public/cm-super/sfit1095.pfb></usr/share/texmf/fonts/typ +e1/public/cm-super/sftt1095.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/ +palatino/uplb8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/palatino/upl +r8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/palatino/uplri8a.pfb> +Output written on lecture_11.pdf (9 pages, 191934 bytes). +PDF statistics: + 152 PDF objects out of 1000 (max. 8388607) + 121 compressed objects within 2 object streams + 27 named destinations out of 1000 (max. 500000) + 85 words of extra memory for PDF output out of 10000 (max. 10000000) + diff --git a/lecture_11/lecture_11.out b/lecture_11/lecture_11.out new file mode 100644 index 0000000..481e738 --- /dev/null +++ b/lecture_11/lecture_11.out @@ -0,0 +1,8 @@ +\BOOKMARK [2][-]{subsection.0.1}{My question from last class}{}% 1 +\BOOKMARK [2][-]{subsection.0.2}{Your questions from last class}{}% 2 +\BOOKMARK [2][-]{subsection.0.3}{Midterm preference}{}% 3 +\BOOKMARK [3][-]{subsubsection.0.3.1}{Midterm Questions}{subsection.0.3}% 4 +\BOOKMARK [1][-]{section.1}{LU Decomposition}{}% 5 +\BOOKMARK [2][-]{subsubsection.1.0.1}{efficient storage of matrices for solutions}{section.1}% 6 +\BOOKMARK [2][-]{subsection.1.1}{Pivoting for LU factorization}{section.1}% 7 +\BOOKMARK [2][-]{subsection.1.2}{Cholesky Factorization}{section.1}% 8 diff --git a/lecture_11/lecture_11.pdf b/lecture_11/lecture_11.pdf new file mode 100644 index 0000000..9fa1342 Binary files /dev/null and b/lecture_11/lecture_11.pdf differ diff --git a/lecture_11/lecture_11.tex b/lecture_11/lecture_11.tex new file mode 100644 index 0000000..318852d --- /dev/null +++ b/lecture_11/lecture_11.tex @@ -0,0 +1,734 @@ + +% Default to the notebook output style + + + + +% Inherit from the specified cell style. + + + + + +\documentclass[11pt]{article} + + + + \usepackage[T1]{fontenc} + % Nicer default font (+ math font) than Computer Modern for most use cases + \usepackage{mathpazo} + + % Basic figure setup, for now with no caption control since it's done + % automatically by Pandoc (which extracts  syntax from Markdown). + \usepackage{graphicx} + % We will generate all images so they have a width \maxwidth. This means + % that they will get their normal width if they fit onto the page, but + % are scaled down if they would overflow the margins. + \makeatletter + \def\maxwidth{\ifdim\Gin@nat@width>\linewidth\linewidth + \else\Gin@nat@width\fi} + \makeatother + \let\Oldincludegraphics\includegraphics + % Set max figure width to be 80% of text width, for now hardcoded. + \renewcommand{\includegraphics}[1]{\Oldincludegraphics[width=.8\maxwidth]{#1}} + % Ensure that by default, figures have no caption (until we provide a + % proper Figure object with a Caption API and a way to capture that + % in the conversion process - todo). + \usepackage{caption} + \DeclareCaptionLabelFormat{nolabel}{} + \captionsetup{labelformat=nolabel} + + \usepackage{adjustbox} % Used to constrain images to a maximum size + \usepackage{xcolor} % Allow colors to be defined + \usepackage{enumerate} % Needed for markdown enumerations to work + \usepackage{geometry} % Used to adjust the document margins + \usepackage{amsmath} % Equations + \usepackage{amssymb} % Equations + \usepackage{textcomp} % defines textquotesingle + % Hack from http://tex.stackexchange.com/a/47451/13684: + \AtBeginDocument{% + \def\PYZsq{\textquotesingle}% Upright quotes in Pygmentized code + } + \usepackage{upquote} % Upright quotes for verbatim code + \usepackage{eurosym} % defines \euro + \usepackage[mathletters]{ucs} % Extended unicode (utf-8) support + \usepackage[utf8x]{inputenc} % Allow utf-8 characters in the tex document + \usepackage{fancyvrb} % verbatim replacement that allows latex + \usepackage{grffile} % extends the file name processing of package graphics + % to support a larger range + % The hyperref package gives us a pdf with properly built + % internal navigation ('pdf bookmarks' for the table of contents, + % internal cross-reference links, web links for URLs, etc.) + \usepackage{hyperref} + \usepackage{longtable} % longtable support required by pandoc >1.10 + \usepackage{booktabs} % table support for pandoc > 1.12.2 + \usepackage[inline]{enumitem} % IRkernel/repr support (it uses the enumerate* environment) + \usepackage[normalem]{ulem} % ulem is needed to support strikethroughs (\sout) + % normalem makes italics be italics, not underlines + + + + + % Colors for the hyperref package + \definecolor{urlcolor}{rgb}{0,.145,.698} + \definecolor{linkcolor}{rgb}{.71,0.21,0.01} + \definecolor{citecolor}{rgb}{.12,.54,.11} + + % ANSI colors + \definecolor{ansi-black}{HTML}{3E424D} + \definecolor{ansi-black-intense}{HTML}{282C36} + \definecolor{ansi-red}{HTML}{E75C58} + \definecolor{ansi-red-intense}{HTML}{B22B31} + \definecolor{ansi-green}{HTML}{00A250} + \definecolor{ansi-green-intense}{HTML}{007427} + \definecolor{ansi-yellow}{HTML}{DDB62B} + \definecolor{ansi-yellow-intense}{HTML}{B27D12} + \definecolor{ansi-blue}{HTML}{208FFB} + \definecolor{ansi-blue-intense}{HTML}{0065CA} + \definecolor{ansi-magenta}{HTML}{D160C4} + \definecolor{ansi-magenta-intense}{HTML}{A03196} + \definecolor{ansi-cyan}{HTML}{60C6C8} + \definecolor{ansi-cyan-intense}{HTML}{258F8F} + \definecolor{ansi-white}{HTML}{C5C1B4} + \definecolor{ansi-white-intense}{HTML}{A1A6B2} + + % commands and environments needed by pandoc snippets + % extracted from the output of `pandoc -s` + \providecommand{\tightlist}{% + \setlength{\itemsep}{0pt}\setlength{\parskip}{0pt}} + \DefineVerbatimEnvironment{Highlighting}{Verbatim}{commandchars=\\\{\}} + % Add ',fontsize=\small' for more characters per line + \newenvironment{Shaded}{}{} + \newcommand{\KeywordTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\DataTypeTok}[1]{\textcolor[rgb]{0.56,0.13,0.00}{{#1}}} + \newcommand{\DecValTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\BaseNTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\FloatTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\CharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\StringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\CommentTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textit{{#1}}}} + \newcommand{\OtherTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{{#1}}} + \newcommand{\AlertTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\FunctionTok}[1]{\textcolor[rgb]{0.02,0.16,0.49}{{#1}}} + \newcommand{\RegionMarkerTok}[1]{{#1}} + \newcommand{\ErrorTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\NormalTok}[1]{{#1}} + + % Additional commands for more recent versions of Pandoc + \newcommand{\ConstantTok}[1]{\textcolor[rgb]{0.53,0.00,0.00}{{#1}}} + \newcommand{\SpecialCharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\VerbatimStringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\SpecialStringTok}[1]{\textcolor[rgb]{0.73,0.40,0.53}{{#1}}} + \newcommand{\ImportTok}[1]{{#1}} + \newcommand{\DocumentationTok}[1]{\textcolor[rgb]{0.73,0.13,0.13}{\textit{{#1}}}} + \newcommand{\AnnotationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\CommentVarTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\VariableTok}[1]{\textcolor[rgb]{0.10,0.09,0.49}{{#1}}} + \newcommand{\ControlFlowTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\OperatorTok}[1]{\textcolor[rgb]{0.40,0.40,0.40}{{#1}}} + \newcommand{\BuiltInTok}[1]{{#1}} + \newcommand{\ExtensionTok}[1]{{#1}} + \newcommand{\PreprocessorTok}[1]{\textcolor[rgb]{0.74,0.48,0.00}{{#1}}} + \newcommand{\AttributeTok}[1]{\textcolor[rgb]{0.49,0.56,0.16}{{#1}}} + \newcommand{\InformationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\WarningTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + + + % Define a nice break command that doesn't care if a line doesn't already + % exist. + \def\br{\hspace*{\fill} \\* } + % Math Jax compatability definitions + \def\gt{>} + \def\lt{<} + % Document parameters + \title{lecture\_11} + + + + + % Pygments definitions + +\makeatletter +\def\PY@reset{\let\PY@it=\relax \let\PY@bf=\relax% + \let\PY@ul=\relax \let\PY@tc=\relax% + \let\PY@bc=\relax \let\PY@ff=\relax} +\def\PY@tok#1{\csname PY@tok@#1\endcsname} +\def\PY@toks#1+{\ifx\relax#1\empty\else% + \PY@tok{#1}\expandafter\PY@toks\fi} +\def\PY@do#1{\PY@bc{\PY@tc{\PY@ul{% + \PY@it{\PY@bf{\PY@ff{#1}}}}}}} +\def\PY#1#2{\PY@reset\PY@toks#1+\relax+\PY@do{#2}} + +\expandafter\def\csname PY@tok@gd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@gu\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.50,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@gt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.27,0.87}{##1}}} +\expandafter\def\csname PY@tok@gs\endcsname{\let\PY@bf=\textbf} +\expandafter\def\csname PY@tok@gr\endcsname{\def\PY@tc##1{\textcolor[rgb]{1.00,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@cm\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@vg\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@vi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@mh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@cs\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@ge\endcsname{\let\PY@it=\textit} +\expandafter\def\csname PY@tok@vc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@il\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@go\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.53,0.53}{##1}}} +\expandafter\def\csname PY@tok@cp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.74,0.48,0.00}{##1}}} +\expandafter\def\csname PY@tok@gi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@gh\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@ni\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.60,0.60,0.60}{##1}}} +\expandafter\def\csname PY@tok@nl\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@nn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@no\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@na\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.49,0.56,0.16}{##1}}} +\expandafter\def\csname PY@tok@nb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@nd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@ne\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.82,0.25,0.23}{##1}}} +\expandafter\def\csname PY@tok@nf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@si\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@s2\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@nt\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nv\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@s1\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ch\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@m\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@gp\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@sh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ow\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@sx\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@bp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c1\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@o\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@mf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@err\endcsname{\def\PY@bc##1{\setlength{\fboxsep}{0pt}\fcolorbox[rgb]{1.00,0.00,0.00}{1,1,1}{\strut ##1}}} +\expandafter\def\csname PY@tok@mb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@ss\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@sr\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@mo\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kd\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@mi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@cpf\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@kr\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@s\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@kp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@w\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.73,0.73}{##1}}} +\expandafter\def\csname PY@tok@kt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.69,0.00,0.25}{##1}}} +\expandafter\def\csname PY@tok@sc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@sb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@k\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@se\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.13}{##1}}} +\expandafter\def\csname PY@tok@sd\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} + +\def\PYZbs{\char`\\} +\def\PYZus{\char`\_} +\def\PYZob{\char`\{} +\def\PYZcb{\char`\}} +\def\PYZca{\char`\^} +\def\PYZam{\char`\&} +\def\PYZlt{\char`\<} +\def\PYZgt{\char`\>} +\def\PYZsh{\char`\#} +\def\PYZpc{\char`\%} +\def\PYZdl{\char`\$} +\def\PYZhy{\char`\-} +\def\PYZsq{\char`\'} +\def\PYZdq{\char`\"} +\def\PYZti{\char`\~} +% for compatibility with earlier versions +\def\PYZat{@} +\def\PYZlb{[} +\def\PYZrb{]} +\makeatother + + + % Exact colors from NB + \definecolor{incolor}{rgb}{0.0, 0.0, 0.5} + \definecolor{outcolor}{rgb}{0.545, 0.0, 0.0} + + + + + % Prevent overflowing lines due to hard-to-break entities + \sloppy + % Setup hyperref package + \hypersetup{ + breaklinks=true, % so long urls are correctly broken across lines + colorlinks=true, + urlcolor=urlcolor, + linkcolor=linkcolor, + citecolor=citecolor, + } + % Slightly bigger margins than the latex defaults + + \geometry{verbose,tmargin=1in,bmargin=1in,lmargin=1in,rmargin=1in} + + + + \begin{document} + + + \maketitle + + + + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}1}]:} \PY{c}{\PYZpc{}plot \PYZhy{}\PYZhy{}format svg} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}2}]:} \PY{n}{setdefaults} +\end{Verbatim} + + \subsection{My question from last +class}\label{my-question-from-last-class} + +\(A=\left[ \begin{array}{ccc} 10 & 2 & 1 \\ 0 & 1 & 1 \\ 0 & 0 & 10\end{array} \right]\) + +\begin{figure}[htbp] +\centering +\includegraphics{det_A.png} +\caption{responses to determinant of A} +\end{figure} + +\subsection{Your questions from last +class}\label{your-questions-from-last-class} + +\begin{enumerate} +\def\labelenumi{\arabic{enumi}.} +\item + Need more linear algebra review + + -We will keep doing Linear Algebra, try the practice problems in + 'linear\_algebra' +\item + How do I do HW3? + + -demo today +\item + For hw4 is the spring constant (K) suppose to be given? + + -yes, its 30 N/m +\item + Deapool or Joker? +\end{enumerate} + +\subsection{Midterm preference}\label{midterm-preference} + +\begin{figure}[htbp] +\centering +\includegraphics{midterm_date.png} +\caption{responses to midterm date} +\end{figure} + +\subsubsection{Midterm Questions}\label{midterm-questions} + +\begin{enumerate} +\def\labelenumi{\arabic{enumi}.} +\item + Notes allowed + + -no +\item + Will there be a review/study sheet + + -yes +\end{enumerate} + + \section{LU Decomposition}\label{lu-decomposition} + +\subsubsection{efficient storage of matrices for +solutions}\label{efficient-storage-of-matrices-for-solutions} + +Considering the same solution set: + +\(y=Ax\) + +Assume that we can perform Gauss elimination and achieve this formula: + +\(Ux=d\) + +Where, \(U\) is an upper triangular matrix that we derived from Gauss +elimination and \(d\) is the set of dependent variables after Gauss +elimination. + +Assume there is a lower triangular matrix, \(L\), with ones on the +diagonal and same dimensions of \(U\) and the following is true: + +\(L(Ux-d)=Ax-y=0\) + +Now, \(Ax=LUx\), so \(A=LU\), and \(y=Ld\). + +\(2x_{1}+x_{2}=1\) + +\(x_{1}+3x_{2}=1\) + +\(\left[ \begin{array}{cc} 2 & 1 \\ 1 & 3 \end{array} \right] \left[\begin{array}{c} x_{1} \\ x_{2} \end{array}\right]= \left[\begin{array}{c} 1 \\ 1\end{array}\right]\) + +f21=0.5 + +A(2,1)=1-1 = 0 + +A(2,2)=3-0.5=2.5 + +y(2)=1-0.5=0.5 + +\(L(Ux-d)= \left[ \begin{array}{cc} 1 & 0 \\ 0.5 & 1 \end{array} \right] \left(\left[ \begin{array}{cc} 2 & 1 \\ 0 & 2.5 \end{array} \right] \left[\begin{array}{c} x_{1} \\ x_{2} \end{array}\right]- \left[\begin{array}{c} 1 \\ 0.5\end{array}\right]\right)=0\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}3}]:} \PY{n}{A}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{]} + \PY{n}{L}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{0}\PY{p}{;}\PY{l+m+mf}{0.5}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{]} + \PY{n}{U}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{,}\PY{l+m+mf}{2.5}\PY{p}{]} + \PY{n}{L}\PY{o}{*}\PY{n}{U} + + \PY{n}{d}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mf}{0.5}\PY{p}{]} + \PY{n}{y}\PY{p}{=}\PY{n}{L}\PY{o}{*}\PY{n}{d} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 2 1 + 1 3 + +L = + + 1.00000 0.00000 + 0.50000 1.00000 + +U = + + 2.00000 1.00000 + 0.00000 2.50000 + +ans = + + 2 1 + 1 3 + +d = + + 1.00000 + 0.50000 + +y = + + 1 + 1 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}5}]:} \PY{c}{\PYZpc{} what is the determinant of L, U and A?} + + \PY{n+nb}{det}\PY{p}{(}\PY{n}{A}\PY{p}{)} + \PY{n+nb}{det}\PY{p}{(}\PY{n}{L}\PY{p}{)} + \PY{n+nb}{det}\PY{p}{(}\PY{n}{U}\PY{p}{)} + \PY{n+nb}{det}\PY{p}{(}\PY{n}{L}\PY{p}{)}\PY{o}{*}\PY{n+nb}{det}\PY{p}{(}\PY{n}{U}\PY{p}{)} + \PY{n+nb}{det}\PY{p}{(}\PY{n}{L}\PY{o}{*}\PY{n}{U}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = 5.0000 +ans = 1 +ans = 5 +ans = 5 +ans = 5.0000 + + \end{Verbatim} + + \subsection{Pivoting for LU +factorization}\label{pivoting-for-lu-factorization} + +LU factorization uses the same method as Gauss elimination so it is also +necessary to perform partial pivoting when creating the lower and upper +triangular matrices. + +Matlab and Octave use pivoting in the command + +\texttt{{[}L,U,P{]}=lu(A)} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}4}]:} \PY{n}{help} \PY{n+nb}{lu} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +'lu' is a built-in function from the file libinterp/corefcn/lu.cc + + -- Built-in Function: [L, U] = lu (A) + -- Built-in Function: [L, U, P] = lu (A) + -- Built-in Function: [L, U, P, Q] = lu (S) + -- Built-in Function: [L, U, P, Q, R] = lu (S) + -- Built-in Function: [{\ldots}] = lu (S, THRES) + -- Built-in Function: Y = lu ({\ldots}) + -- Built-in Function: [{\ldots}] = lu ({\ldots}, "vector") + Compute the LU decomposition of A. + + If A is full subroutines from LAPACK are used and if A is sparse + then UMFPACK is used. + + The result is returned in a permuted form, according to the + optional return value P. For example, given the matrix 'a = [1, 2; + 3, 4]', + + [l, u, p] = lu (A) + + returns + + l = + + 1.00000 0.00000 + 0.33333 1.00000 + + u = + + 3.00000 4.00000 + 0.00000 0.66667 + + p = + + 0 1 + 1 0 + + The matrix is not required to be square. + + When called with two or three output arguments and a spare input + matrix, 'lu' does not attempt to perform sparsity preserving column + permutations. Called with a fourth output argument, the sparsity + preserving column transformation Q is returned, such that 'P * A * + Q = L * U'. + + Called with a fifth output argument and a sparse input matrix, 'lu' + attempts to use a scaling factor R on the input matrix such that 'P + * (R \textbackslash{} A) * Q = L * U'. This typically leads to a sparser and more + stable factorization. + + An additional input argument THRES, that defines the pivoting + threshold can be given. THRES can be a scalar, in which case it + defines the UMFPACK pivoting tolerance for both symmetric and + unsymmetric cases. If THRES is a 2-element vector, then the first + element defines the pivoting tolerance for the unsymmetric UMFPACK + pivoting strategy and the second for the symmetric strategy. By + default, the values defined by 'spparms' are used ([0.1, 0.001]). + + Given the string argument "vector", 'lu' returns the values of P + and Q as vector values, such that for full matrix, 'A (P,:) = L * + U', and 'R(P,:) * A (:, Q) = L * U'. + + With two output arguments, returns the permuted forms of the upper + and lower triangular matrices, such that 'A = L * U'. With one + output argument Y, then the matrix returned by the LAPACK routines + is returned. If the input matrix is sparse then the matrix L is + embedded into U to give a return value similar to the full case. + For both full and sparse matrices, 'lu' loses the permutation + information. + + See also: luupdate, ilu, chol, hess, qr, qz, schur, svd. + +Additional help for built-in functions and operators is +available in the online version of the manual. Use the command +'doc <topic>' to search the manual index. + +Help and information about Octave is also available on the WWW +at http://www.octave.org and via the help@octave.org +mailing list. + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}9}]:} \PY{c}{\PYZpc{} time LU solution vs backslash} + \PY{n}{t\PYZus{}lu}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{100}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}bs}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{100}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{k}{for} \PY{n}{N}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{100} + \PY{n}{A}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{n}{N}\PY{p}{,}\PY{n}{N}\PY{p}{)}\PY{p}{;} + \PY{n}{y}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{n}{N}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{p}{[}\PY{n}{L}\PY{p}{,}\PY{n}{U}\PY{p}{,}\PY{n}{P}\PY{p}{]}\PY{p}{=}\PY{n+nb}{lu}\PY{p}{(}\PY{n}{A}\PY{p}{)}\PY{p}{;} + + \PY{n+nb}{tic}\PY{p}{;} \PY{n}{d}\PY{p}{=}\PY{n+nb}{inv}\PY{p}{(}\PY{n}{L}\PY{p}{)}\PY{o}{*}\PY{n}{y}\PY{p}{;} \PY{n}{x}\PY{p}{=}\PY{n+nb}{inv}\PY{p}{(}\PY{n}{U}\PY{p}{)}\PY{o}{*}\PY{n}{d}\PY{p}{;} \PY{n}{t\PYZus{}lu}\PY{p}{(}\PY{n}{N}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + + \PY{n+nb}{tic}\PY{p}{;} \PY{n}{x}\PY{p}{=}\PY{n+nb}{inv}\PY{p}{(}\PY{n}{A}\PY{p}{)}\PY{o}{*}\PY{n}{y}\PY{p}{;} \PY{n}{t\PYZus{}bs}\PY{p}{(}\PY{n}{N}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{k}{end} + \PY{n+nb}{plot}\PY{p}{(}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{100}\PY{p}{]}\PY{p}{,}\PY{n}{t\PYZus{}lu}\PY{p}{,}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{100}\PY{p}{]}\PY{p}{,}\PY{n}{t\PYZus{}bs}\PY{p}{)} + \PY{n+nb}{legend}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{LU decomp\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{Octave \PYZbs{}\PYZbs{}\PYZsq{}}\PY{p}{)} +\end{Verbatim} + + \begin{center} + \adjustimage{max size={0.9\linewidth}{0.9\paperheight}}{lecture_11_files/lecture_11_8_0.pdf} + \end{center} + { \hspace*{\fill} \\} + + Consider the problem again from the intro to Linear Algebra, 4 masses +are connected in series to 4 springs with K=10 N/m. What are the final +positions of the masses? + +\begin{figure}[htbp] +\centering +\includegraphics{../lecture_09/mass_springs.png} +\caption{Springs-masses} +\end{figure} + +The masses haves the following amounts, 1, 2, 3, and 4 kg for masses +1-4. Using a FBD for each mass: + +\(m_{1}g+k(x_{2}-x_{1})-kx_{1}=0\) + +\(m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0\) + +\(m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0\) + +\(m_{4}g-k(x_{4}-x_{3})=0\) + +in matrix form: + +\(\left[ \begin{array}{cccc} 2k & -k & 0 & 0 \\ -k & 2k & -k & 0 \\ 0 & -k & 2k & -k \\ 0 & 0 & -k & k \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \end{array} \right]= \left[ \begin{array}{c} m_{1}g \\ m_{2}g \\ m_{3}g \\ m_{4}g \end{array} \right]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}10}]:} \PY{n}{k}\PY{p}{=}\PY{l+m+mi}{10}\PY{p}{;} \PY{c}{\PYZpc{} N/m} + \PY{n}{m1}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} \PY{c}{\PYZpc{} kg} + \PY{n}{m2}\PY{p}{=}\PY{l+m+mi}{2}\PY{p}{;} + \PY{n}{m3}\PY{p}{=}\PY{l+m+mi}{3}\PY{p}{;} + \PY{n}{m4}\PY{p}{=}\PY{l+m+mi}{4}\PY{p}{;} + \PY{n}{g}\PY{p}{=}\PY{l+m+mf}{9.81}\PY{p}{;} \PY{c}{\PYZpc{} m/s\PYZca{}2} + \PY{n}{K}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{0} \PY{l+m+mi}{0}\PY{p}{;} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{0}\PY{p}{;} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{l+m+mi}{2}\PY{o}{*}\PY{n}{k} \PY{o}{\PYZhy{}}\PY{n}{k}\PY{p}{;} \PY{l+m+mi}{0} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k} \PY{n}{k}\PY{p}{]} + \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{n}{m1}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m2}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m3}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m4}\PY{o}{*}\PY{n}{g}\PY{p}{]} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K = + + 20 -10 0 0 + -10 20 -10 0 + 0 -10 20 -10 + 0 0 -10 10 + +y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + \end{Verbatim} + + This matrix, K, is symmetric. + +\texttt{K(i,j)==K(j,i)} + +Now we can use, + +\subsection{Cholesky Factorization}\label{cholesky-factorization} + +We can decompose the matrix, K into two matrices, \(U\) and \(U^{T}\), +where + +\(K=U^{T}U\) + +each of the components of U can be calculated with the following +equations: + +\(u_{ii}=\sqrt{a_{ii}-\sum_{k=1}^{i-1}u_{ki}^{2}}\) + +\(u_{ij}=\frac{a_{ij}-\sum_{k=1}^{i-1}u_{ki}u_{kj}}{u_{ii}}\) + +so for K + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}11}]:} \PY{n}{K} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K = + + 20 -10 0 0 + -10 20 -10 0 + 0 -10 20 -10 + 0 0 -10 10 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}12}]:} \PY{n}{u11}\PY{p}{=}\PY{n+nb}{sqrt}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{)} + \PY{n}{u12}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{)}\PY{o}{/}\PY{n}{u11} + \PY{n}{u13}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)}\PY{o}{/}\PY{n}{u11} + \PY{n}{u14}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)}\PY{p}{)}\PY{o}{/}\PY{n}{u11} + \PY{n}{u22}\PY{p}{=}\PY{n+nb}{sqrt}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u12}\PYZca{}\PY{l+m+mi}{2}\PY{p}{)} + \PY{n}{u23}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u12}\PY{o}{*}\PY{n}{u13}\PY{p}{)}\PY{o}{/}\PY{n}{u22} + \PY{n}{u24}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u12}\PY{o}{*}\PY{n}{u14}\PY{p}{)}\PY{o}{/}\PY{n}{u22} + \PY{n}{u33}\PY{p}{=}\PY{n+nb}{sqrt}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u13}\PYZca{}\PY{l+m+mi}{2}\PY{o}{\PYZhy{}}\PY{n}{u23}\PYZca{}\PY{l+m+mi}{2}\PY{p}{)} + \PY{n}{u34}\PY{p}{=}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u13}\PY{o}{*}\PY{n}{u14}\PY{o}{\PYZhy{}}\PY{n}{u23}\PY{o}{*}\PY{n}{u24}\PY{p}{)}\PY{o}{/}\PY{n}{u33} + \PY{n}{u44}\PY{p}{=}\PY{n+nb}{sqrt}\PY{p}{(}\PY{n}{K}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{u14}\PYZca{}\PY{l+m+mi}{2}\PY{o}{\PYZhy{}}\PY{n}{u24}\PYZca{}\PY{l+m+mi}{2}\PY{o}{\PYZhy{}}\PY{n}{u34}\PYZca{}\PY{l+m+mi}{2}\PY{p}{)} + \PY{n}{U}\PY{p}{=}\PY{p}{[}\PY{n}{u11}\PY{p}{,}\PY{n}{u12}\PY{p}{,}\PY{n}{u13}\PY{p}{,}\PY{n}{u14}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{,}\PY{n}{u22}\PY{p}{,}\PY{n}{u23}\PY{p}{,}\PY{n}{u24}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{,}\PY{l+m+mi}{0}\PY{p}{,}\PY{n}{u33}\PY{p}{,}\PY{n}{u34}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{,}\PY{l+m+mi}{0}\PY{p}{,}\PY{l+m+mi}{0}\PY{p}{,}\PY{n}{u44}\PY{p}{]} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +u11 = 4.4721 +u12 = -2.2361 +u13 = 0 +u14 = 0 +u22 = 3.8730 +u23 = -2.5820 +u24 = 0 +u33 = 3.6515 +u34 = -2.7386 +u44 = 1.5811 +U = + + 4.47214 -2.23607 0.00000 0.00000 + 0.00000 3.87298 -2.58199 0.00000 + 0.00000 0.00000 3.65148 -2.73861 + 0.00000 0.00000 0.00000 1.58114 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}17}]:} \PY{p}{(}\PY{n}{U}\PY{o}{\PYZsq{}}\PY{o}{*}\PY{n}{U}\PY{p}{)}\PY{o}{\PYZsq{}}\PY{o}{==}\PY{n}{U}\PY{o}{\PYZsq{}}\PY{o}{*}\PY{n}{U} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 1 1 1 1 + 1 1 1 1 + 1 1 1 1 + 1 1 1 1 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}18}]:} \PY{c}{\PYZpc{} time solution for Cholesky vs backslash} + \PY{n}{t\PYZus{}chol}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{1000}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}bs}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{1000}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{k}{for} \PY{n}{i}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{:}\PY{l+m+mi}{1000} + \PY{n+nb}{tic}\PY{p}{;} \PY{n}{d}\PY{p}{=}\PY{n}{U}\PY{o}{\PYZsq{}}\PY{o}{*}\PY{n}{y}\PY{p}{;} \PY{n}{x}\PY{p}{=}\PY{n}{U}\PY{o}{\PYZbs{}}\PY{n}{d}\PY{p}{;} \PY{n}{t\PYZus{}chol}\PY{p}{(}\PY{n}{i}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} \PY{n}{x}\PY{p}{=}\PY{n}{K}\PY{o}{\PYZbs{}}\PY{n}{y}\PY{p}{;} \PY{n}{t\PYZus{}bs}\PY{p}{(}\PY{n}{i}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{k}{end} + \PY{n+nb}{fprintf}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{average time spent for Cholesky factored solution = \PYZpc{}e+/\PYZhy{}\PYZpc{}e\PYZsq{}}\PY{p}{,}\PY{n+nb}{mean}\PY{p}{(}\PY{n}{t\PYZus{}chol}\PY{p}{)}\PY{p}{,}\PY{n+nb}{std}\PY{p}{(}\PY{n}{t\PYZus{}chol}\PY{p}{)}\PY{p}{)} + + \PY{n+nb}{fprintf}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{average time spent for backslash solution = \PYZpc{}e+/\PYZhy{}\PYZpc{}e\PYZsq{}}\PY{p}{,}\PY{n+nb}{mean}\PY{p}{(}\PY{n}{t\PYZus{}bs}\PY{p}{)}\PY{p}{,}\PY{n+nb}{std}\PY{p}{(}\PY{n}{t\PYZus{}bs}\PY{p}{)}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +average time spent for Cholesky factored solution = 1.465964e-05+/-9.806001e-06 +average time spent for backslash solution = 1.555967e-05+/-1.048561e-05 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor} }]:} +\end{Verbatim} + + + % Add a bibliography block to the postdoc + + + + \end{document} diff --git a/lecture_11/lecture_11_files/lecture_11_6_0.pdf b/lecture_11/lecture_11_files/lecture_11_6_0.pdf new file mode 100644 index 0000000..40e3f28 Binary files /dev/null and b/lecture_11/lecture_11_files/lecture_11_6_0.pdf differ diff --git a/lecture_11/lecture_11_files/lecture_11_6_0.svg b/lecture_11/lecture_11_files/lecture_11_6_0.svg new file mode 100644 index 0000000..bb1f18d --- /dev/null +++ b/lecture_11/lecture_11_files/lecture_11_6_0.svg @@ -0,0 +1,149 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="78.8,384.0 534.9,384.0 534.9,16.8 78.8,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,384.0 L91.3,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,390.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,322.8 L91.3,322.8 M535.0,322.8 L522.5,322.8 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,328.8)"> + <text><tspan font-family="{}">5e-05</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,261.6 L91.3,261.6 M535.0,261.6 L522.5,261.6 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,267.6)"> + <text><tspan font-family="{}">0.0001</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,200.3 L91.3,200.3 M535.0,200.3 L522.5,200.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,206.3)"> + <text><tspan font-family="{}">0.00015</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,139.1 L91.3,139.1 M535.0,139.1 L522.5,139.1 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,145.1)"> + <text><tspan font-family="{}">0.0002</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,77.9 L91.3,77.9 M535.0,77.9 L522.5,77.9 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,83.9)"> + <text><tspan font-family="{}">0.00025</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,16.7 L91.3,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(70.5,22.7)"> + <text><tspan font-family="{}">0.0003</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,384.0 L78.8,371.5 M78.8,16.7 L78.8,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(78.8,408.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M170.0,384.0 L170.0,371.5 M170.0,16.7 L170.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(170.0,408.0)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M261.3,384.0 L261.3,371.5 M261.3,16.7 L261.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(261.3,408.0)"> + <text><tspan font-family="{}">40</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M352.5,384.0 L352.5,371.5 M352.5,16.7 L352.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(352.5,408.0)"> + <text><tspan font-family="{}">60</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M443.8,384.0 L443.8,371.5 M443.8,16.7 L443.8,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(443.8,408.0)"> + <text><tspan font-family="{}">80</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">100</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M78.8,16.7 L78.8,384.0 L535.0,384.0 L535.0,16.7 L78.8,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>LU decomp</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,55.7)"> + <text><tspan font-family="{}">LU decomp</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M360.9,49.7 L414.7,49.7 M83.4,330.3 L87.9,244.5 L92.5,289.7 L97.0,292.1 L101.6,288.5 L106.2,289.7 L110.7,287.1 L115.3,283.6 L119.9,279.8 L124.4,276.3 L129.0,276.3 L133.5,265.5 L138.1,269.0 L142.7,266.4 L147.2,261.7 L151.8,261.7 L156.4,271.3 L160.9,269.9 L165.5,274.8 L170.0,272.5 L174.6,268.7 L179.2,212.7 L183.7,256.7 L188.3,261.4 L192.9,260.2 L197.4,234.5 L202.0,270.2 L206.5,269.0 L211.1,249.4 L215.7,265.2 L220.2,303.1 L224.8,298.2 L229.3,300.8 L233.9,299.6 L238.5,292.3 L243.0,299.3 L247.6,298.2 L252.2,294.7 L256.7,284.8 L261.3,282.4 L265.8,306.9 L270.4,297.0 L275.0,303.1 L279.5,306.9 L284.1,299.3 L288.7,283.6 L293.2,294.4 L297.8,295.8 L302.3,292.3 L306.9,292.1 L311.5,283.6 L316.0,287.4 L320.6,286.2 L325.1,272.8 L329.7,293.2 L334.3,292.1 L338.8,294.7 L343.4,293.2 L348.0,292.1 L352.5,302.0 L357.1,302.0 L361.6,302.0 L366.2,299.6 L370.8,293.2 L375.3,277.5 L379.9,294.7 L384.5,292.1 L389.0,289.7 L393.6,289.7 L398.1,288.5 L402.7,286.2 L407.3,288.5 L411.8,234.5 L416.4,285.9 L421.0,282.4 L425.5,241.8 L430.1,241.8 L434.6,279.8 L439.2,266.4 L443.8,280.1 L448.3,259.1 L452.9,229.6 L457.4,277.7 L462.0,283.6 L466.6,276.3 L471.1,278.6 L475.7,277.5 L480.3,277.5 L484.8,274.8 L489.4,265.2 L493.9,270.2 L498.5,272.5 L503.1,259.1 L507.6,264.0 L512.2,264.0 L516.8,266.4 L521.3,261.4 L525.9,264.0 L530.4,247.1 L535.0,259.1 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>Octave \\</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,103.7)"> + <text><tspan font-family="{}">Octave \</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M360.9,97.7 L414.7,97.7 M83.4,359.5 L87.9,287.4 L92.5,306.6 L97.0,311.9 L101.6,305.8 L106.2,306.9 L110.7,305.5 L115.3,303.1 L119.9,293.2 L124.4,292.3 L129.0,262.6 L133.5,278.6 L138.1,272.8 L142.7,232.2 L147.2,265.2 L151.8,260.2 L156.4,275.1 L160.9,238.3 L165.5,231.9 L170.0,240.7 L174.6,221.1 L179.2,229.9 L183.7,221.1 L188.3,218.8 L192.9,198.9 L197.4,185.8 L202.0,218.8 L206.5,221.1 L211.1,216.2 L215.7,213.8 L220.2,265.2 L224.8,265.2 L229.3,269.9 L233.9,254.1 L238.5,256.7 L243.0,256.7 L247.6,249.1 L252.2,247.1 L256.7,241.8 L261.3,204.2 L265.8,265.2 L270.4,262.9 L275.0,243.3 L279.5,264.0 L284.1,252.9 L288.7,249.4 L293.2,247.1 L297.8,245.6 L302.3,241.0 L306.9,229.9 L311.5,205.4 L316.0,229.9 L320.6,205.1 L325.1,222.3 L329.7,241.0 L334.3,244.2 L338.8,238.3 L343.4,227.2 L348.0,218.5 L352.5,250.6 L357.1,250.6 L361.6,246.8 L366.2,232.2 L370.8,240.7 L375.3,238.3 L379.9,220.0 L384.5,207.7 L389.0,222.6 L393.6,217.6 L398.1,215.0 L402.7,212.7 L407.3,213.8 L411.8,223.5 L416.4,208.9 L421.0,205.4 L425.5,196.6 L430.1,184.6 L434.6,190.5 L439.2,195.4 L443.8,185.8 L448.3,177.0 L452.9,183.2 L457.4,180.8 L462.0,188.1 L466.6,164.8 L471.1,164.8 L475.7,175.9 L480.3,175.9 L484.8,169.7 L489.4,165.9 L493.9,161.0 L498.5,75.5 L503.1,150.2 L507.6,135.3 L512.2,150.2 L516.8,145.5 L521.3,147.6 L525.9,134.1 L530.4,126.8 L535.0,135.3 " stroke="rgb( 0, 128, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 128, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_11/lecture_11_files/lecture_11_8_0.pdf b/lecture_11/lecture_11_files/lecture_11_8_0.pdf new file mode 100644 index 0000000..7f562c6 Binary files /dev/null and b/lecture_11/lecture_11_files/lecture_11_8_0.pdf differ diff --git a/lecture_11/lecture_11_files/lecture_11_8_0.svg b/lecture_11/lecture_11_files/lecture_11_8_0.svg new file mode 100644 index 0000000..37a1c3f --- /dev/null +++ b/lecture_11/lecture_11_files/lecture_11_8_0.svg @@ -0,0 +1,139 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,390.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,298.2)"> + <text><tspan font-family="{}">0.0005</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,206.3)"> + <text><tspan font-family="{}">0.001</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,114.5)"> + <text><tspan font-family="{}">0.0015</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,22.7)"> + <text><tspan font-family="{}">0.002</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(70.5,408.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(163.4,408.0)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(256.3,408.0)"> + <text><tspan font-family="{}">40</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(349.2,408.0)"> + <text><tspan font-family="{}">60</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(442.1,408.0)"> + <text><tspan font-family="{}">80</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">100</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>LU decomp</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,55.7)"> + <text><tspan font-family="{}">LU decomp</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M360.9,49.7 L414.7,49.7 M75.1,357.4 L79.8,366.4 L84.4,370.3 L89.1,369.9 L93.7,363.8 L98.4,369.5 L103.0,369.5 L107.7,362.2 L112.3,368.4 L117.0,368.0 L121.6,360.8 L126.2,366.5 L130.9,366.6 L135.5,355.4 L140.2,355.5 L144.8,353.0 L149.5,346.7 L154.1,360.0 L158.8,362.3 L163.4,361.2 L168.0,362.3 L172.7,355.7 L177.3,360.3 L182.0,356.9 L186.6,355.1 L191.3,357.9 L195.9,351.3 L200.6,356.6 L205.2,355.0 L209.9,355.4 L214.5,362.2 L219.1,360.9 L223.8,360.8 L228.4,359.7 L233.1,359.0 L237.7,356.5 L242.4,358.3 L247.0,356.6 L251.7,360.7 L256.3,360.3 L260.9,360.0 L265.6,359.0 L270.2,359.0 L274.9,357.6 L279.5,357.4 L284.2,356.2 L288.8,354.2 L293.5,359.6 L298.1,358.5 L302.8,357.9 L307.4,356.5 L312.0,356.5 L316.7,355.9 L321.3,355.1 L326.0,353.9 L330.6,352.4 L335.3,357.0 L339.9,356.6 L344.6,355.9 L349.2,355.2 L353.8,354.1 L358.5,353.1 L363.1,352.6 L367.8,351.5 L372.4,335.7 L377.1,356.3 L381.7,356.6 L386.4,352.6 L391.0,355.5 L395.7,355.5 L400.3,354.6 L404.9,355.1 L409.6,224.4 L414.2,352.4 L418.9,338.8 L423.5,351.5 L428.2,350.8 L432.8,350.4 L437.5,349.7 L442.1,350.4 L446.7,348.4 L451.4,347.8 L456.0,346.2 L460.7,347.0 L465.3,340.7 L470.0,338.6 L474.6,346.2 L479.3,347.3 L483.9,344.2 L488.6,343.8 L493.2,342.5 L497.8,343.2 L502.5,341.2 L507.1,342.5 L511.8,338.8 L516.4,342.3 L521.1,337.9 L525.7,338.3 L530.4,337.8 L535.0,339.2 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>Octave \\</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(526.7,103.7)"> + <text><tspan font-family="{}">Octave \</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M360.9,97.7 L414.7,97.7 M75.1,371.7 L79.8,368.6 L84.4,372.8 L89.1,372.4 L93.7,371.3 L98.4,371.7 L103.0,371.3 L107.7,369.9 L112.3,370.3 L117.0,370.2 L121.6,368.6 L126.2,368.9 L130.9,364.9 L135.5,357.0 L140.2,358.5 L144.8,354.4 L149.5,353.0 L154.1,358.7 L158.8,359.8 L163.4,360.1 L168.0,360.7 L172.7,355.2 L177.3,353.7 L182.0,355.4 L186.6,337.5 L191.3,353.7 L195.9,349.1 L200.6,354.4 L205.2,350.4 L209.9,329.8 L214.5,357.6 L219.1,353.7 L223.8,357.6 L228.4,350.4 L233.1,354.4 L237.7,353.9 L242.4,352.4 L247.0,140.3 L251.7,355.1 L256.3,356.8 L260.9,355.5 L265.6,352.6 L270.2,353.3 L274.9,353.9 L279.5,351.7 L284.2,350.8 L288.8,341.2 L293.5,355.2 L298.1,353.0 L302.8,352.6 L307.4,350.6 L312.0,351.3 L316.7,343.8 L321.3,348.0 L326.0,347.3 L330.6,345.4 L335.3,351.5 L339.9,338.1 L344.6,348.7 L349.2,349.1 L353.8,347.3 L358.5,346.9 L363.1,343.2 L367.8,343.6 L372.4,343.2 L377.1,335.7 L381.7,342.7 L386.4,344.5 L391.0,345.8 L395.7,345.6 L400.3,332.4 L404.9,340.7 L409.6,341.9 L414.2,262.6 L418.9,340.1 L423.5,331.8 L428.2,339.4 L432.8,338.3 L437.5,334.6 L442.1,335.5 L446.7,328.7 L451.4,333.3 L456.0,328.7 L460.7,331.3 L465.3,329.7 L470.0,327.8 L474.6,323.0 L479.3,324.8 L483.9,114.6 L488.6,315.3 L493.2,314.0 L497.8,301.7 L502.5,315.3 L507.1,319.2 L511.8,314.6 L516.4,315.1 L521.1,311.6 L525.7,313.1 L530.4,302.3 L535.0,305.2 " stroke="rgb( 0, 128, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb( 0, 128, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_11/mass_springs.png b/lecture_11/mass_springs.png new file mode 100644 index 0000000..259a333 Binary files /dev/null and b/lecture_11/mass_springs.png differ diff --git a/lecture_11/mass_springs.svg b/lecture_11/mass_springs.svg new file mode 100644 index 0000000..2bec8a4 --- /dev/null +++ b/lecture_11/mass_springs.svg @@ -0,0 +1,214 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!-- Created with Inkscape (http://www.inkscape.org/) --> + +<svg + xmlns:dc="http://purl.org/dc/elements/1.1/" + xmlns:cc="http://creativecommons.org/ns#" + xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" + xmlns:svg="http://www.w3.org/2000/svg" + xmlns="http://www.w3.org/2000/svg" + xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" + xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" + width="2in" + height="3in" + viewBox="0 0 180 270.00001" + id="svg7576" + version="1.1" + inkscape:version="0.91 r13725" + sodipodi:docname="mass_springs.svg"> + <defs + id="defs7578" /> + <sodipodi:namedview + id="base" + pagecolor="#ffffff" + bordercolor="#666666" + borderopacity="1.0" + inkscape:pageopacity="0.0" + inkscape:pageshadow="2" + inkscape:zoom="2" + inkscape:cx="7.6217341" + inkscape:cy="150.34609" + inkscape:document-units="px" + inkscape:current-layer="layer1" + showgrid="false" + units="in" + inkscape:window-width="1920" + inkscape:window-height="1019" + inkscape:window-x="0" + inkscape:window-y="27" + inkscape:window-maximized="1" /> + <metadata + id="metadata7581"> + <rdf:RDF> + <cc:Work + rdf:about=""> + <dc:format>image/svg+xml</dc:format> + <dc:type + rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> + <dc:title></dc:title> + </cc:Work> + </rdf:RDF> + </metadata> + <g + inkscape:label="Layer 1" + inkscape:groupmode="layer" + id="layer1" + transform="translate(0,-782.36215)"> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 25.411765,803.96215 136.588235,0" + id="path8124" + inkscape:connector-curvature="0" /> + <rect + style="opacity:1;fill:none;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect8126-0-5" + width="22.66995" + height="22.166191" + x="81.006226" + y="941.9967" + ry="9.7905083" + rx="0" /> + <rect + style="opacity:1;fill:none;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect8126" + width="22.66995" + height="22.166191" + x="81.006226" + y="835.7912" + ry="9.7905083" + rx="0" /> + <rect + style="opacity:1;fill:none;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect8126-0" + width="22.66995" + height="22.166191" + x="81.006226" + y="888.88458" + ry="9.7905083" + rx="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 94.616074,803.6445 0,6.16471 -6.670588,5.4 8.705882,4.22353 -8.388235,5.49412 6.035294,5.17647 0,5.30588" + id="path8191" + inkscape:connector-curvature="0" + sodipodi:nodetypes="ccccccc" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 94.616074,857.3772 0,6.16471 -6.670588,5.4 8.705882,4.22353 -8.388235,5.49412 6.035294,5.17647 0,5.30588" + id="path8191-6" + inkscape:connector-curvature="0" + sodipodi:nodetypes="ccccccc" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 94.616074,911.3772 0,6.16471 -6.670588,5.4 8.705882,4.22353 -8.388235,5.49412 6.035294,5.17647 0,5.30588" + id="path8191-6-6" + inkscape:connector-curvature="0" + sodipodi:nodetypes="ccccccc" /> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="105.56688" + y="850.21277" + id="text8223" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan8225" + x="105.56688" + y="850.21277" + style="font-size:27.5px">m<tspan + style="font-size:64.99999762%;baseline-shift:sub" + id="tspan8229">1</tspan></tspan></text> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="106.67688" + y="907.24207" + id="text8223-4" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan8225-0" + x="106.67688" + y="907.24207" + style="font-size:27.5px">m<tspan + style="font-size:64.99999762%;baseline-shift:sub" + id="tspan8229-0">2</tspan></tspan></text> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="108.5006" + y="961.43335" + id="text8223-4-4" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan8225-0-6" + x="108.5006" + y="961.43335" + style="font-size:27.5px">m<tspan + style="font-size:64.99999762%;baseline-shift:sub" + id="tspan8229-0-2">3</tspan></tspan></text> + <rect + style="opacity:1;fill:none;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" + id="rect8126-0-5-6" + width="22.66995" + height="22.166191" + x="80.311447" + y="995.02972" + ry="9.7905083" + rx="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 93.921299,964.41026 0,6.16471 -6.670588,5.4 8.705879,4.22353 -8.388232,5.49412 6.035294,5.17647 0,5.30588" + id="path8191-6-6-7" + inkscape:connector-curvature="0" + sodipodi:nodetypes="ccccccc" /> + <text + xml:space="preserve" + style="font-style:normal;font-weight:normal;font-size:40px;line-height:125%;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + x="107.80582" + y="1014.4664" + id="text8223-4-4-5" + sodipodi:linespacing="125%"><tspan + sodipodi:role="line" + id="tspan8225-0-6-6" + x="107.80582" + y="1014.4664" + style="font-size:27.5px">m<tspan + style="font-size:64.99999762%;baseline-shift:sub" + id="tspan8229-0-2-9">4</tspan></tspan></text> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 25.955575,803.80746 17.08955,-18.73167" + id="path8300" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 66.538797,803.80746 17.08955,-18.73167" + id="path8300-8" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 127.41363,803.80746 17.08955,-18.73167" + id="path8300-8-7" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 107.12201,803.80746 17.08955,-18.73167" + id="path8300-8-7-2" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 46.247187,803.80746 17.08955,-18.73167" + id="path8300-8-7-2-8" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="M 86.830398,803.80746 103.91995,785.07579" + id="path8300-8-7-2-8-2" + inkscape:connector-curvature="0" /> + <path + style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="m 147.70523,803.80746 17.08955,-18.73167" + id="path8300-8-7-2-8-2-9" + inkscape:connector-curvature="0" /> + </g> +</svg> diff --git a/lecture_11/midterm_date.png b/lecture_11/midterm_date.png new file mode 100644 index 0000000..4dd0663 Binary files /dev/null and b/lecture_11/midterm_date.png differ diff --git a/lecture_11/nohup.out b/lecture_11/nohup.out new file mode 100644 index 0000000..838862f --- /dev/null +++ b/lecture_11/nohup.out @@ -0,0 +1,2 @@ + +(evince:15386): Gtk-WARNING **: gtk_widget_size_allocate(): attempt to allocate widget with width -71 and height 20 diff --git a/lecture_11/octave-workspace b/lecture_11/octave-workspace new file mode 100644 index 0000000..8c437bb Binary files /dev/null and b/lecture_11/octave-workspace differ diff --git a/lecture_12/.ipynb_checkpoints/lecture_12-checkpoint.ipynb b/lecture_12/.ipynb_checkpoints/lecture_12-checkpoint.ipynb new file mode 100644 index 0000000..1332b29 --- /dev/null +++ b/lecture_12/.ipynb_checkpoints/lecture_12-checkpoint.ipynb @@ -0,0 +1,1483 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 47, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 48, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## My question from last class \n", + "\n", + "\n", + "## Your questions from last class\n", + "\n", + "1. Need more linear algebra review\n", + " \n", + " -We will keep doing Linear Algebra, try the practice problems in 'linear_algebra'\n", + "\n", + "2. How do I do HW3? \n", + " \n", + " -demo today\n", + "\n", + "3. For hw4 is the spring constant (K) suppose to be given? \n", + " \n", + " -yes, its 30 N/m\n", + " \n", + "4. Deapool or Joker?" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Matrix Inverse and Condition\n", + "\n", + "\n", + "Considering the same solution set:\n", + "\n", + "$y=Ax$\n", + "\n", + "If we know that $A^{-1}A=I$, then \n", + "\n", + "$A^{-1}y=A^{-1}Ax=x$\n", + "\n", + "so \n", + "\n", + "$x=A^{-1}y$\n", + "\n", + "Where, $A^{-1}$ is the inverse of matrix $A$.\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "$Ax=y$\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "1 & 3 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "$A^{-1}=\\frac{1}{2*3-1*1}\\left[ \\begin{array}{cc}\n", + "3 & 1 \\\\\n", + "-1 & 2 \\end{array} \\right]=\n", + "\\left[ \\begin{array}{cc}\n", + "3/5 & -1/5 \\\\\n", + "-1/5 & 2/5 \\end{array} \\right]$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "invA =\n", + "\n", + " 0.60000 -0.20000\n", + " -0.20000 0.40000\n", + "\n", + "ans =\n", + "\n", + " 1.00000 0.00000\n", + " 0.00000 1.00000\n", + "\n", + "ans =\n", + "\n", + " 1.00000 0.00000\n", + " 0.00000 1.00000\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "invA=1/5*[3,-1;-1,2]\n", + "\n", + "A*invA\n", + "invA*A" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "How did we know the inverse of A? \n", + "\n", + "for 2$\\times$2 matrices, it is always:\n", + "\n", + "$A=\\left[ \\begin{array}{cc}\n", + "A_{11} & A_{12} \\\\\n", + "A_{21} & A_{22} \\end{array} \\right]$\n", + "\n", + "$A^{-1}=\\frac{1}{det(A)}\\left[ \\begin{array}{cc}\n", + "A_{22} & -A_{12} \\\\\n", + "-A_{21} & A_{11} \\end{array} \\right]$" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "$AA^{-1}=\\frac{1}{A_{11}A_{22}-A_{21}A_{12}}\\left[ \\begin{array}{cc}\n", + "A_{11}A_{22}-A_{21}A_{12} & -A_{11}A_{12}+A_{12}A_{11} \\\\\n", + "A_{21}A_{22}-A_{22}A_{21} & -A_{21}A_{12}+A_{22}A_{11} \\end{array} \\right]\n", + "=\\left[ \\begin{array}{cc}\n", + "1 & 0 \\\\\n", + "0 & 1 \\end{array} \\right]$" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "What about bigger matrices?\n", + "\n", + "We can use the LU-decomposition\n", + "\n", + "$A=LU$\n", + "\n", + "$A^{-1}=(LU)^{-1}=U^{-1}L^{-1}$\n", + "\n", + "if we divide $A^{-1}$ into n-column vectors, $a_{n}$, then\n", + "\n", + "$Aa_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$Aa_{2}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$Aa_{n}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "1 \\end{array} \\right]$\n", + "\n", + "\n", + "Which we can solve for each $a_{n}$ with LU-decomposition, knowing the lower and upper triangular decompositions, then \n", + "\n", + "$A^{-1}=\\left[ \\begin{array}{cccc}\n", + "| & | & & | \\\\\n", + "a_{1} & a_{2} & \\cdots & a_{3} \\\\\n", + "| & | & & | \\end{array} \\right]$\n", + "\n", + "\n", + "$Ld_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$;~Ua_{1}=d_{1}$\n", + "\n", + "$Ld_{2}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$;~Ua_{2}=d_{2}$\n", + "\n", + "$Ld_{n}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "n \\end{array} \\right]$\n", + "$;~Ua_{n}=d_{n}$\n", + "\n", + "Consider the following matrix:\n", + "\n", + "$A=\\left[ \\begin{array}{ccc}\n", + "2 & -1 & 0\\\\\n", + "-1 & 2 & -1\\\\\n", + "0 & -1 & 1 \\end{array} \\right]$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 21, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 -1 0\n", + " -1 2 -1\n", + " 0 -1 1\n", + "\n", + "U =\n", + "\n", + " 2.00000 -1.00000 0.00000\n", + " 0.00000 1.50000 -1.00000\n", + " 0.00000 -1.00000 1.00000\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " -0.50000 1.00000 0.00000\n", + " 0.00000 0.00000 1.00000\n", + "\n" + ] + } + ], + "source": [ + "A=[2,-1,0;-1,2,-1;0,-1,1]\n", + "U=A;\n", + "L=eye(3,3);\n", + "U(2,:)=U(2,:)-U(2,1)/U(1,1)*U(1,:)\n", + "L(2,1)=A(2,1)/A(1,1)" + ] + }, + { + "cell_type": "code", + "execution_count": 22, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " -0.50000 1.00000 0.00000\n", + " 0.00000 -0.66667 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 -1.00000 0.00000\n", + " 0.00000 1.50000 -1.00000\n", + " 0.00000 0.00000 0.33333\n", + "\n" + ] + } + ], + "source": [ + "L(3,2)=U(3,2)/U(2,2)\n", + "U(3,:)=U(3,:)-U(3,2)/U(2,2)*U(2,:)\n" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Now solve for $d_1$ then $a_1$, $d_2$ then $a_2$, and $d_3$ then $a_{3}$\n", + "\n", + "$Ld_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$;~Ua_{1}=d_{1}$" + ] + }, + { + "cell_type": "code", + "execution_count": 29, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d1 =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + " 0.33333\n", + "\n" + ] + } + ], + "source": [ + "d1=zeros(3,1);\n", + "d1(1)=1;\n", + "d1(2)=0-L(2,1)*d1(1);\n", + "d1(3)=0-L(3,1)*d1(1)-L(3,2)*d1(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 30, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a1 =\n", + "\n", + " 1.00000\n", + " 1.00000\n", + " 1.00000\n", + "\n" + ] + } + ], + "source": [ + "a1=zeros(3,1);\n", + "a1(3)=d1(3)/U(3,3);\n", + "a1(2)=1/U(2,2)*(d1(2)-U(2,3)*a1(3));\n", + "a1(1)=1/U(1,1)*(d1(1)-U(1,2)*a1(2)-U(1,3)*a1(3))" + ] + }, + { + "cell_type": "code", + "execution_count": 28, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d2 =\n", + "\n", + " 0.00000\n", + " 1.00000\n", + " 0.66667\n", + "\n" + ] + } + ], + "source": [ + "d2=zeros(3,1);\n", + "d2(1)=0;\n", + "d2(2)=1-L(2,1)*d2(1);\n", + "d2(3)=0-L(3,1)*d2(1)-L(3,2)*d2(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 31, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a2 =\n", + "\n", + " 1.0000\n", + " 2.0000\n", + " 2.0000\n", + "\n" + ] + } + ], + "source": [ + "a2=zeros(3,1);\n", + "a2(3)=d2(3)/U(3,3);\n", + "a2(2)=1/U(2,2)*(d2(2)-U(2,3)*a2(3));\n", + "a2(1)=1/U(1,1)*(d2(1)-U(1,2)*a2(2)-U(1,3)*a2(3))" + ] + }, + { + "cell_type": "code", + "execution_count": 37, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d3 =\n", + "\n", + " 0\n", + " 0\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "d3=zeros(3,1);\n", + "d3(1)=0;\n", + "d3(2)=0-L(2,1)*d3(1);\n", + "d3(3)=1-L(3,1)*d3(1)-L(3,2)*d3(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 38, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a3 =\n", + "\n", + " 1.00000\n", + " 2.00000\n", + " 3.00000\n", + "\n" + ] + } + ], + "source": [ + "a3=zeros(3,1);\n", + "a3(3)=d3(3)/U(3,3);\n", + "a3(2)=1/U(2,2)*(d3(2)-U(2,3)*a3(3));\n", + "a3(1)=1/U(1,1)*(d3(1)-U(1,2)*a3(2)-U(1,3)*a3(3))" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Final solution for $A^{-1}$ is $[a_{1}~a_{2}~a_{3}]$" + ] + }, + { + "cell_type": "code", + "execution_count": 40, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "invA =\n", + "\n", + " 1.00000 1.00000 1.00000\n", + " 1.00000 2.00000 2.00000\n", + " 1.00000 2.00000 3.00000\n", + "\n", + "ans =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " 0.00000 1.00000 -0.00000\n", + " -0.00000 -0.00000 1.00000\n", + "\n" + ] + } + ], + "source": [ + "invA=[a1,a2,a3]\n", + "A*invA" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Now the solution of $x$ to $Ax=y$ is $x=A^{-1}y$" + ] + }, + { + "cell_type": "code", + "execution_count": 44, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "y =\n", + "\n", + " 1\n", + " 2\n", + " 3\n", + "\n", + "x =\n", + "\n", + " 6.0000\n", + " 11.0000\n", + " 14.0000\n", + "\n", + "xbs =\n", + "\n", + " 6.0000\n", + " 11.0000\n", + " 14.0000\n", + "\n", + "ans =\n", + "\n", + " -3.5527e-15\n", + " -8.8818e-15\n", + " -1.0658e-14\n", + "\n", + "ans = 2.2204e-16\n" + ] + } + ], + "source": [ + "y=[1;2;3]\n", + "x=invA*y\n", + "xbs=A\\y\n", + "x-xbs\n", + "eps" + ] + }, + { + "cell_type": "code", + "execution_count": 61, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,298.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0005</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,114.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(70.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(163.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(256.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(349.2,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(442.1,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M78.8,169.7 L78.8,25.7 L311.8,25.7 L311.8,169.7 L78.8,169.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>inversion</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">inversion</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,49.7 L143.8,49.7 M75.1,367.8 L79.8,374.3 L84.4,375.7 L89.1,375.5 L93.7,375.5 L98.4,375.2 L103.0,374.6 L107.7,374.5 L112.3,373.4 L117.0,372.8 L121.6,368.2 L126.2,372.4 L130.9,372.0 L135.5,371.5 L140.2,371.1 L144.8,369.7 L149.5,373.5 L154.1,250.8 L158.8,365.1 L163.4,364.9 L168.0,364.2 L172.7,362.5 L177.3,362.2 L182.0,361.1 L186.6,359.9 L191.3,360.1 L195.9,357.4 L200.6,358.3 L205.2,356.3 L209.9,362.5 L213.7,16.7 M215.3,16.7 L219.1,360.7 L223.8,360.5 L228.4,356.3 L233.1,354.6 L237.7,356.8 L242.4,354.4 L247.0,360.1 L251.7,359.6 L256.3,359.0 L260.9,358.5 L265.6,356.1 L270.2,356.5 L274.9,354.8 L279.5,354.1 L284.2,351.9 L288.8,351.3 L293.5,352.0 L298.1,350.0 L302.8,348.4 L307.4,348.0 L312.0,354.4 L316.7,351.5 L321.3,352.4 L326.0,351.3 L330.6,351.7 L335.3,346.3 L339.9,345.4 L344.6,347.3 L349.2,347.4 L353.8,345.2 L358.5,342.5 L363.1,344.3 L367.8,347.1 L372.4,338.9 L377.1,340.1 L381.7,340.1 L386.4,329.3 L391.0,337.0 L395.7,319.7 L400.3,338.6 L404.9,340.0 L409.6,336.3 L414.2,335.3 L418.9,333.7 L423.5,333.3 L428.2,330.2 L432.8,328.7 L437.5,332.8 L442.1,327.4 L446.7,325.6 L451.4,326.5 L456.0,325.2 L460.7,324.5 L465.3,320.3 L470.0,325.4 L474.6,319.4 L479.3,322.1 L483.9,319.7 L488.6,321.2 L493.2,315.7 L497.8,316.6 L502.5,299.5 L507.1,317.5 L511.8,310.4 L516.4,318.2 L521.1,314.0 L525.7,316.6 L530.4,311.8 L535.0,314.0 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>backslash</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">backslash</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,97.7 L143.8,97.7 M75.1,381.3 L79.8,377.7 L84.4,378.8 L89.1,378.7 L93.7,378.7 L98.4,377.2 L103.0,378.0 L107.7,378.0 L112.3,377.2 L117.0,376.6 L121.6,376.3 L126.2,376.1 L130.9,375.8 L135.5,375.9 L140.2,375.5 L144.8,377.6 L149.5,377.0 L154.1,370.4 L158.8,371.0 L163.4,371.0 L168.0,371.0 L172.7,369.3 L177.3,370.0 L182.0,369.3 L186.6,368.6 L191.3,368.0 L195.9,367.3 L200.6,366.6 L205.2,366.7 L209.9,370.3 L214.5,367.7 L219.1,369.5 L223.8,340.8 L228.4,367.3 L233.1,367.6 L237.7,367.1 L242.4,368.9 L247.0,369.3 L251.7,368.6 L256.3,368.8 L260.9,368.4 L265.6,367.7 L270.2,367.1 L274.9,365.3 L279.5,366.6 L284.2,364.2 L288.8,365.1 L293.5,365.6 L298.1,364.9 L302.8,363.1 L307.4,366.0 L312.0,366.2 L316.7,363.8 L321.3,365.6 L326.0,365.1 L330.6,365.3 L335.3,362.5 L339.9,362.3 L344.6,363.4 L349.2,363.1 L353.8,362.9 L358.5,364.0 L363.1,361.1 L367.8,363.8 L372.4,361.4 L377.1,352.7 L381.7,357.9 L386.4,359.7 L391.0,355.2 L395.7,358.3 L400.3,357.0 L404.9,358.5 L409.6,357.6 L414.2,356.8 L418.9,354.6 L423.5,355.1 L428.2,355.9 L432.8,353.1 L437.5,351.5 L442.1,351.9 L446.7,351.7 L451.4,351.1 L456.0,350.9 L460.7,350.5 L465.3,347.7 L470.0,350.4 L474.6,349.5 L479.3,349.3 L483.9,348.9 L488.6,348.4 L493.2,342.5 L497.8,346.5 L502.5,347.8 L507.1,347.8 L511.8,347.1 L516.4,347.6 L521.1,347.3 L525.7,346.2 L530.4,345.6 L535.0,346.0 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_3a\"><title>multiplication</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,151.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">multiplication</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,145.7 L143.8,145.7 M75.1,382.0 L79.8,381.4 L84.4,381.8 L89.1,381.8 L93.7,381.8 L98.4,381.8 L103.0,381.8 L107.7,381.8 L112.3,381.8 L117.0,381.9 L121.6,381.8 L126.2,381.8 L130.9,382.0 L135.5,381.8 L140.2,381.8 L144.8,382.6 L149.5,382.3 L154.1,381.8 L158.8,381.8 L163.4,382.0 L168.0,381.8 L172.7,381.8 L177.3,381.8 L182.0,381.8 L186.6,381.8 L191.3,381.8 L195.9,381.6 L200.6,381.6 L205.2,381.8 L209.9,382.2 L214.5,381.9 L219.1,382.2 L223.8,382.0 L228.4,382.2 L233.1,382.2 L237.7,382.0 L242.4,382.6 L247.0,382.3 L251.7,382.6 L256.3,382.6 L260.9,382.4 L265.6,382.5 L270.2,382.5 L274.9,382.3 L279.5,382.3 L284.2,382.3 L288.8,382.5 L293.5,382.4 L298.1,382.3 L302.8,379.9 L307.4,382.7 L312.0,382.5 L316.7,382.5 L321.3,382.7 L326.0,382.7 L330.6,382.6 L335.3,382.6 L339.9,382.5 L344.6,382.6 L349.2,382.5 L353.8,382.6 L358.5,382.7 L363.1,382.6 L367.8,382.7 L372.4,382.5 L377.1,382.6 L381.7,382.5 L386.4,382.5 L391.0,382.6 L395.7,382.5 L400.3,382.5 L404.9,382.5 L409.6,382.6 L414.2,382.5 L418.9,382.5 L423.5,382.6 L428.2,382.6 L432.8,382.6 L437.5,382.3 L442.1,382.5 L446.7,382.6 L451.4,382.5 L456.0,382.5 L460.7,382.5 L465.3,382.4 L470.0,382.3 L474.6,382.3 L479.3,382.6 L483.9,382.4 L488.6,382.3 L493.2,382.3 L497.8,382.6 L502.5,382.6 L507.1,382.3 L511.8,382.3 L516.4,382.3 L521.1,382.6 L525.7,382.3 L530.4,382.3 L535.0,382.4 \" stroke=\"rgb(255, 0, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb(255, 0, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "N=100;\n", + "n=[1:N];\n", + "t_inv=zeros(N,1);\n", + "t_bs=zeros(N,1);\n", + "t_mult=zeros(N,1);\n", + "for i=1:N\n", + " A=rand(i,i);\n", + " tic\n", + " invA=inv(A);\n", + " t_inv(i)=toc;\n", + " b=rand(i,1);\n", + " tic;\n", + " x=A\\b;\n", + " t_bs(i)=toc;\n", + " tic;\n", + " x=invA*b;\n", + " t_mult(i)=toc;\n", + "end\n", + "plot(n,t_inv,n,t_bs,n,t_mult)\n", + "axis([0 100 0 0.002])\n", + "legend('inversion','backslash','multiplication','Location','NorthWest')" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Condition of a matrix \n", + "### *just checked in to see what condition my condition was in*\n", + "### Matrix norms\n", + "\n", + "The Euclidean norm of a vector is measure of the magnitude (in 3D this would be: $|x|=\\sqrt{x_{1}^{2}+x_{2}^{2}+x_{3}^{2}}$) in general the equation is:\n", + "\n", + "$||x||_{e}=\\sqrt{\\sum_{i=1}^{n}x_{i}^{2}}$\n", + "\n", + "For a matrix, A, the same norm is called the Frobenius norm:\n", + "\n", + "$||A||_{f}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{2}}$\n", + "\n", + "In general we can calculate any $p$-norm where\n", + "\n", + "$||A||_{p}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{p}}$\n", + "\n", + "so the p=1, 1-norm is \n", + "\n", + "$||A||_{1}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{1}}=\\sum_{i=1}^{n}\\sum_{i=1}^{m}|A_{i,j}|$\n", + "\n", + "$||A||_{\\infty}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{\\infty}}=\\max_{1\\le i \\le n}\\sum_{j=1}^{m}|A_{i,j}|$\n", + "\n", + "### Condition of Matrix\n", + "\n", + "The matrix condition is the product of \n", + "\n", + "$Cond(A) = ||A||\\cdot||A^{-1}||$ \n", + "\n", + "So each norm will have a different condition number, but the limit is $Cond(A)\\ge 1$\n", + "\n", + "An estimate of the rounding error is based on the condition of A:\n", + "\n", + "$\\frac{||\\Delta x||}{x} \\le Cond(A) \\frac{||\\Delta A||}{||A||}$\n", + "\n", + "So if the coefficients of A have accuracy to $10^{-t}\n", + "\n", + "and the condition of A, $Cond(A)=10^{c}$\n", + "\n", + "then the solution for x can have rounding errors up to $10^{c-t}$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 1, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 1.00000 0.50000 0.33333\n", + " 0.50000 0.33333 0.25000\n", + " 0.33333 0.25000 0.20000\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " 0.50000 1.00000 0.00000\n", + " 0.33333 1.00000 1.00000\n", + "\n", + "U =\n", + "\n", + " 1.00000 0.50000 0.33333\n", + " 0.00000 0.08333 0.08333\n", + " 0.00000 -0.00000 0.00556\n", + "\n" + ] + } + ], + "source": [ + "A=[1,1/2,1/3;1/2,1/3,1/4;1/3,1/4,1/5]\n", + "[L,U]=LU_naive(A)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "invA=" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000\n", + " 0.50000 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 1.00000\n", + " 0.00000 2.50000\n", + "\n", + "ans =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "d =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + "\n", + "y =\n", + "\n", + " 1\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "L=[1,0;0.5,1]\n", + "U=[2,1;0,2.5]\n", + "L*U\n", + "\n", + "d=[1;0.5]\n", + "y=L*d" + ] + }, + { + "cell_type": "code", + "execution_count": 5, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = 5.0000\n", + "ans = 1\n", + "ans = 5\n", + "ans = 5\n", + "ans = 5.0000\n" + ] + } + ], + "source": [ + "% what is the determinant of L, U and A?\n", + "\n", + "det(A)\n", + "det(L)\n", + "det(U)\n", + "det(L)*det(U)\n", + "det(L*U)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Pivoting for LU factorization\n", + "\n", + "LU factorization uses the same method as Gauss elimination so it is also necessary to perform partial pivoting when creating the lower and upper triangular matrices. \n", + "\n", + "Matlab and Octave use pivoting in the command \n", + "\n", + "`[L,U,P]=lu(A)`\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "'lu' is a built-in function from the file libinterp/corefcn/lu.cc\n", + "\n", + " -- Built-in Function: [L, U] = lu (A)\n", + " -- Built-in Function: [L, U, P] = lu (A)\n", + " -- Built-in Function: [L, U, P, Q] = lu (S)\n", + " -- Built-in Function: [L, U, P, Q, R] = lu (S)\n", + " -- Built-in Function: [...] = lu (S, THRES)\n", + " -- Built-in Function: Y = lu (...)\n", + " -- Built-in Function: [...] = lu (..., \"vector\")\n", + " Compute the LU decomposition of A.\n", + "\n", + " If A is full subroutines from LAPACK are used and if A is sparse\n", + " then UMFPACK is used.\n", + "\n", + " The result is returned in a permuted form, according to the\n", + " optional return value P. For example, given the matrix 'a = [1, 2;\n", + " 3, 4]',\n", + "\n", + " [l, u, p] = lu (A)\n", + "\n", + " returns\n", + "\n", + " l =\n", + "\n", + " 1.00000 0.00000\n", + " 0.33333 1.00000\n", + "\n", + " u =\n", + "\n", + " 3.00000 4.00000\n", + " 0.00000 0.66667\n", + "\n", + " p =\n", + "\n", + " 0 1\n", + " 1 0\n", + "\n", + " The matrix is not required to be square.\n", + "\n", + " When called with two or three output arguments and a spare input\n", + " matrix, 'lu' does not attempt to perform sparsity preserving column\n", + " permutations. Called with a fourth output argument, the sparsity\n", + " preserving column transformation Q is returned, such that 'P * A *\n", + " Q = L * U'.\n", + "\n", + " Called with a fifth output argument and a sparse input matrix, 'lu'\n", + " attempts to use a scaling factor R on the input matrix such that 'P\n", + " * (R \\ A) * Q = L * U'. This typically leads to a sparser and more\n", + " stable factorization.\n", + "\n", + " An additional input argument THRES, that defines the pivoting\n", + " threshold can be given. THRES can be a scalar, in which case it\n", + " defines the UMFPACK pivoting tolerance for both symmetric and\n", + " unsymmetric cases. If THRES is a 2-element vector, then the first\n", + " element defines the pivoting tolerance for the unsymmetric UMFPACK\n", + " pivoting strategy and the second for the symmetric strategy. By\n", + " default, the values defined by 'spparms' are used ([0.1, 0.001]).\n", + "\n", + " Given the string argument \"vector\", 'lu' returns the values of P\n", + " and Q as vector values, such that for full matrix, 'A (P,:) = L *\n", + " U', and 'R(P,:) * A (:, Q) = L * U'.\n", + "\n", + " With two output arguments, returns the permuted forms of the upper\n", + " and lower triangular matrices, such that 'A = L * U'. With one\n", + " output argument Y, then the matrix returned by the LAPACK routines\n", + " is returned. If the input matrix is sparse then the matrix L is\n", + " embedded into U to give a return value similar to the full case.\n", + " For both full and sparse matrices, 'lu' loses the permutation\n", + " information.\n", + "\n", + " See also: luupdate, ilu, chol, hess, qr, qz, schur, svd.\n", + "\n", + "Additional help for built-in functions and operators is\n", + "available in the online version of the manual. Use the command\n", + "'doc <topic>' to search the manual index.\n", + "\n", + "Help and information about Octave is also available on the WWW\n", + "at http://www.octave.org and via the help@octave.org\n", + "mailing list.\n" + ] + } + ], + "source": [ + "help lu" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,298.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0005</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,114.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(70.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(163.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(256.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(349.2,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(442.1,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>LU decomp</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">LU decomp</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,49.7 L414.7,49.7 M75.1,357.4 L79.8,366.4 L84.4,370.3 L89.1,369.9 L93.7,363.8 L98.4,369.5 L103.0,369.5 L107.7,362.2 L112.3,368.4 L117.0,368.0 L121.6,360.8 L126.2,366.5 L130.9,366.6 L135.5,355.4 L140.2,355.5 L144.8,353.0 L149.5,346.7 L154.1,360.0 L158.8,362.3 L163.4,361.2 L168.0,362.3 L172.7,355.7 L177.3,360.3 L182.0,356.9 L186.6,355.1 L191.3,357.9 L195.9,351.3 L200.6,356.6 L205.2,355.0 L209.9,355.4 L214.5,362.2 L219.1,360.9 L223.8,360.8 L228.4,359.7 L233.1,359.0 L237.7,356.5 L242.4,358.3 L247.0,356.6 L251.7,360.7 L256.3,360.3 L260.9,360.0 L265.6,359.0 L270.2,359.0 L274.9,357.6 L279.5,357.4 L284.2,356.2 L288.8,354.2 L293.5,359.6 L298.1,358.5 L302.8,357.9 L307.4,356.5 L312.0,356.5 L316.7,355.9 L321.3,355.1 L326.0,353.9 L330.6,352.4 L335.3,357.0 L339.9,356.6 L344.6,355.9 L349.2,355.2 L353.8,354.1 L358.5,353.1 L363.1,352.6 L367.8,351.5 L372.4,335.7 L377.1,356.3 L381.7,356.6 L386.4,352.6 L391.0,355.5 L395.7,355.5 L400.3,354.6 L404.9,355.1 L409.6,224.4 L414.2,352.4 L418.9,338.8 L423.5,351.5 L428.2,350.8 L432.8,350.4 L437.5,349.7 L442.1,350.4 L446.7,348.4 L451.4,347.8 L456.0,346.2 L460.7,347.0 L465.3,340.7 L470.0,338.6 L474.6,346.2 L479.3,347.3 L483.9,344.2 L488.6,343.8 L493.2,342.5 L497.8,343.2 L502.5,341.2 L507.1,342.5 L511.8,338.8 L516.4,342.3 L521.1,337.9 L525.7,338.3 L530.4,337.8 L535.0,339.2 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>Octave \\\\</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Octave \\</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,97.7 L414.7,97.7 M75.1,371.7 L79.8,368.6 L84.4,372.8 L89.1,372.4 L93.7,371.3 L98.4,371.7 L103.0,371.3 L107.7,369.9 L112.3,370.3 L117.0,370.2 L121.6,368.6 L126.2,368.9 L130.9,364.9 L135.5,357.0 L140.2,358.5 L144.8,354.4 L149.5,353.0 L154.1,358.7 L158.8,359.8 L163.4,360.1 L168.0,360.7 L172.7,355.2 L177.3,353.7 L182.0,355.4 L186.6,337.5 L191.3,353.7 L195.9,349.1 L200.6,354.4 L205.2,350.4 L209.9,329.8 L214.5,357.6 L219.1,353.7 L223.8,357.6 L228.4,350.4 L233.1,354.4 L237.7,353.9 L242.4,352.4 L247.0,140.3 L251.7,355.1 L256.3,356.8 L260.9,355.5 L265.6,352.6 L270.2,353.3 L274.9,353.9 L279.5,351.7 L284.2,350.8 L288.8,341.2 L293.5,355.2 L298.1,353.0 L302.8,352.6 L307.4,350.6 L312.0,351.3 L316.7,343.8 L321.3,348.0 L326.0,347.3 L330.6,345.4 L335.3,351.5 L339.9,338.1 L344.6,348.7 L349.2,349.1 L353.8,347.3 L358.5,346.9 L363.1,343.2 L367.8,343.6 L372.4,343.2 L377.1,335.7 L381.7,342.7 L386.4,344.5 L391.0,345.8 L395.7,345.6 L400.3,332.4 L404.9,340.7 L409.6,341.9 L414.2,262.6 L418.9,340.1 L423.5,331.8 L428.2,339.4 L432.8,338.3 L437.5,334.6 L442.1,335.5 L446.7,328.7 L451.4,333.3 L456.0,328.7 L460.7,331.3 L465.3,329.7 L470.0,327.8 L474.6,323.0 L479.3,324.8 L483.9,114.6 L488.6,315.3 L493.2,314.0 L497.8,301.7 L502.5,315.3 L507.1,319.2 L511.8,314.6 L516.4,315.1 L521.1,311.6 L525.7,313.1 L530.4,302.3 L535.0,305.2 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 128, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "% time LU solution vs backslash\n", + "t_lu=zeros(100,1);\n", + "t_bs=zeros(100,1);\n", + "for N=1:100\n", + " A=rand(N,N);\n", + " y=rand(N,1);\n", + " [L,U,P]=lu(A);\n", + "\n", + " tic; d=inv(L)*y; x=inv(U)*d; t_lu(N)=toc;\n", + "\n", + " tic; x=inv(A)*y; t_bs(N)=toc;\n", + "end\n", + "plot([1:100],t_lu,[1:100],t_bs) \n", + "legend('LU decomp','Octave \\\\')" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$\n", + "\n", + "$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "2k & -k & 0 & 0 \\\\\n", + "-k & 2k & -k & 0 \\\\\n", + "0 & -k & 2k & -k \\\\\n", + "0 & 0 & -k & k \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k=10; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "This matrix, K, is symmetric. \n", + "\n", + "`K(i,j)==K(j,i)`\n", + "\n", + "Now we can use,\n", + "\n", + "## Cholesky Factorization\n", + "\n", + "We can decompose the matrix, K into two matrices, $U$ and $U^{T}$, where\n", + "\n", + "$K=U^{T}U$\n", + "\n", + "each of the components of U can be calculated with the following equations:\n", + "\n", + "$u_{ii}=\\sqrt{a_{ii}-\\sum_{k=1}^{i-1}u_{ki}^{2}}$\n", + "\n", + "$u_{ij}=\\frac{a_{ij}-\\sum_{k=1}^{i-1}u_{ki}u_{kj}}{u_{ii}}$\n", + "\n", + "so for K" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n" + ] + } + ], + "source": [ + "K" + ] + }, + { + "cell_type": "code", + "execution_count": 12, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "u11 = 4.4721\n", + "u12 = -2.2361\n", + "u13 = 0\n", + "u14 = 0\n", + "u22 = 3.8730\n", + "u23 = -2.5820\n", + "u24 = 0\n", + "u33 = 3.6515\n", + "u34 = -2.7386\n", + "u44 = 1.5811\n", + "U =\n", + "\n", + " 4.47214 -2.23607 0.00000 0.00000\n", + " 0.00000 3.87298 -2.58199 0.00000\n", + " 0.00000 0.00000 3.65148 -2.73861\n", + " 0.00000 0.00000 0.00000 1.58114\n", + "\n" + ] + } + ], + "source": [ + "u11=sqrt(K(1,1))\n", + "u12=(K(1,2))/u11\n", + "u13=(K(1,3))/u11\n", + "u14=(K(1,4))/u11\n", + "u22=sqrt(K(2,2)-u12^2)\n", + "u23=(K(2,3)-u12*u13)/u22\n", + "u24=(K(2,4)-u12*u14)/u22\n", + "u33=sqrt(K(3,3)-u13^2-u23^2)\n", + "u34=(K(3,4)-u13*u14-u23*u24)/u33\n", + "u44=sqrt(K(4,4)-u14^2-u24^2-u34^2)\n", + "U=[u11,u12,u13,u14;0,u22,u23,u24;0,0,u33,u34;0,0,0,u44]" + ] + }, + { + "cell_type": "code", + "execution_count": 17, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + "\n" + ] + } + ], + "source": [ + "(U'*U)'==U'*U" + ] + }, + { + "cell_type": "code", + "execution_count": 18, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "average time spent for Cholesky factored solution = 1.465964e-05+/-9.806001e-06\n", + "average time spent for backslash solution = 1.555967e-05+/-1.048561e-05\n" + ] + } + ], + "source": [ + "% time solution for Cholesky vs backslash\n", + "t_chol=zeros(1000,1);\n", + "t_bs=zeros(1000,1);\n", + "for i=1:1000\n", + " tic; d=U'*y; x=U\\d; t_chol(i)=toc;\n", + " tic; x=K\\y; t_bs(i)=toc;\n", + "end\n", + "fprintf('average time spent for Cholesky factored solution = %e+/-%e',mean(t_chol),std(t_chol))\n", + "\n", + "fprintf('average time spent for backslash solution = %e+/-%e',mean(t_bs),std(t_bs))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_12/LU_naive.m b/lecture_12/LU_naive.m new file mode 100644 index 0000000..92efde6 --- /dev/null +++ b/lecture_12/LU_naive.m @@ -0,0 +1,27 @@ +function [L, U] = LU_naive(A) +% GaussNaive: naive Gauss elimination +% x = GaussNaive(A,b): Gauss elimination without pivoting. +% input: +% A = coefficient matrix +% y = right hand side vector +% output: +% x = solution vector +[m,n] = size(A); +if m~=n, error('Matrix A must be square'); end +nb = n; +L=diag(ones(n,1)); +U=A; +% forward elimination +for k = 1:n-1 + for i = k+1:n + fik = U(i,k)/U(k,k); + L(i,k)=fik; + U(i,k:nb) = U(i,k:nb)-fik*U(k,k:nb); + end +end +%% back substitution +%x = zeros(n,1); +%x(n) = Aug(n,nb)/Aug(n,n); +%for i = n-1:-1:1 +% x(i) = (Aug(i,nb)-Aug(i,i+1:n)*x(i+1:n))/Aug(i,i); +%end diff --git a/lecture_12/chol_pre.png b/lecture_12/chol_pre.png new file mode 100644 index 0000000..67d2493 Binary files /dev/null and b/lecture_12/chol_pre.png differ diff --git a/lecture_12/det_L.png b/lecture_12/det_L.png new file mode 100644 index 0000000..aaac5a2 Binary files /dev/null and b/lecture_12/det_L.png differ diff --git a/lecture_12/lecture_12.aux b/lecture_12/lecture_12.aux new file mode 100644 index 0000000..4aa3a49 --- /dev/null +++ b/lecture_12/lecture_12.aux @@ -0,0 +1,38 @@ +\relax +\providecommand\hyper@newdestlabel[2]{} +\providecommand\HyperFirstAtBeginDocument{\AtBeginDocument} +\HyperFirstAtBeginDocument{\ifx\hyper@anchor\@undefined +\global\let\oldcontentsline\contentsline +\gdef\contentsline#1#2#3#4{\oldcontentsline{#1}{#2}{#3}} +\global\let\oldnewlabel\newlabel +\gdef\newlabel#1#2{\newlabelxx{#1}#2} +\gdef\newlabelxx#1#2#3#4#5#6{\oldnewlabel{#1}{{#2}{#3}}} +\AtEndDocument{\ifx\hyper@anchor\@undefined +\let\contentsline\oldcontentsline +\let\newlabel\oldnewlabel +\fi} +\fi} +\global\let\hyper@last\relax +\gdef\HyperFirstAtBeginDocument#1{#1} +\providecommand\HyField@AuxAddToFields[1]{} +\providecommand\HyField@AuxAddToCoFields[2]{} +\providecommand \oddpage@label [2]{} +\@writefile{toc}{\contentsline {subsection}{\numberline {0.1}My question from last class}{2}{subsection.0.1}} +\newlabel{my-question-from-last-class}{{0.1}{2}{My question from last class}{subsection.0.1}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {1}{\ignorespaces q1\relax }}{2}{figure.caption.1}} +\@writefile{lof}{\contentsline {figure}{\numberline {2}{\ignorespaces q2\relax }}{3}{figure.caption.2}} +\@writefile{toc}{\contentsline {subsection}{\numberline {0.2}Your questions from last class}{3}{subsection.0.2}} +\newlabel{your-questions-from-last-class}{{0.2}{3}{Your questions from last class}{subsection.0.2}{}} +\@writefile{toc}{\contentsline {section}{\numberline {1}Matrix Inverse and Condition}{3}{section.1}} +\newlabel{matrix-inverse-and-condition}{{1}{3}{Matrix Inverse and Condition}{section.1}{}} +\newlabel{note-on-solving-for-a-1-column-1}{{1}{5}{\texorpdfstring {Note on solving for \(A^{-1}\) column 1}{Note on solving for A\^{}\{-1\} column 1}}{section*.3}{}} +\@writefile{toc}{\contentsline {paragraph}{Note on solving for \(A^{-1}\) column 1}{5}{section*.3}} +\@writefile{toc}{\contentsline {subsection}{\numberline {1.1}Condition of a matrix}{10}{subsection.1.1}} +\newlabel{condition-of-a-matrix}{{1.1}{10}{Condition of a matrix}{subsection.1.1}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.1.1}\emph {just checked in to see what condition my condition was in}}{10}{subsubsection.1.1.1}} +\newlabel{just-checked-in-to-see-what-condition-my-condition-was-in}{{1.1.1}{10}{\texorpdfstring {\emph {just checked in to see what condition my condition was in}}{just checked in to see what condition my condition was in}}{subsubsection.1.1.1}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.1.2}Matrix norms}{10}{subsubsection.1.1.2}} +\newlabel{matrix-norms}{{1.1.2}{10}{Matrix norms}{subsubsection.1.1.2}{}} +\@writefile{toc}{\contentsline {subsubsection}{\numberline {1.1.3}Condition of Matrix}{11}{subsubsection.1.1.3}} +\newlabel{condition-of-matrix}{{1.1.3}{11}{Condition of Matrix}{subsubsection.1.1.3}{}} +\@writefile{lof}{\contentsline {figure}{\numberline {3}{\ignorespaces Springs-masses\relax }}{13}{figure.caption.4}} diff --git a/lecture_12/lecture_12.bbl b/lecture_12/lecture_12.bbl new file mode 100644 index 0000000..e69de29 diff --git a/lecture_12/lecture_12.blg b/lecture_12/lecture_12.blg new file mode 100644 index 0000000..beafcd1 --- /dev/null +++ b/lecture_12/lecture_12.blg @@ -0,0 +1,48 @@ +This is BibTeX, Version 0.99d (TeX Live 2015/Debian) +Capacity: max_strings=35307, hash_size=35307, hash_prime=30011 +The top-level auxiliary file: lecture_12.aux +I found no \citation commands---while reading file lecture_12.aux +I found no \bibdata command---while reading file lecture_12.aux +I found no \bibstyle command---while reading file lecture_12.aux +You've used 0 entries, + 0 wiz_defined-function locations, + 83 strings with 494 characters, +and the built_in function-call counts, 0 in all, are: += -- 0 +> -- 0 +< -- 0 ++ -- 0 +- -- 0 +* -- 0 +:= -- 0 +add.period$ -- 0 +call.type$ -- 0 +change.case$ -- 0 +chr.to.int$ -- 0 +cite$ -- 0 +duplicate$ -- 0 +empty$ -- 0 +format.name$ -- 0 +if$ -- 0 +int.to.chr$ -- 0 +int.to.str$ -- 0 +missing$ -- 0 +newline$ -- 0 +num.names$ -- 0 +pop$ -- 0 +preamble$ -- 0 +purify$ -- 0 +quote$ -- 0 +skip$ -- 0 +stack$ -- 0 +substring$ -- 0 +swap$ -- 0 +text.length$ -- 0 +text.prefix$ -- 0 +top$ -- 0 +type$ -- 0 +warning$ -- 0 +while$ -- 0 +width$ -- 0 +write$ -- 0 +(There were 3 error messages) diff --git a/lecture_12/lecture_12.ipynb b/lecture_12/lecture_12.ipynb new file mode 100644 index 0000000..41f1959 --- /dev/null +++ b/lecture_12/lecture_12.ipynb @@ -0,0 +1,1248 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 27, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 28, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "code", + "execution_count": 29, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 0.447394 0.357071 0.720915 0.499926\n", + " 0.648313 0.323276 0.521677 0.288345\n", + " 0.084982 0.581513 0.466420 0.142342\n", + " 0.576580 0.658089 0.916987 0.923165\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000 0.00000 0.00000\n", + " 0.13108 1.00000 0.00000 0.00000\n", + " 0.69009 0.24851 1.00000 0.00000\n", + " 0.88935 0.68736 0.68488 1.00000\n", + "\n", + "U =\n", + "\n", + " 0.64831 0.32328 0.52168 0.28834\n", + " 0.00000 0.53914 0.39804 0.10455\n", + " 0.00000 0.00000 0.26199 0.27496\n", + " 0.00000 0.00000 0.00000 0.40655\n", + "\n", + "P =\n", + "\n", + "Permutation Matrix\n", + "\n", + " 0 1 0 0\n", + " 0 0 1 0\n", + " 1 0 0 0\n", + " 0 0 0 1\n", + "\n", + "ans = 1\n" + ] + } + ], + "source": [ + "A=rand(4,4)\n", + "\n", + "[L,U,P]=lu(A)\n", + "\n", + "det(L)" + ] + }, + { + "cell_type": "code", + "execution_count": 44, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 4 4\n", + "\n", + "ans = 23.586\n", + "ans = 35.826\n", + "ans = 14.869\n", + "C =\n", + "\n", + " 5.98549 4.28555 4.35707 4.31359\n", + " 0.00000 3.63950 1.35005 1.45342\n", + " 0.00000 0.00000 3.62851 1.50580\n", + " 0.00000 0.00000 0.00000 3.21911\n", + "\n" + ] + } + ], + "source": [ + "A=rand(4,100)';\n", + "A=A'*A;\n", + "size(A)\n", + "min(min(A))\n", + "max(max(A))\n", + "cond(A)\n", + "C=chol(A)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## My question from last class \n", + "\n", + "\n", + "\n", + "\n", + "\n", + "\n", + "## Your questions from last class\n", + "\n", + "1. Will the exam be more theoretical or problem based?\n", + "\n", + "2. Writing code is difficult \n", + "\n", + "3. What format can we expect for the midterm? \n", + "\n", + "2. Could we go over some example questions for the exam?\n", + "\n", + "3. Will the use of GitHub be tested on the Midterm exam? Or is it more focused on linear algebra techniques/what was covered in the lectures?\n", + "\n", + "4. This is not my strong suit, getting a bit overwhelmed with matrix multiplication.\n", + "\n", + "5. I forgot how much I learned in linear algebra.\n", + "\n", + "6. What's the most exciting project you've ever worked on with Matlab/Octave?" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Matrix Inverse and Condition\n", + "\n", + "\n", + "Considering the same solution set:\n", + "\n", + "$y=Ax$\n", + "\n", + "If we know that $A^{-1}A=I$, then \n", + "\n", + "$A^{-1}y=A^{-1}Ax=x$\n", + "\n", + "so \n", + "\n", + "$x=A^{-1}y$\n", + "\n", + "Where, $A^{-1}$ is the inverse of matrix $A$.\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "$Ax=y$\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "1 & 3 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "$A^{-1}=\\frac{1}{2*3-1*1}\\left[ \\begin{array}{cc}\n", + "3 & -1 \\\\\n", + "-1 & 2 \\end{array} \\right]=\n", + "\\left[ \\begin{array}{cc}\n", + "3/5 & -1/5 \\\\\n", + "-1/5 & 2/5 \\end{array} \\right]$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 45, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "invA =\n", + "\n", + " 0.60000 -0.20000\n", + " -0.20000 0.40000\n", + "\n", + "ans =\n", + "\n", + " 1.00000 0.00000\n", + " 0.00000 1.00000\n", + "\n", + "ans =\n", + "\n", + " 1.00000 0.00000\n", + " 0.00000 1.00000\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "invA=1/5*[3,-1;-1,2]\n", + "\n", + "A*invA\n", + "invA*A" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "How did we know the inverse of A? \n", + "\n", + "for 2$\\times$2 matrices, it is always:\n", + "\n", + "$A=\\left[ \\begin{array}{cc}\n", + "A_{11} & A_{12} \\\\\n", + "A_{21} & A_{22} \\end{array} \\right]$\n", + "\n", + "$A^{-1}=\\frac{1}{det(A)}\\left[ \\begin{array}{cc}\n", + "A_{22} & -A_{12} \\\\\n", + "-A_{21} & A_{11} \\end{array} \\right]$" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "$AA^{-1}=\\frac{1}{A_{11}A_{22}-A_{21}A_{12}}\\left[ \\begin{array}{cc}\n", + "A_{11}A_{22}-A_{21}A_{12} & -A_{11}A_{12}+A_{12}A_{11} \\\\\n", + "A_{21}A_{22}-A_{22}A_{21} & -A_{21}A_{12}+A_{22}A_{11} \\end{array} \\right]\n", + "=\\left[ \\begin{array}{cc}\n", + "1 & 0 \\\\\n", + "0 & 1 \\end{array} \\right]$" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "What about bigger matrices?\n", + "\n", + "We can use the LU-decomposition\n", + "\n", + "$A=LU$\n", + "\n", + "$A^{-1}=(LU)^{-1}=U^{-1}L^{-1}$\n", + "\n", + "if we divide $A^{-1}$ into n-column vectors, $a_{n}$, then\n", + "\n", + "$Aa_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$Aa_{2}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$Aa_{n}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "1 \\end{array} \\right]$\n", + "\n", + "\n", + "Which we can solve for each $a_{n}$ with LU-decomposition, knowing the lower and upper triangular decompositions, then \n", + "\n", + "$A^{-1}=\\left[ \\begin{array}{cccc}\n", + "| & | & & | \\\\\n", + "a_{1} & a_{2} & \\cdots & a_{n} \\\\\n", + "| & | & & | \\end{array} \\right]$\n", + "\n", + "\n", + "$Ld_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$;~Ua_{1}=d_{1}$\n", + "\n", + "$Ld_{2}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]$\n", + "$;~Ua_{2}=d_{2}$\n", + "\n", + "$Ld_{n}=\\left[\\begin{array}{c} \n", + "0 \\\\ \n", + "1 \\\\ \n", + "\\vdots \\\\\n", + "n \\end{array} \\right]$\n", + "$;~Ua_{n}=d_{n}$\n", + "\n", + "Consider the following matrix:\n", + "\n", + "$A=\\left[ \\begin{array}{ccc}\n", + "2 & -1 & 0\\\\\n", + "-1 & 2 & -1\\\\\n", + "0 & -1 & 1 \\end{array} \\right]$\n" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "#### Note on solving for $A^{-1}$ column 1\n", + "\n", + "$Aa_1=I(:,1)$\n", + "\n", + "$LUa_1=I(:,1)$\n", + "\n", + "$(LUa_1-I(:,1))=0$\n", + "\n", + "$L(Ua_1-d_1)=0$\n", + "\n", + "$I(:,1)=Ld_1$" + ] + }, + { + "cell_type": "code", + "execution_count": 56, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 -1 0\n", + " -1 2 -1\n", + " 0 -1 1\n", + "\n", + "U =\n", + "\n", + " 2.00000 -1.00000 0.00000\n", + " 0.00000 1.50000 -1.00000\n", + " 0.00000 -1.00000 1.00000\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " -0.50000 1.00000 0.00000\n", + " 0.00000 0.00000 1.00000\n", + "\n" + ] + } + ], + "source": [ + "A=[2,-1,0;-1,2,-1;0,-1,1]\n", + "U=A;\n", + "L=eye(3,3);\n", + "U(2,:)=U(2,:)-U(2,1)/U(1,1)*U(1,:)\n", + "L(2,1)=A(2,1)/A(1,1)" + ] + }, + { + "cell_type": "code", + "execution_count": 57, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " -0.50000 1.00000 0.00000\n", + " 0.00000 -0.66667 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 -1.00000 0.00000\n", + " 0.00000 1.50000 -1.00000\n", + " 0.00000 0.00000 0.33333\n", + "\n" + ] + } + ], + "source": [ + "L(3,2)=U(3,2)/U(2,2)\n", + "U(3,:)=U(3,:)-U(3,2)/U(2,2)*U(2,:)\n" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Now solve for $d_1$ then $a_1$, $d_2$ then $a_2$, and $d_3$ then $a_{3}$\n", + "\n", + "$Ld_{1}=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "\\vdots \\\\\n", + "0 \\end{array} \\right]=\n", + "\\left[\\begin{array}{ccc} \n", + "1 & 0 & 0 \\\\ \n", + "-1/2 & 1 & 0 \\\\\n", + "0 & -2/3 & 1 \\end{array} \\right]\\left[\\begin{array}{c} \n", + "d1(1) \\\\ \n", + "d1(2) \\\\ \n", + "d1(3)\\end{array} \\right]=\\left[\\begin{array}{c} \n", + "1 \\\\ \n", + "0 \\\\ \n", + "0 \\end{array} \\right]\n", + ";~Ua_{1}=d_{1}$" + ] + }, + { + "cell_type": "code", + "execution_count": 58, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d1 =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + " 0.33333\n", + "\n" + ] + } + ], + "source": [ + "d1=zeros(3,1);\n", + "d1(1)=1;\n", + "d1(2)=0-L(2,1)*d1(1);\n", + "d1(3)=0-L(3,1)*d1(1)-L(3,2)*d1(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 59, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a1 =\n", + "\n", + " 1.00000\n", + " 1.00000\n", + " 1.00000\n", + "\n" + ] + } + ], + "source": [ + "a1=zeros(3,1);\n", + "a1(3)=d1(3)/U(3,3);\n", + "a1(2)=1/U(2,2)*(d1(2)-U(2,3)*a1(3));\n", + "a1(1)=1/U(1,1)*(d1(1)-U(1,2)*a1(2)-U(1,3)*a1(3))" + ] + }, + { + "cell_type": "code", + "execution_count": 60, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d2 =\n", + "\n", + " 0.00000\n", + " 1.00000\n", + " 0.66667\n", + "\n" + ] + } + ], + "source": [ + "d2=zeros(3,1);\n", + "d2(1)=0;\n", + "d2(2)=1-L(2,1)*d2(1);\n", + "d2(3)=0-L(3,1)*d2(1)-L(3,2)*d2(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 61, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a2 =\n", + "\n", + " 1.0000\n", + " 2.0000\n", + " 2.0000\n", + "\n" + ] + } + ], + "source": [ + "a2=zeros(3,1);\n", + "a2(3)=d2(3)/U(3,3);\n", + "a2(2)=1/U(2,2)*(d2(2)-U(2,3)*a2(3));\n", + "a2(1)=1/U(1,1)*(d2(1)-U(1,2)*a2(2)-U(1,3)*a2(3))" + ] + }, + { + "cell_type": "code", + "execution_count": 62, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "d3 =\n", + "\n", + " 0\n", + " 0\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "d3=zeros(3,1);\n", + "d3(1)=0;\n", + "d3(2)=0-L(2,1)*d3(1);\n", + "d3(3)=1-L(3,1)*d3(1)-L(3,2)*d3(2)" + ] + }, + { + "cell_type": "code", + "execution_count": 63, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "a3 =\n", + "\n", + " 1.00000\n", + " 2.00000\n", + " 3.00000\n", + "\n" + ] + } + ], + "source": [ + "a3=zeros(3,1);\n", + "a3(3)=d3(3)/U(3,3);\n", + "a3(2)=1/U(2,2)*(d3(2)-U(2,3)*a3(3));\n", + "a3(1)=1/U(1,1)*(d3(1)-U(1,2)*a3(2)-U(1,3)*a3(3))" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Final solution for $A^{-1}$ is $[a_{1}~a_{2}~a_{3}]$" + ] + }, + { + "cell_type": "code", + "execution_count": 69, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "invA =\n", + "\n", + " 1.00000 1.00000 1.00000\n", + " 1.00000 2.00000 2.00000\n", + " 1.00000 2.00000 3.00000\n", + "\n", + "I_app =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " 0.00000 1.00000 -0.00000\n", + " -0.00000 -0.00000 1.00000\n", + "\n", + "ans = -4.4409e-16\n", + "ans = 2.2204e-16\n", + "ans = 0.0039062\n" + ] + } + ], + "source": [ + "invA=[a1,a2,a3]\n", + "I_app=A*invA\n", + "I_app(2,3)\n", + "eps\n", + "\n", + "2^-8" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Now the solution of $x$ to $Ax=y$ is $x=A^{-1}y$" + ] + }, + { + "cell_type": "code", + "execution_count": 70, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "y =\n", + "\n", + " 1\n", + " 2\n", + " 3\n", + "\n", + "x =\n", + "\n", + " 6.0000\n", + " 11.0000\n", + " 14.0000\n", + "\n", + "xbs =\n", + "\n", + " 6.0000\n", + " 11.0000\n", + " 14.0000\n", + "\n", + "ans =\n", + "\n", + " -3.5527e-15\n", + " -8.8818e-15\n", + " -1.0658e-14\n", + "\n", + "ans = 2.2204e-16\n" + ] + } + ], + "source": [ + "y=[1;2;3]\n", + "x=invA*y\n", + "xbs=A\\y\n", + "x-xbs\n", + "eps" + ] + }, + { + "cell_type": "code", + "execution_count": 71, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,298.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0005</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,114.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(70.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(163.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(256.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(349.2,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(442.1,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M78.8,169.7 L78.8,25.7 L311.8,25.7 L311.8,169.7 L78.8,169.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>inversion</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">inversion</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,49.7 L143.8,49.7 M75.1,359.6 L79.8,366.2 L84.4,364.9 L89.1,365.8 L93.7,366.6 L98.4,366.2 L103.0,365.3 L107.7,365.3 L112.3,363.8 L117.0,363.2 L121.6,360.0 L126.2,347.8 L130.9,358.3 L135.5,362.7 L140.2,362.4 L144.8,361.4 L149.5,360.1 L154.1,323.0 L158.8,341.7 L163.4,341.7 L168.0,332.4 L172.7,338.1 L177.3,335.4 L182.0,342.0 L186.6,364.3 L191.3,371.9 L195.9,370.8 L200.6,371.3 L205.2,371.2 L209.9,370.2 L214.5,368.8 L219.1,369.7 L223.8,368.4 L228.4,364.2 L233.1,366.7 L237.7,366.9 L242.4,364.7 L247.0,365.3 L251.7,364.0 L256.3,364.6 L260.9,363.4 L265.6,362.2 L270.2,361.6 L274.9,361.6 L279.5,360.3 L284.2,358.3 L288.8,358.7 L293.5,359.0 L298.1,357.3 L302.8,354.8 L307.4,355.2 L312.0,355.4 L316.7,353.9 L321.3,353.1 L326.0,351.9 L330.6,352.8 L335.3,349.5 L339.9,350.0 L344.6,348.2 L349.2,349.1 L353.8,345.0 L358.5,346.2 L363.1,344.9 L367.8,346.9 L372.4,337.9 L377.1,341.0 L381.7,342.9 L386.4,341.2 L391.0,339.7 L395.7,339.0 L400.3,338.1 L404.9,337.3 L409.6,336.8 L414.2,336.3 L418.9,334.4 L423.5,330.6 L428.2,330.4 L432.8,332.9 L437.5,329.8 L442.1,330.6 L446.7,327.8 L451.4,326.2 L456.0,323.9 L460.7,323.0 L465.3,322.7 L470.0,321.2 L474.6,320.8 L479.3,312.8 L483.9,317.3 L488.6,317.1 L493.2,317.3 L497.8,315.7 L502.5,316.6 L507.1,315.7 L511.8,307.6 L516.4,315.5 L521.1,314.6 L525.7,311.8 L530.4,308.5 L535.0,310.2 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>backslash</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">backslash</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,97.7 L143.8,97.7 M75.1,379.4 L79.8,372.8 L84.4,373.9 L89.1,368.0 L93.7,373.0 L98.4,373.0 L103.0,372.1 L107.7,372.1 L112.3,371.2 L117.0,370.6 L121.6,367.8 L126.2,366.0 L130.9,366.7 L135.5,369.9 L140.2,369.9 L144.8,369.3 L149.5,368.5 L154.1,354.8 L158.8,355.7 L163.4,355.4 L168.0,350.5 L172.7,354.1 L177.3,349.7 L182.0,334.4 L186.6,376.5 L191.3,376.1 L195.9,375.5 L200.6,375.8 L205.2,375.9 L209.9,375.0 L214.5,374.8 L219.1,374.6 L223.8,374.1 L228.4,370.8 L233.1,373.0 L237.7,373.0 L242.4,371.3 L247.0,371.9 L251.7,371.5 L256.3,371.7 L260.9,371.5 L265.6,370.6 L270.2,370.2 L274.9,369.9 L279.5,369.5 L284.2,369.1 L288.8,368.8 L293.5,368.7 L298.1,368.2 L302.8,367.5 L307.4,367.1 L312.0,366.9 L316.7,366.4 L321.3,366.0 L326.0,365.6 L330.6,365.8 L335.3,364.9 L339.9,364.5 L344.6,363.8 L349.2,363.8 L353.8,361.0 L358.5,362.9 L363.1,360.5 L367.8,363.2 L372.4,361.9 L377.1,357.7 L381.7,360.0 L386.4,359.6 L391.0,358.9 L395.7,358.6 L400.3,357.7 L404.9,356.1 L409.6,357.4 L414.2,356.8 L418.9,356.3 L423.5,357.7 L428.2,353.1 L432.8,355.2 L437.5,354.2 L442.1,352.8 L446.7,351.7 L451.4,350.8 L456.0,350.2 L460.7,350.6 L465.3,348.7 L470.0,348.7 L474.6,348.0 L479.3,343.4 L483.9,347.4 L488.6,345.2 L493.2,347.3 L497.8,347.8 L502.5,346.7 L507.1,346.2 L511.8,338.6 L516.4,347.8 L521.1,346.4 L525.7,344.3 L530.4,345.6 L535.0,347.1 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_3a\"><title>multiplication</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(311.8,151.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">multiplication</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M90.0,145.7 L143.8,145.7 M75.1,380.5 L79.8,379.4 L84.4,379.6 L89.1,379.8 L93.7,379.6 L98.4,379.8 L103.0,379.8 L107.7,379.8 L112.3,379.8 L117.0,379.8 L121.6,378.1 L126.2,379.4 L130.9,380.1 L135.5,380.3 L140.2,380.3 L144.8,380.3 L149.5,380.3 L154.1,378.9 L158.8,378.8 L163.4,378.9 L168.0,378.7 L172.7,378.5 L177.3,379.6 L182.0,379.4 L186.6,382.7 L191.3,382.7 L195.9,382.7 L200.6,382.7 L205.2,382.7 L209.9,382.7 L214.5,382.9 L219.1,382.9 L223.8,382.9 L228.4,382.7 L233.1,382.7 L237.7,382.7 L242.4,382.7 L247.0,382.9 L251.7,382.7 L256.3,382.7 L260.9,382.6 L265.6,382.7 L270.2,382.7 L274.9,382.7 L279.5,382.7 L284.2,382.7 L288.8,382.5 L293.5,382.7 L298.1,382.7 L302.8,382.6 L307.4,382.5 L312.0,382.5 L316.7,382.5 L321.3,382.7 L326.0,382.7 L330.6,382.7 L335.3,382.6 L339.9,382.7 L344.6,382.7 L349.2,382.6 L353.8,382.7 L358.5,382.6 L363.1,382.7 L367.8,382.5 L372.4,382.5 L377.1,382.7 L381.7,382.5 L386.4,382.7 L391.0,382.5 L395.7,382.5 L400.3,382.6 L404.9,382.7 L409.6,382.6 L414.2,382.5 L418.9,382.6 L423.5,382.5 L428.2,382.5 L432.8,382.4 L437.5,382.5 L442.1,382.6 L446.7,382.6 L451.4,382.5 L456.0,382.4 L460.7,382.3 L465.3,382.5 L470.0,382.3 L474.6,382.6 L479.3,382.3 L483.9,382.4 L488.6,382.3 L493.2,382.3 L497.8,382.5 L502.5,382.3 L507.1,382.6 L511.8,382.4 L516.4,379.8 L521.1,382.3 L525.7,382.3 L530.4,382.5 L535.0,382.5 \" stroke=\"rgb(255, 0, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb(255, 0, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "N=100;\n", + "n=[1:N];\n", + "t_inv=zeros(N,1);\n", + "t_bs=zeros(N,1);\n", + "t_mult=zeros(N,1);\n", + "for i=1:N\n", + " A=rand(i,i);\n", + " tic\n", + " invA=inv(A);\n", + " t_inv(i)=toc;\n", + " b=rand(i,1);\n", + " tic;\n", + " x=A\\b;\n", + " t_bs(i)=toc;\n", + " tic;\n", + " x=invA*b;\n", + " t_mult(i)=toc;\n", + "end\n", + "plot(n,t_inv,n,t_bs,n,t_mult)\n", + "axis([0 100 0 0.002])\n", + "legend('inversion','backslash','multiplication','Location','NorthWest')" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Condition of a matrix \n", + "### *just checked in to see what condition my condition was in*\n", + "### Matrix norms\n", + "\n", + "The Euclidean norm of a vector is measure of the magnitude (in 3D this would be: $|x|=\\sqrt{x_{1}^{2}+x_{2}^{2}+x_{3}^{2}}$) in general the equation is:\n", + "\n", + "$||x||_{e}=\\sqrt{\\sum_{i=1}^{n}x_{i}^{2}}$\n", + "\n", + "For a matrix, A, the same norm is called the Frobenius norm:\n", + "\n", + "$||A||_{f}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{2}}$\n", + "\n", + "In general we can calculate any $p$-norm where\n", + "\n", + "$||A||_{p}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{p}}$\n", + "\n", + "so the p=1, 1-norm is \n", + "\n", + "$||A||_{1}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{1}}=\\sum_{i=1}^{n}\\sum_{i=1}^{m}|A_{i,j}|$\n", + "\n", + "$||A||_{\\infty}=\\sqrt{\\sum_{i=1}^{n}\\sum_{i=1}^{m}A_{i,j}^{\\infty}}=\\max_{1\\le i \\le n}\\sum_{j=1}^{m}|A_{i,j}|$\n", + "\n", + "### Condition of Matrix\n", + "\n", + "The matrix condition is the product of \n", + "\n", + "$Cond(A) = ||A||\\cdot||A^{-1}||$ \n", + "\n", + "So each norm will have a different condition number, but the limit is $Cond(A)\\ge 1$\n", + "\n", + "An estimate of the rounding error is based on the condition of A:\n", + "\n", + "$\\frac{||\\Delta x||}{x} \\le Cond(A) \\frac{||\\Delta A||}{||A||}$\n", + "\n", + "So if the coefficients of A have accuracy to $10^{-t}\n", + "\n", + "and the condition of A, $Cond(A)=10^{c}$\n", + "\n", + "then the solution for x can have rounding errors up to $10^{c-t}$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 72, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 1.00000 0.50000 0.33333\n", + " 0.50000 0.33333 0.25000\n", + " 0.33333 0.25000 0.20000\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000 0.00000\n", + " 0.50000 1.00000 0.00000\n", + " 0.33333 1.00000 1.00000\n", + "\n", + "U =\n", + "\n", + " 1.00000 0.50000 0.33333\n", + " 0.00000 0.08333 0.08333\n", + " 0.00000 -0.00000 0.00556\n", + "\n" + ] + } + ], + "source": [ + "A=[1,1/2,1/3;1/2,1/3,1/4;1/3,1/4,1/5]\n", + "[L,U]=LU_naive(A)" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Then, $A^{-1}=(LU)^{-1}=U^{-1}L^{-1}$\n", + "\n", + "$Ld_{1}=\\left[\\begin{array}{c}\n", + "1 \\\\\n", + "0 \\\\\n", + "0 \\end{array}\\right]$, $Ux_{1}=d_{1}$ ..." + ] + }, + { + "cell_type": "code", + "execution_count": 75, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "invA =\n", + "\n", + " 9.0000 -36.0000 30.0000\n", + " -36.0000 192.0000 -180.0000\n", + " 30.0000 -180.0000 180.0000\n", + "\n", + "ans =\n", + "\n", + " 1.0000e+00 3.5527e-15 2.9976e-15\n", + " -1.3249e-14 1.0000e+00 -9.1038e-15\n", + " 8.5117e-15 7.1054e-15 1.0000e+00\n", + "\n" + ] + } + ], + "source": [ + "invA=zeros(3,3);\n", + "d1=L\\[1;0;0];\n", + "d2=L\\[0;1;0];\n", + "d3=L\\[0;0;1];\n", + "invA(:,1)=U\\d1;\n", + "invA(:,2)=U\\d2;\n", + "invA(:,3)=U\\d3\n", + "invA*A" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Find the condition of A, $cond(A)$" + ] + }, + { + "cell_type": "code", + "execution_count": 74, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "normf_A = 1.4136\n", + "normf_invA = 372.21\n", + "cond_f_A = 526.16\n", + "ans = 1.4136\n", + "norm1_A = 1.8333\n", + "norm1_invA = 30.000\n", + "ans = 1.8333\n", + "cond_1_A = 55.000\n", + "norminf_A = 1.8333\n", + "norminf_invA = 30.000\n", + "ans = 1.8333\n", + "cond_inf_A = 55.000\n" + ] + } + ], + "source": [ + "% Frobenius norm\n", + "normf_A = sqrt(sum(sum(A.^2)))\n", + "normf_invA = sqrt(sum(sum(invA.^2)))\n", + "\n", + "cond_f_A = normf_A*normf_invA\n", + "\n", + "norm(A,'fro')\n", + "\n", + "% p=1, column sum norm\n", + "norm1_A = max(sum(A,2))\n", + "norm1_invA = max(sum(invA,2))\n", + "norm(A,1)\n", + "\n", + "cond_1_A=norm1_A*norm1_invA\n", + "\n", + "% p=inf, row sum norm\n", + "norminf_A = max(sum(A,1))\n", + "norminf_invA = max(sum(invA,1))\n", + "norm(A,inf)\n", + "\n", + "cond_inf_A=norminf_A*norminf_invA\n" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with spring constants $K_{i}$. What does a high condition number mean for this problem? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0$\n", + "\n", + "$m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k_{4}(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "k_{1}+k_{2} & -k_{2} & 0 & 0 \\\\\n", + "-k_{2} & k_{2}+k_{3} & -k_{3} & 0 \\\\\n", + "0 & -k_{3} & k_{3}+k_{4} & -k_{4} \\\\\n", + "0 & 0 & -k_{4} & k_{4} \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 21, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 100010 -100000 0 0\n", + " -100000 100010 -10 0\n", + " 0 -10 11 -1\n", + " 0 0 -1 1\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k1=10; % N/m\n", + "k2=100000;\n", + "k3=10;\n", + "k4=1;\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[k1+k2 -k2 0 0; -k2 k2+k3 -k3 0; 0 -k3 k3+k4 -k4; 0 0 -k4 k4]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "code", + "execution_count": 25, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = 3.2004e+05\n", + "ans = 3.2004e+05\n", + "ans = 2.5925e+05\n", + "ans = 2.5293e+05\n" + ] + } + ], + "source": [ + "cond(K,inf)\n", + "cond(K,1)\n", + "cond(K,'fro')\n", + "cond(K,2)" + ] + }, + { + "cell_type": "code", + "execution_count": 26, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "e =\n", + "\n", + " 7.9078e-01\n", + " 3.5881e+00\n", + " 1.7621e+01\n", + " 2.0001e+05\n", + "\n", + "ans = 2.5293e+05\n" + ] + } + ], + "source": [ + "e=eig(K)\n", + "max(e)/min(e)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/lecture_12/lecture_12.log b/lecture_12/lecture_12.log new file mode 100644 index 0000000..c4a5ed3 --- /dev/null +++ b/lecture_12/lecture_12.log @@ -0,0 +1,841 @@ +This is pdfTeX, Version 3.14159265-2.6-1.40.16 (TeX Live 2015/Debian) (preloaded format=pdflatex 2017.1.11) 28 FEB 2017 14:24 +entering extended mode + restricted \write18 enabled. + %&-line parsing enabled. +**lecture_12.tex +(./lecture_12.tex +LaTeX2e <2016/02/01> +Babel <3.9q> and hyphenation patterns for 81 language(s) loaded. +(/usr/share/texlive/texmf-dist/tex/latex/base/article.cls +Document Class: article 2014/09/29 v1.4h Standard LaTeX document class +(/usr/share/texlive/texmf-dist/tex/latex/base/size11.clo +File: size11.clo 2014/09/29 v1.4h Standard LaTeX file (size option) +) +\c@part=\count79 +\c@section=\count80 +\c@subsection=\count81 +\c@subsubsection=\count82 +\c@paragraph=\count83 +\c@subparagraph=\count84 +\c@figure=\count85 +\c@table=\count86 +\abovecaptionskip=\skip41 +\belowcaptionskip=\skip42 +\bibindent=\dimen102 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/fontenc.sty +Package: fontenc 2005/09/27 v1.99g Standard LaTeX package + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1enc.def +File: t1enc.def 2005/09/27 v1.99g Standard LaTeX file +LaTeX Font Info: Redeclaring font encoding T1 on input line 48. +)) +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/mathpazo.sty +Package: mathpazo 2005/04/12 PSNFSS-v9.2a Palatino w/ Pazo Math (D.Puga, WaS) +\symupright=\mathgroup4 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphicx.sty +Package: graphicx 2014/10/28 v1.0g Enhanced LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/keyval.sty +Package: keyval 2014/10/28 v1.15 key=value parser (DPC) +\KV@toks@=\toks14 +) +(/usr/share/texlive/texmf-dist/tex/latex/graphics/graphics.sty +Package: graphics 2016/01/03 v1.0q Standard LaTeX Graphics (DPC,SPQR) + +(/usr/share/texlive/texmf-dist/tex/latex/graphics/trig.sty +Package: trig 2016/01/03 v1.10 sin cos tan (DPC) +) +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/graphics.cfg +File: graphics.cfg 2010/04/23 v1.9 graphics configuration of TeX Live +) +Package graphics Info: Driver file: pdftex.def on input line 95. + +(/usr/share/texlive/texmf-dist/tex/latex/pdftex-def/pdftex.def +File: pdftex.def 2011/05/27 v0.06d Graphics/color for pdfTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/infwarerr.sty +Package: infwarerr 2010/04/08 v1.3 Providing info/warning/error messages (HO) +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ltxcmds.sty +Package: ltxcmds 2011/11/09 v1.22 LaTeX kernel commands for general use (HO) +) +\Gread@gobject=\count87 +)) +\Gin@req@height=\dimen103 +\Gin@req@width=\dimen104 +) +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption.sty +Package: caption 2016/02/21 v3.3-144 Customizing captions (AR) + +(/usr/share/texlive/texmf-dist/tex/latex/caption/caption3.sty +Package: caption3 2016/02/04 v1.7-139 caption3 kernel (AR) +Package caption3 Info: TeX engine: e-TeX on input line 67. +\captionmargin=\dimen105 +\captionmargin@=\dimen106 +\captionwidth=\dimen107 +\caption@tempdima=\dimen108 +\caption@indent=\dimen109 +\caption@parindent=\dimen110 +\caption@hangindent=\dimen111 +) +\c@ContinuedFloat=\count88 +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjustbox.sty +Package: adjustbox 2012/05/21 v1.0 Adjusting TeX boxes (trim, clip, ...) + +(/usr/share/texlive/texmf-dist/tex/latex/xkeyval/xkeyval.sty +Package: xkeyval 2014/12/03 v2.7a package option processing (HA) + +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkeyval.tex +(/usr/share/texlive/texmf-dist/tex/generic/xkeyval/xkvutils.tex +\XKV@toks=\toks15 +\XKV@tempa@toks=\toks16 +) +\XKV@depth=\count89 +File: xkeyval.tex 2014/12/03 v2.7a key=value parser (HA) +)) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/adjcalc.sty +Package: adjcalc 2012/05/16 v1.1 Provides advanced setlength with multiple back +-ends (calc, etex, pgfmath) +) +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/trimclip.sty +Package: trimclip 2012/05/16 v1.0 Trim and clip general TeX material + +(/usr/share/texlive/texmf-dist/tex/latex/collectbox/collectbox.sty +Package: collectbox 2012/05/17 v0.4b Collect macro arguments as boxes +\collectedbox=\box26 +) +\tc@llx=\dimen112 +\tc@lly=\dimen113 +\tc@urx=\dimen114 +\tc@ury=\dimen115 +Package trimclip Info: Using driver 'tc-pdftex.def'. + +(/usr/share/texlive/texmf-dist/tex/latex/adjustbox/tc-pdftex.def +File: tc-pdftex.def 2012/05/13 v1.0 Clipping driver for pdftex +)) +\adjbox@Width=\dimen116 +\adjbox@Height=\dimen117 +\adjbox@Depth=\dimen118 +\adjbox@Totalheight=\dimen119 + +(/usr/share/texlive/texmf-dist/tex/latex/ifoddpage/ifoddpage.sty +Package: ifoddpage 2011/09/13 v1.0 Conditionals for odd/even page detection +\c@checkoddpage=\count90 +) +(/usr/share/texlive/texmf-dist/tex/latex/varwidth/varwidth.sty +Package: varwidth 2009/03/30 ver 0.92; Variable-width minipages +\@vwid@box=\box27 +\sift@deathcycles=\count91 +\@vwid@loff=\dimen120 +\@vwid@roff=\dimen121 +)) +(/usr/share/texlive/texmf-dist/tex/latex/xcolor/xcolor.sty +Package: xcolor 2007/01/21 v2.11 LaTeX color extensions (UK) + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/color.cfg +File: color.cfg 2007/01/18 v1.5 color configuration of teTeX/TeXLive +) +Package xcolor Info: Driver file: pdftex.def on input line 225. +Package xcolor Info: Model `cmy' substituted by `cmy0' on input line 1337. +Package xcolor Info: Model `hsb' substituted by `rgb' on input line 1341. +Package xcolor Info: Model `RGB' extended on input line 1353. +Package xcolor Info: Model `HTML' substituted by `rgb' on input line 1355. +Package xcolor Info: Model `Hsb' substituted by `hsb' on input line 1356. +Package xcolor Info: Model `tHsb' substituted by `hsb' on input line 1357. +Package xcolor Info: Model `HSB' substituted by `hsb' on input line 1358. +Package xcolor Info: Model `Gray' substituted by `gray' on input line 1359. +Package xcolor Info: Model `wave' substituted by `hsb' on input line 1360. +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/enumerate.sty +Package: enumerate 2015/07/23 v3.00 enumerate extensions (DPC) +\@enLab=\toks17 +) +(/usr/share/texlive/texmf-dist/tex/latex/geometry/geometry.sty +Package: geometry 2010/09/12 v5.6 Page Geometry + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifpdf.sty +Package: ifpdf 2011/01/30 v2.3 Provides the ifpdf switch (HO) +Package ifpdf Info: pdfTeX in PDF mode is detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifvtex.sty +Package: ifvtex 2010/03/01 v1.5 Detect VTeX and its facilities (HO) +Package ifvtex Info: VTeX not detected. +) +(/usr/share/texlive/texmf-dist/tex/generic/ifxetex/ifxetex.sty +Package: ifxetex 2010/09/12 v0.6 Provides ifxetex conditional +) +\Gm@cnth=\count92 +\Gm@cntv=\count93 +\c@Gm@tempcnt=\count94 +\Gm@bindingoffset=\dimen122 +\Gm@wd@mp=\dimen123 +\Gm@odd@mp=\dimen124 +\Gm@even@mp=\dimen125 +\Gm@layoutwidth=\dimen126 +\Gm@layoutheight=\dimen127 +\Gm@layouthoffset=\dimen128 +\Gm@layoutvoffset=\dimen129 +\Gm@dimlist=\toks18 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsmath.sty +Package: amsmath 2016/03/03 v2.15a AMS math features +\@mathmargin=\skip43 + +For additional information on amsmath, use the `?' option. +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amstext.sty +Package: amstext 2000/06/29 v2.01 AMS text + +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsgen.sty +File: amsgen.sty 1999/11/30 v2.0 generic functions +\@emptytoks=\toks19 +\ex@=\dimen130 +)) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsbsy.sty +Package: amsbsy 1999/11/29 v1.2d Bold Symbols +\pmbraise@=\dimen131 +) +(/usr/share/texlive/texmf-dist/tex/latex/amsmath/amsopn.sty +Package: amsopn 1999/12/14 v2.01 operator names +) +\inf@bad=\count95 +LaTeX Info: Redefining \frac on input line 199. +\uproot@=\count96 +\leftroot@=\count97 +LaTeX Info: Redefining \overline on input line 297. +\classnum@=\count98 +\DOTSCASE@=\count99 +LaTeX Info: Redefining \ldots on input line 394. +LaTeX Info: Redefining \dots on input line 397. +LaTeX Info: Redefining \cdots on input line 518. +\Mathstrutbox@=\box28 +\strutbox@=\box29 +\big@size=\dimen132 +LaTeX Font Info: Redeclaring font encoding OML on input line 630. +LaTeX Font Info: Redeclaring font encoding OMS on input line 631. +\macc@depth=\count100 +\c@MaxMatrixCols=\count101 +\dotsspace@=\muskip10 +\c@parentequation=\count102 +\dspbrk@lvl=\count103 +\tag@help=\toks20 +\row@=\count104 +\column@=\count105 +\maxfields@=\count106 +\andhelp@=\toks21 +\eqnshift@=\dimen133 +\alignsep@=\dimen134 +\tagshift@=\dimen135 +\tagwidth@=\dimen136 +\totwidth@=\dimen137 +\lineht@=\dimen138 +\@envbody=\toks22 +\multlinegap=\skip44 +\multlinetaggap=\skip45 +\mathdisplay@stack=\toks23 +LaTeX Info: Redefining \[ on input line 2735. +LaTeX Info: Redefining \] on input line 2736. +) +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amssymb.sty +Package: amssymb 2013/01/14 v3.01 AMS font symbols + +(/usr/share/texlive/texmf-dist/tex/latex/amsfonts/amsfonts.sty +Package: amsfonts 2013/01/14 v3.01 Basic AMSFonts support +\symAMSa=\mathgroup5 +\symAMSb=\mathgroup6 +LaTeX Font Info: Overwriting math alphabet `\mathfrak' in version `bold' +(Font) U/euf/m/n --> U/euf/b/n on input line 106. +)) +(/usr/share/texlive/texmf-dist/tex/latex/base/textcomp.sty +Package: textcomp 2005/09/27 v1.99g Standard LaTeX package +Package textcomp Info: Sub-encoding information: +(textcomp) 5 = only ISO-Adobe without \textcurrency +(textcomp) 4 = 5 + \texteuro +(textcomp) 3 = 4 + \textohm +(textcomp) 2 = 3 + \textestimated + \textcurrency +(textcomp) 1 = TS1 - \textcircled - \t +(textcomp) 0 = TS1 (full) +(textcomp) Font families with sub-encoding setting implement +(textcomp) only a restricted character set as indicated. +(textcomp) Family '?' is the default used for unknown fonts. +(textcomp) See the documentation for details. +Package textcomp Info: Setting ? sub-encoding to TS1/1 on input line 79. + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1enc.def +File: ts1enc.def 2001/06/05 v3.0e (jk/car/fm) Standard LaTeX file +) +LaTeX Info: Redefining \oldstylenums on input line 334. +Package textcomp Info: Setting cmr sub-encoding to TS1/0 on input line 349. +Package textcomp Info: Setting cmss sub-encoding to TS1/0 on input line 350. +Package textcomp Info: Setting cmtt sub-encoding to TS1/0 on input line 351. +Package textcomp Info: Setting cmvtt sub-encoding to TS1/0 on input line 352. +Package textcomp Info: Setting cmbr sub-encoding to TS1/0 on input line 353. +Package textcomp Info: Setting cmtl sub-encoding to TS1/0 on input line 354. +Package textcomp Info: Setting ccr sub-encoding to TS1/0 on input line 355. +Package textcomp Info: Setting ptm sub-encoding to TS1/4 on input line 356. +Package textcomp Info: Setting pcr sub-encoding to TS1/4 on input line 357. +Package textcomp Info: Setting phv sub-encoding to TS1/4 on input line 358. +Package textcomp Info: Setting ppl sub-encoding to TS1/3 on input line 359. +Package textcomp Info: Setting pag sub-encoding to TS1/4 on input line 360. +Package textcomp Info: Setting pbk sub-encoding to TS1/4 on input line 361. +Package textcomp Info: Setting pnc sub-encoding to TS1/4 on input line 362. +Package textcomp Info: Setting pzc sub-encoding to TS1/4 on input line 363. +Package textcomp Info: Setting bch sub-encoding to TS1/4 on input line 364. +Package textcomp Info: Setting put sub-encoding to TS1/5 on input line 365. +Package textcomp Info: Setting uag sub-encoding to TS1/5 on input line 366. +Package textcomp Info: Setting ugq sub-encoding to TS1/5 on input line 367. +Package textcomp Info: Setting ul8 sub-encoding to TS1/4 on input line 368. +Package textcomp Info: Setting ul9 sub-encoding to TS1/4 on input line 369. +Package textcomp Info: Setting augie sub-encoding to TS1/5 on input line 370. +Package textcomp Info: Setting dayrom sub-encoding to TS1/3 on input line 371. +Package textcomp Info: Setting dayroms sub-encoding to TS1/3 on input line 372. + +Package textcomp Info: Setting pxr sub-encoding to TS1/0 on input line 373. +Package textcomp Info: Setting pxss sub-encoding to TS1/0 on input line 374. +Package textcomp Info: Setting pxtt sub-encoding to TS1/0 on input line 375. +Package textcomp Info: Setting txr sub-encoding to TS1/0 on input line 376. +Package textcomp Info: Setting txss sub-encoding to TS1/0 on input line 377. +Package textcomp Info: Setting txtt sub-encoding to TS1/0 on input line 378. +Package textcomp Info: Setting lmr sub-encoding to TS1/0 on input line 379. +Package textcomp Info: Setting lmdh sub-encoding to TS1/0 on input line 380. +Package textcomp Info: Setting lmss sub-encoding to TS1/0 on input line 381. +Package textcomp Info: Setting lmssq sub-encoding to TS1/0 on input line 382. +Package textcomp Info: Setting lmvtt sub-encoding to TS1/0 on input line 383. +Package textcomp Info: Setting lmtt sub-encoding to TS1/0 on input line 384. +Package textcomp Info: Setting qhv sub-encoding to TS1/0 on input line 385. +Package textcomp Info: Setting qag sub-encoding to TS1/0 on input line 386. +Package textcomp Info: Setting qbk sub-encoding to TS1/0 on input line 387. +Package textcomp Info: Setting qcr sub-encoding to TS1/0 on input line 388. +Package textcomp Info: Setting qcs sub-encoding to TS1/0 on input line 389. +Package textcomp Info: Setting qpl sub-encoding to TS1/0 on input line 390. +Package textcomp Info: Setting qtm sub-encoding to TS1/0 on input line 391. +Package textcomp Info: Setting qzc sub-encoding to TS1/0 on input line 392. +Package textcomp Info: Setting qhvc sub-encoding to TS1/0 on input line 393. +Package textcomp Info: Setting futs sub-encoding to TS1/4 on input line 394. +Package textcomp Info: Setting futx sub-encoding to TS1/4 on input line 395. +Package textcomp Info: Setting futj sub-encoding to TS1/4 on input line 396. +Package textcomp Info: Setting hlh sub-encoding to TS1/3 on input line 397. +Package textcomp Info: Setting hls sub-encoding to TS1/3 on input line 398. +Package textcomp Info: Setting hlst sub-encoding to TS1/3 on input line 399. +Package textcomp Info: Setting hlct sub-encoding to TS1/5 on input line 400. +Package textcomp Info: Setting hlx sub-encoding to TS1/5 on input line 401. +Package textcomp Info: Setting hlce sub-encoding to TS1/5 on input line 402. +Package textcomp Info: Setting hlcn sub-encoding to TS1/5 on input line 403. +Package textcomp Info: Setting hlcw sub-encoding to TS1/5 on input line 404. +Package textcomp Info: Setting hlcf sub-encoding to TS1/5 on input line 405. +Package textcomp Info: Setting pplx sub-encoding to TS1/3 on input line 406. +Package textcomp Info: Setting pplj sub-encoding to TS1/3 on input line 407. +Package textcomp Info: Setting ptmx sub-encoding to TS1/4 on input line 408. +Package textcomp Info: Setting ptmj sub-encoding to TS1/4 on input line 409. +) +(/usr/share/texlive/texmf-dist/tex/latex/upquote/upquote.sty +Package: upquote 2012/04/19 v1.3 upright-quote and grave-accent glyphs in verba +tim +) +(/usr/share/texlive/texmf-dist/tex/latex/eurosym/eurosym.sty +Package: eurosym 1998/08/06 v1.1 European currency symbol ``Euro'' +\@eurobox=\box30 +) +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucs.sty +Package: ucs 2013/05/11 v2.2 UCS: Unicode input support + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/data/uni-global.def +File: uni-global.def 2013/05/13 UCS: Unicode global data +) +\uc@secondtry=\count107 +\uc@combtoks=\toks24 +\uc@combtoksb=\toks25 +\uc@temptokena=\toks26 +) +(/usr/share/texlive/texmf-dist/tex/latex/base/inputenc.sty +Package: inputenc 2015/03/17 v1.2c Input encoding file +\inpenc@prehook=\toks27 +\inpenc@posthook=\toks28 + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/utf8x.def +File: utf8x.def 2004/10/17 UCS: Input encoding UTF-8 +)) +(/usr/share/texlive/texmf-dist/tex/latex/fancyvrb/fancyvrb.sty +Package: fancyvrb 2008/02/07 + +Style option: `fancyvrb' v2.7a, with DG/SPQR fixes, and firstline=lastline fix +<2008/02/07> (tvz) +\FV@CodeLineNo=\count108 +\FV@InFile=\read1 +\FV@TabBox=\box31 +\c@FancyVerbLine=\count109 +\FV@StepNumber=\count110 +\FV@OutFile=\write3 +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grffile.sty +Package: grffile 2012/04/05 v1.16 Extended file name support for graphics (HO) + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/kvoptions.sty +Package: kvoptions 2011/06/30 v3.11 Key value format for package options (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/kvsetkeys.sty +Package: kvsetkeys 2012/04/25 v1.16 Key value parser (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/etexcmds.sty +Package: etexcmds 2011/02/16 v1.5 Avoid name clashes with e-TeX commands (HO) + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/ifluatex.sty +Package: ifluatex 2010/03/01 v1.3 Provides the ifluatex switch (HO) +Package ifluatex Info: LuaTeX not detected. +) +Package etexcmds Info: Could not find \expanded. +(etexcmds) That can mean that you are not using pdfTeX 1.50 or +(etexcmds) that some package has redefined \expanded. +(etexcmds) In the latter case, load this package earlier. +))) +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/pdftexcmds.sty +Package: pdftexcmds 2011/11/29 v0.20 Utility functions of pdfTeX for LuaTeX (HO +) +Package pdftexcmds Info: LuaTeX not detected. +Package pdftexcmds Info: \pdf@primitive is available. +Package pdftexcmds Info: \pdf@ifprimitive is available. +Package pdftexcmds Info: \pdfdraftmode found. +) +Package grffile Info: Option `multidot' is set to `true'. +Package grffile Info: Option `extendedchars' is set to `false'. +Package grffile Info: Option `space' is set to `true'. +Package grffile Info: \Gin@ii of package `graphicx' fixed on input line 486. +) +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hyperref.sty +Package: hyperref 2012/11/06 v6.83m Hypertext links for LaTeX + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-hyperref.sty +Package: hobsub-hyperref 2012/05/28 v1.13 Bundle oberdiek, subset hyperref (HO) + + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/hobsub-generic.sty +Package: hobsub-generic 2012/05/28 v1.13 Bundle oberdiek, subset generic (HO) +Package: hobsub 2012/05/28 v1.13 Construct package bundles (HO) +Package hobsub Info: Skipping package `infwarerr' (already loaded). +Package hobsub Info: Skipping package `ltxcmds' (already loaded). +Package hobsub Info: Skipping package `ifluatex' (already loaded). +Package hobsub Info: Skipping package `ifvtex' (already loaded). +Package: intcalc 2007/09/27 v1.1 Expandable calculations with integers (HO) +Package hobsub Info: Skipping package `ifpdf' (already loaded). +Package hobsub Info: Skipping package `etexcmds' (already loaded). +Package hobsub Info: Skipping package `kvsetkeys' (already loaded). +Package: kvdefinekeys 2011/04/07 v1.3 Define keys (HO) +Package hobsub Info: Skipping package `pdftexcmds' (already loaded). +Package: pdfescape 2011/11/25 v1.13 Implements pdfTeX's escape features (HO) +Package: bigintcalc 2012/04/08 v1.3 Expandable calculations on big integers (HO +) +Package: bitset 2011/01/30 v1.1 Handle bit-vector datatype (HO) +Package: uniquecounter 2011/01/30 v1.2 Provide unlimited unique counter (HO) +) +Package hobsub Info: Skipping package `hobsub' (already loaded). +Package: letltxmacro 2010/09/02 v1.4 Let assignment for LaTeX macros (HO) +Package: hopatch 2012/05/28 v1.2 Wrapper for package hooks (HO) +Package: xcolor-patch 2011/01/30 xcolor patch +Package: atveryend 2011/06/30 v1.8 Hooks at the very end of document (HO) +Package atveryend Info: \enddocument detected (standard20110627). +Package: atbegshi 2011/10/05 v1.16 At begin shipout hook (HO) +Package: refcount 2011/10/16 v3.4 Data extraction from label references (HO) +Package: hycolor 2011/01/30 v1.7 Color options for hyperref/bookmark (HO) +) +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/auxhook.sty +Package: auxhook 2011/03/04 v1.3 Hooks for auxiliary files (HO) +) +\@linkdim=\dimen139 +\Hy@linkcounter=\count111 +\Hy@pagecounter=\count112 + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/pd1enc.def +File: pd1enc.def 2012/11/06 v6.83m Hyperref: PDFDocEncoding definition (HO) +) +\Hy@SavedSpaceFactor=\count113 + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/hyperref.cfg +File: hyperref.cfg 2002/06/06 v1.2 hyperref configuration of TeXLive +) +Package hyperref Info: Hyper figures OFF on input line 4443. +Package hyperref Info: Link nesting OFF on input line 4448. +Package hyperref Info: Hyper index ON on input line 4451. +Package hyperref Info: Plain pages OFF on input line 4458. +Package hyperref Info: Backreferencing OFF on input line 4463. +Package hyperref Info: Implicit mode ON; LaTeX internals redefined. +Package hyperref Info: Bookmarks ON on input line 4688. +\c@Hy@tempcnt=\count114 + +(/usr/share/texlive/texmf-dist/tex/latex/url/url.sty +\Urlmuskip=\muskip11 +Package: url 2013/09/16 ver 3.4 Verb mode for urls, etc. +) +LaTeX Info: Redefining \url on input line 5041. +\XeTeXLinkMargin=\dimen140 +\Fld@menulength=\count115 +\Field@Width=\dimen141 +\Fld@charsize=\dimen142 +Package hyperref Info: Hyper figures OFF on input line 6295. +Package hyperref Info: Link nesting OFF on input line 6300. +Package hyperref Info: Hyper index ON on input line 6303. +Package hyperref Info: backreferencing OFF on input line 6310. +Package hyperref Info: Link coloring OFF on input line 6315. +Package hyperref Info: Link coloring with OCG OFF on input line 6320. +Package hyperref Info: PDF/A mode OFF on input line 6325. +LaTeX Info: Redefining \ref on input line 6365. +LaTeX Info: Redefining \pageref on input line 6369. +\Hy@abspage=\count116 +\c@Item=\count117 +\c@Hfootnote=\count118 +) + +Package hyperref Message: Driver (autodetected): hpdftex. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/hpdftex.def +File: hpdftex.def 2012/11/06 v6.83m Hyperref driver for pdfTeX +\Fld@listcount=\count119 +\c@bookmark@seq@number=\count120 + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/rerunfilecheck.sty +Package: rerunfilecheck 2011/04/15 v1.7 Rerun checks for auxiliary files (HO) +Package uniquecounter Info: New unique counter `rerunfilecheck' on input line 2 +82. +) +\Hy@SectionHShift=\skip46 +) +(/usr/share/texlive/texmf-dist/tex/latex/tools/longtable.sty +Package: longtable 2014/10/28 v4.11 Multi-page Table package (DPC) +\LTleft=\skip47 +\LTright=\skip48 +\LTpre=\skip49 +\LTpost=\skip50 +\LTchunksize=\count121 +\LTcapwidth=\dimen143 +\LT@head=\box32 +\LT@firsthead=\box33 +\LT@foot=\box34 +\LT@lastfoot=\box35 +\LT@cols=\count122 +\LT@rows=\count123 +\c@LT@tables=\count124 +\c@LT@chunks=\count125 +\LT@p@ftn=\toks29 +) +(/usr/share/texlive/texmf-dist/tex/latex/booktabs/booktabs.sty +Package: booktabs 2005/04/14 v1.61803 publication quality tables +\heavyrulewidth=\dimen144 +\lightrulewidth=\dimen145 +\cmidrulewidth=\dimen146 +\belowrulesep=\dimen147 +\belowbottomsep=\dimen148 +\aboverulesep=\dimen149 +\abovetopsep=\dimen150 +\cmidrulesep=\dimen151 +\cmidrulekern=\dimen152 +\defaultaddspace=\dimen153 +\@cmidla=\count126 +\@cmidlb=\count127 +\@aboverulesep=\dimen154 +\@belowrulesep=\dimen155 +\@thisruleclass=\count128 +\@lastruleclass=\count129 +\@thisrulewidth=\dimen156 +) +(/usr/share/texlive/texmf-dist/tex/latex/enumitem/enumitem.sty +Package: enumitem 2011/09/28 v3.5.2 Customized lists +\labelindent=\skip51 +\enit@outerparindent=\dimen157 +\enit@toks=\toks30 +\enit@inbox=\box36 +\enitdp@description=\count130 +) +(/usr/share/texlive/texmf-dist/tex/generic/ulem/ulem.sty +\UL@box=\box37 +\UL@hyphenbox=\box38 +\UL@skip=\skip52 +\UL@hook=\toks31 +\UL@height=\dimen158 +\UL@pe=\count131 +\UL@pixel=\dimen159 +\ULC@box=\box39 +Package: ulem 2012/05/18 +\ULdepth=\dimen160 +) +Package hyperref Info: Option `breaklinks' set `true' on input line 264. +Package hyperref Info: Option `colorlinks' set `true' on input line 264. + (./lecture_12.aux) +\openout1 = `lecture_12.aux'. + +LaTeX Font Info: Checking defaults for OML/cmm/m/it on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for T1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OT1/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMS/cmsy/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for OMX/cmex/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for U/cmr/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for TS1/cmr/m/n on input line 271. +LaTeX Font Info: Try loading font information for TS1+cmr on input line 271. + + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmr.fd +File: ts1cmr.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Checking defaults for PD1/pdf/m/n on input line 271. +LaTeX Font Info: ... okay on input line 271. +LaTeX Font Info: Try loading font information for T1+ppl on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/t1ppl.fd +File: t1ppl.fd 2001/06/04 font definitions for T1/ppl. +) +(/usr/share/texlive/texmf-dist/tex/context/base/supp-pdf.mkii +[Loading MPS to PDF converter (version 2006.09.02).] +\scratchcounter=\count132 +\scratchdimen=\dimen161 +\scratchbox=\box40 +\nofMPsegments=\count133 +\nofMParguments=\count134 +\everyMPshowfont=\toks32 +\MPscratchCnt=\count135 +\MPscratchDim=\dimen162 +\MPnumerator=\count136 +\makeMPintoPDFobject=\count137 +\everyMPtoPDFconversion=\toks33 +) (/usr/share/texlive/texmf-dist/tex/latex/oberdiek/epstopdf-base.sty +Package: epstopdf-base 2010/02/09 v2.5 Base part for package epstopdf + +(/usr/share/texlive/texmf-dist/tex/latex/oberdiek/grfext.sty +Package: grfext 2010/08/19 v1.1 Manage graphics extensions (HO) +) +Package grfext Info: Graphics extension search list: +(grfext) [.png,.pdf,.jpg,.mps,.jpeg,.jbig2,.jb2,.PNG,.PDF,.JPG,.JPE +G,.JBIG2,.JB2,.eps] +(grfext) \AppendGraphicsExtensions on input line 452. + +(/usr/share/texlive/texmf-dist/tex/latex/latexconfig/epstopdf-sys.cfg +File: epstopdf-sys.cfg 2010/07/13 v1.3 Configuration of (r)epstopdf for TeX Liv +e +)) +Package caption Info: Begin \AtBeginDocument code. +Package caption Info: hyperref package is loaded. +Package caption Info: longtable package is loaded. + +(/usr/share/texlive/texmf-dist/tex/latex/caption/ltcaption.sty +Package: ltcaption 2013/06/09 v1.4-94 longtable captions (AR) +) +Package caption Info: End \AtBeginDocument code. + +*geometry* driver: auto-detecting +*geometry* detected driver: pdftex +*geometry* verbose mode - [ preamble ] result: +* driver: pdftex +* paper: <default> +* layout: <same size as paper> +* layoutoffset:(h,v)=(0.0pt,0.0pt) +* modes: +* h-part:(L,W,R)=(72.26999pt, 469.75502pt, 72.26999pt) +* v-part:(T,H,B)=(72.26999pt, 650.43001pt, 72.26999pt) +* \paperwidth=614.295pt +* \paperheight=794.96999pt +* \textwidth=469.75502pt +* \textheight=650.43001pt +* \oddsidemargin=0.0pt +* \evensidemargin=0.0pt +* \topmargin=-37.0pt +* \headheight=12.0pt +* \headsep=25.0pt +* \topskip=11.0pt +* \footskip=30.0pt +* \marginparwidth=59.0pt +* \marginparsep=10.0pt +* \columnsep=10.0pt +* \skip\footins=10.0pt plus 4.0pt minus 2.0pt +* \hoffset=0.0pt +* \voffset=0.0pt +* \mag=1000 +* \@twocolumnfalse +* \@twosidefalse +* \@mparswitchfalse +* \@reversemarginfalse +* (1in=72.27pt=25.4mm, 1cm=28.453pt) + +(/usr/share/texlive/texmf-dist/tex/latex/ucs/ucsencs.def +File: ucsencs.def 2011/01/21 Fixes to fontencodings LGR, T3 +) +\AtBeginShipoutBox=\box41 +Package hyperref Info: Link coloring ON on input line 271. + +(/usr/share/texlive/texmf-dist/tex/latex/hyperref/nameref.sty +Package: nameref 2012/10/27 v2.43 Cross-referencing by name of section + +(/usr/share/texlive/texmf-dist/tex/generic/oberdiek/gettitlestring.sty +Package: gettitlestring 2010/12/03 v1.4 Cleanup title references (HO) +) +\c@section@level=\count138 +) +LaTeX Info: Redefining \ref on input line 271. +LaTeX Info: Redefining \pageref on input line 271. +LaTeX Info: Redefining \nameref on input line 271. + +(./lecture_12.out) (./lecture_12.out) +\@outlinefile=\write4 +\openout4 = `lecture_12.out'. + +LaTeX Font Info: Try loading font information for OT1+ppl on input line 275. + + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1ppl.fd +File: ot1ppl.fd 2001/06/04 font definitions for OT1/ppl. +) +LaTeX Font Info: Try loading font information for OML+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omlzplm.fd +File: omlzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OML/zplm. +) +LaTeX Font Info: Try loading font information for OMS+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omszplm.fd +File: omszplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMS/zplm. +) +LaTeX Font Info: Try loading font information for OMX+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/omxzplm.fd +File: omxzplm.fd 2002/09/08 Fontinst v1.914 font definitions for OMX/zplm. +) +LaTeX Font Info: Try loading font information for OT1+zplm on input line 275 +. + +(/usr/share/texlive/texmf-dist/tex/latex/psnfss/ot1zplm.fd +File: ot1zplm.fd 2002/09/08 Fontinst v1.914 font definitions for OT1/zplm. +) +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 12.50409pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 9.37807pt on input line 275. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 7.29405pt on input line 275. + + +LaTeX Warning: No \author given. + +LaTeX Font Info: Try loading font information for T1+cmtt on input line 279. + +(/usr/share/texlive/texmf-dist/tex/latex/base/t1cmtt.fd +File: t1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) [1 + +{/var/lib/texmf/fonts/map/pdftex/updmap/pdftex.map}] +LaTeX Font Info: Try loading font information for TS1+cmtt on input line 331 +. + +(/usr/share/texlive/texmf-dist/tex/latex/base/ts1cmtt.fd +File: ts1cmtt.fd 2014/09/29 v2.5h Standard LaTeX font definitions +) +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <12> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 359. + +<det_L.png, id=40, 928.46875pt x 453.695pt> +File: det_L.png Graphic file (type png) + <use det_L.png> +Package pdftex.def Info: det_L.png used on input line 363. +(pdftex.def) Requested size: 375.80544pt x 183.64162pt. + +<chol_pre.png, id=42, 943.525pt x 461.725pt> +File: chol_pre.png Graphic file (type png) + <use chol_pre.png> +Package pdftex.def Info: chol_pre.png used on input line 369. +(pdftex.def) Requested size: 375.80544pt x 183.9047pt. + [2 <./det_L.png>] +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <14.4> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 400. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 11.40997pt on input line 404. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 8.33606pt on input line 404. +LaTeX Font Info: Font shape `U/msa/m/n' will be +(Font) scaled to size 6.25204pt on input line 404. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 11.40997pt on input line 404. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 8.33606pt on input line 404. +LaTeX Font Info: Font shape `U/msb/m/n' will be +(Font) scaled to size 6.25204pt on input line 404. + [3 <./chol_pre.png>] [4] +LaTeX Font Info: Font shape `T1/ppl/bx/n' in size <10.95> not available +(Font) Font shape `T1/ppl/b/n' tried instead on input line 503. + [5] [6] [7] [8] +LaTeX Font Info: Font shape `T1/cmtt/bx/n' in size <10.95> not available +(Font) Font shape `T1/cmtt/m/n' tried instead on input line 746. + +<lecture_12_files/lecture_12_24_0.pdf, id=91, 449.68pt x 337.26pt> +File: lecture_12_files/lecture_12_24_0.pdf Graphic file (type pdf) + +<use lecture_12_files/lecture_12_24_0.pdf> +Package pdftex.def Info: lecture_12_files/lecture_12_24_0.pdf used on input lin +e 765. +(pdftex.def) Requested size: 449.6789pt x 337.25917pt. + [9] +Underfull \hbox (badness 10000) in paragraph at lines 767--768 + + [] + +LaTeX Font Info: Font shape `T1/ppl/bx/it' in size <10.95> not available +(Font) Font shape `T1/ppl/b/it' tried instead on input line 773. +[10 <./lecture_12_files/lecture_12_24_0.pdf>] [11] [12] +<../lecture_09/mass_springs.png, id=118, 112.42pt x 190.7125pt> +File: ../lecture_09/mass_springs.png Graphic file (type png) + +<use ../lecture_09/mass_springs.png> +Package pdftex.def Info: ../lecture_09/mass_springs.png used on input line 923. + +(pdftex.def) Requested size: 89.93611pt x 152.576pt. + [13 <../lecture_09/mass_springs.png>] +Package atveryend Info: Empty hook `BeforeClearDocument' on input line 1015. + +[14] +Package atveryend Info: Empty hook `AfterLastShipout' on input line 1015. + (./lecture_12.aux) +Package atveryend Info: Executing hook `AtVeryEndDocument' on input line 1015. +Package atveryend Info: Executing hook `AtEndAfterFileList' on input line 1015. + +Package rerunfilecheck Info: File `lecture_12.out' has not changed. +(rerunfilecheck) Checksum: 2BDB89EC075D3A42B038A5DAC39843C7;535. +Package atveryend Info: Empty hook `AtVeryVeryEnd' on input line 1015. + ) +Here is how much of TeX's memory you used: + 10955 strings out of 493029 + 163811 string characters out of 6136234 + 270140 words of memory out of 5000000 + 14229 multiletter control sequences out of 15000+600000 + 37652 words of font info for 95 fonts, out of 8000000 for 9000 + 1141 hyphenation exceptions out of 8191 + 36i,9n,77p,512b,465s stack positions out of 5000i,500n,10000p,200000b,80000s +{/usr/share/texlive/texmf-dist/fonts/enc/dvips/base/8r.enc}{/usr/share/texmf/ +fonts/enc/dvips/cm-super/cm-super-ts1.enc}{/usr/share/texmf/fonts/enc/dvips/cm- +super/cm-super-t1.enc}</usr/share/texlive/texmf-dist/fonts/type1/public/amsfont +s/cm/cmex10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/c +mr10.pfb></usr/share/texlive/texmf-dist/fonts/type1/public/amsfonts/cm/cmsy10.p +fb></usr/share/texlive/texmf-dist/fonts/type1/public/mathpazo/fplmr.pfb></usr/s +hare/texmf/fonts/type1/public/cm-super/sfit1095.pfb></usr/share/texmf/fonts/typ +e1/public/cm-super/sftt1095.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/ +palatino/uplb8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/palatino/upl +bi8a.pfb></usr/share/texlive/texmf-dist/fonts/type1/urw/palatino/uplr8a.pfb></u +sr/share/texlive/texmf-dist/fonts/type1/urw/palatino/uplri8a.pfb> +Output written on lecture_12.pdf (14 pages, 232410 bytes). +PDF statistics: + 177 PDF objects out of 1000 (max. 8388607) + 140 compressed objects within 2 object streams + 34 named destinations out of 1000 (max. 500000) + 77 words of extra memory for PDF output out of 10000 (max. 10000000) + diff --git a/lecture_12/lecture_12.md b/lecture_12/lecture_12.md new file mode 100644 index 0000000..82f9bea --- /dev/null +++ b/lecture_12/lecture_12.md @@ -0,0 +1,772 @@ + + +```octave +%plot --format svg +``` + + +```octave +setdefaults +``` + + +```octave +A=rand(4,4) + +[L,U,P]=lu(A) + +det(L) +``` + + A = + + 0.447394 0.357071 0.720915 0.499926 + 0.648313 0.323276 0.521677 0.288345 + 0.084982 0.581513 0.466420 0.142342 + 0.576580 0.658089 0.916987 0.923165 + + L = + + 1.00000 0.00000 0.00000 0.00000 + 0.13108 1.00000 0.00000 0.00000 + 0.69009 0.24851 1.00000 0.00000 + 0.88935 0.68736 0.68488 1.00000 + + U = + + 0.64831 0.32328 0.52168 0.28834 + 0.00000 0.53914 0.39804 0.10455 + 0.00000 0.00000 0.26199 0.27496 + 0.00000 0.00000 0.00000 0.40655 + + P = + + Permutation Matrix + + 0 1 0 0 + 0 0 1 0 + 1 0 0 0 + 0 0 0 1 + + ans = 1 + + + +```octave +A=rand(4,100)'; +A=A'*A; +size(A) +min(min(A)) +max(max(A)) +cond(A) +C=chol(A) +``` + + ans = + + 4 4 + + ans = 23.586 + ans = 35.826 + ans = 14.869 + C = + + 5.98549 4.28555 4.35707 4.31359 + 0.00000 3.63950 1.35005 1.45342 + 0.00000 0.00000 3.62851 1.50580 + 0.00000 0.00000 0.00000 3.21911 + + + +## My question from last class + + + + + + +## Your questions from last class + +1. Will the exam be more theoretical or problem based? + +2. Writing code is difficult + +3. What format can we expect for the midterm? + +2. Could we go over some example questions for the exam? + +3. Will the use of GitHub be tested on the Midterm exam? Or is it more focused on linear algebra techniques/what was covered in the lectures? + +4. This is not my strong suit, getting a bit overwhelmed with matrix multiplication. + +5. I forgot how much I learned in linear algebra. + +6. What's the most exciting project you've ever worked on with Matlab/Octave? + +# Matrix Inverse and Condition + + +Considering the same solution set: + +$y=Ax$ + +If we know that $A^{-1}A=I$, then + +$A^{-1}y=A^{-1}Ax=x$ + +so + +$x=A^{-1}y$ + +Where, $A^{-1}$ is the inverse of matrix $A$. + +$2x_{1}+x_{2}=1$ + +$x_{1}+3x_{2}=1$ + +$Ax=y$ + +$\left[ \begin{array}{cc} +2 & 1 \\ +1 & 3 \end{array} \right] +\left[\begin{array}{c} +x_{1} \\ +x_{2} \end{array}\right]= +\left[\begin{array}{c} +1 \\ +1\end{array}\right]$ + +$A^{-1}=\frac{1}{2*3-1*1}\left[ \begin{array}{cc} +3 & -1 \\ +-1 & 2 \end{array} \right]= +\left[ \begin{array}{cc} +3/5 & -1/5 \\ +-1/5 & 2/5 \end{array} \right]$ + + + +```octave +A=[2,1;1,3] +invA=1/5*[3,-1;-1,2] + +A*invA +invA*A +``` + + A = + + 2 1 + 1 3 + + invA = + + 0.60000 -0.20000 + -0.20000 0.40000 + + ans = + + 1.00000 0.00000 + 0.00000 1.00000 + + ans = + + 1.00000 0.00000 + 0.00000 1.00000 + + + +How did we know the inverse of A? + +for 2$\times$2 matrices, it is always: + +$A=\left[ \begin{array}{cc} +A_{11} & A_{12} \\ +A_{21} & A_{22} \end{array} \right]$ + +$A^{-1}=\frac{1}{det(A)}\left[ \begin{array}{cc} +A_{22} & -A_{12} \\ +-A_{21} & A_{11} \end{array} \right]$ + +$AA^{-1}=\frac{1}{A_{11}A_{22}-A_{21}A_{12}}\left[ \begin{array}{cc} +A_{11}A_{22}-A_{21}A_{12} & -A_{11}A_{12}+A_{12}A_{11} \\ +A_{21}A_{22}-A_{22}A_{21} & -A_{21}A_{12}+A_{22}A_{11} \end{array} \right] +=\left[ \begin{array}{cc} +1 & 0 \\ +0 & 1 \end{array} \right]$ + +What about bigger matrices? + +We can use the LU-decomposition + +$A=LU$ + +$A^{-1}=(LU)^{-1}=U^{-1}L^{-1}$ + +if we divide $A^{-1}$ into n-column vectors, $a_{n}$, then + +$Aa_{1}=\left[\begin{array}{c} +1 \\ +0 \\ +\vdots \\ +0 \end{array} \right]$ +$Aa_{2}=\left[\begin{array}{c} +0 \\ +1 \\ +\vdots \\ +0 \end{array} \right]$ +$Aa_{n}=\left[\begin{array}{c} +0 \\ +0 \\ +\vdots \\ +1 \end{array} \right]$ + + +Which we can solve for each $a_{n}$ with LU-decomposition, knowing the lower and upper triangular decompositions, then + +$A^{-1}=\left[ \begin{array}{cccc} +| & | & & | \\ +a_{1} & a_{2} & \cdots & a_{n} \\ +| & | & & | \end{array} \right]$ + + +$Ld_{1}=\left[\begin{array}{c} +1 \\ +0 \\ +\vdots \\ +0 \end{array} \right]$ +$;~Ua_{1}=d_{1}$ + +$Ld_{2}=\left[\begin{array}{c} +0 \\ +1 \\ +\vdots \\ +0 \end{array} \right]$ +$;~Ua_{2}=d_{2}$ + +$Ld_{n}=\left[\begin{array}{c} +0 \\ +1 \\ +\vdots \\ +n \end{array} \right]$ +$;~Ua_{n}=d_{n}$ + +Consider the following matrix: + +$A=\left[ \begin{array}{ccc} +2 & -1 & 0\\ +-1 & 2 & -1\\ +0 & -1 & 1 \end{array} \right]$ + + +#### Note on solving for $A^{-1}$ column 1 + +$Aa_1=I(:,1)$ + +$LUa_1=I(:,1)$ + +$(LUa_1-I(:,1))=0$ + +$L(Ua_1-d_1)=0$ + +$I(:,1)=Ld_1$ + + +```octave +A=[2,-1,0;-1,2,-1;0,-1,1] +U=A; +L=eye(3,3); +U(2,:)=U(2,:)-U(2,1)/U(1,1)*U(1,:) +L(2,1)=A(2,1)/A(1,1) +``` + + A = + + 2 -1 0 + -1 2 -1 + 0 -1 1 + + U = + + 2.00000 -1.00000 0.00000 + 0.00000 1.50000 -1.00000 + 0.00000 -1.00000 1.00000 + + L = + + 1.00000 0.00000 0.00000 + -0.50000 1.00000 0.00000 + 0.00000 0.00000 1.00000 + + + + +```octave +L(3,2)=U(3,2)/U(2,2) +U(3,:)=U(3,:)-U(3,2)/U(2,2)*U(2,:) + +``` + + L = + + 1.00000 0.00000 0.00000 + -0.50000 1.00000 0.00000 + 0.00000 -0.66667 1.00000 + + U = + + 2.00000 -1.00000 0.00000 + 0.00000 1.50000 -1.00000 + 0.00000 0.00000 0.33333 + + + +Now solve for $d_1$ then $a_1$, $d_2$ then $a_2$, and $d_3$ then $a_{3}$ + +$Ld_{1}=\left[\begin{array}{c} +1 \\ +0 \\ +\vdots \\ +0 \end{array} \right]= +\left[\begin{array}{ccc} +1 & 0 & 0 \\ +-1/2 & 1 & 0 \\ +0 & -2/3 & 1 \end{array} \right]\left[\begin{array}{c} +d1(1) \\ +d1(2) \\ +d1(3)\end{array} \right]=\left[\begin{array}{c} +1 \\ +0 \\ +0 \end{array} \right] +;~Ua_{1}=d_{1}$ + + +```octave +d1=zeros(3,1); +d1(1)=1; +d1(2)=0-L(2,1)*d1(1); +d1(3)=0-L(3,1)*d1(1)-L(3,2)*d1(2) +``` + + d1 = + + 1.00000 + 0.50000 + 0.33333 + + + + +```octave +a1=zeros(3,1); +a1(3)=d1(3)/U(3,3); +a1(2)=1/U(2,2)*(d1(2)-U(2,3)*a1(3)); +a1(1)=1/U(1,1)*(d1(1)-U(1,2)*a1(2)-U(1,3)*a1(3)) +``` + + a1 = + + 1.00000 + 1.00000 + 1.00000 + + + + +```octave +d2=zeros(3,1); +d2(1)=0; +d2(2)=1-L(2,1)*d2(1); +d2(3)=0-L(3,1)*d2(1)-L(3,2)*d2(2) +``` + + d2 = + + 0.00000 + 1.00000 + 0.66667 + + + + +```octave +a2=zeros(3,1); +a2(3)=d2(3)/U(3,3); +a2(2)=1/U(2,2)*(d2(2)-U(2,3)*a2(3)); +a2(1)=1/U(1,1)*(d2(1)-U(1,2)*a2(2)-U(1,3)*a2(3)) +``` + + a2 = + + 1.0000 + 2.0000 + 2.0000 + + + + +```octave +d3=zeros(3,1); +d3(1)=0; +d3(2)=0-L(2,1)*d3(1); +d3(3)=1-L(3,1)*d3(1)-L(3,2)*d3(2) +``` + + d3 = + + 0 + 0 + 1 + + + + +```octave +a3=zeros(3,1); +a3(3)=d3(3)/U(3,3); +a3(2)=1/U(2,2)*(d3(2)-U(2,3)*a3(3)); +a3(1)=1/U(1,1)*(d3(1)-U(1,2)*a3(2)-U(1,3)*a3(3)) +``` + + a3 = + + 1.00000 + 2.00000 + 3.00000 + + + +Final solution for $A^{-1}$ is $[a_{1}~a_{2}~a_{3}]$ + + +```octave +invA=[a1,a2,a3] +I_app=A*invA +I_app(2,3) +eps + +2^-8 +``` + + invA = + + 1.00000 1.00000 1.00000 + 1.00000 2.00000 2.00000 + 1.00000 2.00000 3.00000 + + I_app = + + 1.00000 0.00000 0.00000 + 0.00000 1.00000 -0.00000 + -0.00000 -0.00000 1.00000 + + ans = -4.4409e-16 + ans = 2.2204e-16 + ans = 0.0039062 + + +Now the solution of $x$ to $Ax=y$ is $x=A^{-1}y$ + + +```octave +y=[1;2;3] +x=invA*y +xbs=A\y +x-xbs +eps +``` + + y = + + 1 + 2 + 3 + + x = + + 6.0000 + 11.0000 + 14.0000 + + xbs = + + 6.0000 + 11.0000 + 14.0000 + + ans = + + -3.5527e-15 + -8.8818e-15 + -1.0658e-14 + + ans = 2.2204e-16 + + + +```octave +N=100; +n=[1:N]; +t_inv=zeros(N,1); +t_bs=zeros(N,1); +t_mult=zeros(N,1); +for i=1:N + A=rand(i,i); + tic + invA=inv(A); + t_inv(i)=toc; + b=rand(i,1); + tic; + x=A\b; + t_bs(i)=toc; + tic; + x=invA*b; + t_mult(i)=toc; +end +plot(n,t_inv,n,t_bs,n,t_mult) +axis([0 100 0 0.002]) +legend('inversion','backslash','multiplication','Location','NorthWest') +``` + + + + + +## Condition of a matrix +### *just checked in to see what condition my condition was in* +### Matrix norms + +The Euclidean norm of a vector is measure of the magnitude (in 3D this would be: $|x|=\sqrt{x_{1}^{2}+x_{2}^{2}+x_{3}^{2}}$) in general the equation is: + +$||x||_{e}=\sqrt{\sum_{i=1}^{n}x_{i}^{2}}$ + +For a matrix, A, the same norm is called the Frobenius norm: + +$||A||_{f}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{2}}$ + +In general we can calculate any $p$-norm where + +$||A||_{p}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{p}}$ + +so the p=1, 1-norm is + +$||A||_{1}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{1}}=\sum_{i=1}^{n}\sum_{i=1}^{m}|A_{i,j}|$ + +$||A||_{\infty}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{\infty}}=\max_{1\le i \le n}\sum_{j=1}^{m}|A_{i,j}|$ + +### Condition of Matrix + +The matrix condition is the product of + +$Cond(A) = ||A||\cdot||A^{-1}||$ + +So each norm will have a different condition number, but the limit is $Cond(A)\ge 1$ + +An estimate of the rounding error is based on the condition of A: + +$\frac{||\Delta x||}{x} \le Cond(A) \frac{||\Delta A||}{||A||}$ + +So if the coefficients of A have accuracy to $10^{-t} + +and the condition of A, $Cond(A)=10^{c}$ + +then the solution for x can have rounding errors up to $10^{c-t}$ + + + +```octave +A=[1,1/2,1/3;1/2,1/3,1/4;1/3,1/4,1/5] +[L,U]=LU_naive(A) +``` + + A = + + 1.00000 0.50000 0.33333 + 0.50000 0.33333 0.25000 + 0.33333 0.25000 0.20000 + + L = + + 1.00000 0.00000 0.00000 + 0.50000 1.00000 0.00000 + 0.33333 1.00000 1.00000 + + U = + + 1.00000 0.50000 0.33333 + 0.00000 0.08333 0.08333 + 0.00000 -0.00000 0.00556 + + + +Then, $A^{-1}=(LU)^{-1}=U^{-1}L^{-1}$ + +$Ld_{1}=\left[\begin{array}{c} +1 \\ +0 \\ +0 \end{array}\right]$, $Ux_{1}=d_{1}$ ... + + +```octave +invA=zeros(3,3); +d1=L\[1;0;0]; +d2=L\[0;1;0]; +d3=L\[0;0;1]; +invA(:,1)=U\d1; +invA(:,2)=U\d2; +invA(:,3)=U\d3 +invA*A +``` + + invA = + + 9.0000 -36.0000 30.0000 + -36.0000 192.0000 -180.0000 + 30.0000 -180.0000 180.0000 + + ans = + + 1.0000e+00 3.5527e-15 2.9976e-15 + -1.3249e-14 1.0000e+00 -9.1038e-15 + 8.5117e-15 7.1054e-15 1.0000e+00 + + + +Find the condition of A, $cond(A)$ + + +```octave +% Frobenius norm +normf_A = sqrt(sum(sum(A.^2))) +normf_invA = sqrt(sum(sum(invA.^2))) + +cond_f_A = normf_A*normf_invA + +norm(A,'fro') + +% p=1, column sum norm +norm1_A = max(sum(A,2)) +norm1_invA = max(sum(invA,2)) +norm(A,1) + +cond_1_A=norm1_A*norm1_invA + +% p=inf, row sum norm +norminf_A = max(sum(A,1)) +norminf_invA = max(sum(invA,1)) +norm(A,inf) + +cond_inf_A=norminf_A*norminf_invA + +``` + + normf_A = 1.4136 + normf_invA = 372.21 + cond_f_A = 526.16 + ans = 1.4136 + norm1_A = 1.8333 + norm1_invA = 30.000 + ans = 1.8333 + cond_1_A = 55.000 + norminf_A = 1.8333 + norminf_invA = 30.000 + ans = 1.8333 + cond_inf_A = 55.000 + + +Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with spring constants $K_{i}$. What does a high condition number mean for this problem? + + + +The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass: + +$m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0$ + +$m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0$ + +$m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0$ + +$m_{4}g-k_{4}(x_{4}-x_{3})=0$ + +in matrix form: + +$\left[ \begin{array}{cccc} +k_{1}+k_{2} & -k_{2} & 0 & 0 \\ +-k_{2} & k_{2}+k_{3} & -k_{3} & 0 \\ +0 & -k_{3} & k_{3}+k_{4} & -k_{4} \\ +0 & 0 & -k_{4} & k_{4} \end{array} \right] +\left[ \begin{array}{c} +x_{1} \\ +x_{2} \\ +x_{3} \\ +x_{4} \end{array} \right]= +\left[ \begin{array}{c} +m_{1}g \\ +m_{2}g \\ +m_{3}g \\ +m_{4}g \end{array} \right]$ + + +```octave +k1=10; % N/m +k2=100000; +k3=10; +k4=1; +m1=1; % kg +m2=2; +m3=3; +m4=4; +g=9.81; % m/s^2 +K=[k1+k2 -k2 0 0; -k2 k2+k3 -k3 0; 0 -k3 k3+k4 -k4; 0 0 -k4 k4] +y=[m1*g;m2*g;m3*g;m4*g] +``` + + K = + + 100010 -100000 0 0 + -100000 100010 -10 0 + 0 -10 11 -1 + 0 0 -1 1 + + y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + + +```octave +cond(K,inf) +cond(K,1) +cond(K,'fro') +cond(K,2) +``` + + ans = 3.2004e+05 + ans = 3.2004e+05 + ans = 2.5925e+05 + ans = 2.5293e+05 + + + +```octave +e=eig(K) +max(e)/min(e) +``` + + e = + + 7.9078e-01 + 3.5881e+00 + 1.7621e+01 + 2.0001e+05 + + ans = 2.5293e+05 + + + +```octave + +``` diff --git a/lecture_12/lecture_12.out b/lecture_12/lecture_12.out new file mode 100644 index 0000000..e7b5af8 --- /dev/null +++ b/lecture_12/lecture_12.out @@ -0,0 +1,7 @@ +\BOOKMARK [2][-]{subsection.0.1}{My question from last class}{}% 1 +\BOOKMARK [2][-]{subsection.0.2}{Your questions from last class}{}% 2 +\BOOKMARK [1][-]{section.1}{Matrix Inverse and Condition}{}% 3 +\BOOKMARK [2][-]{subsection.1.1}{Condition of a matrix}{section.1}% 4 +\BOOKMARK [3][-]{subsubsection.1.1.1}{just checked in to see what condition my condition was in}{subsection.1.1}% 5 +\BOOKMARK [3][-]{subsubsection.1.1.2}{Matrix norms}{subsection.1.1}% 6 +\BOOKMARK [3][-]{subsubsection.1.1.3}{Condition of Matrix}{subsection.1.1}% 7 diff --git a/lecture_12/lecture_12.pdf b/lecture_12/lecture_12.pdf new file mode 100644 index 0000000..e0b4e6c Binary files /dev/null and b/lecture_12/lecture_12.pdf differ diff --git a/lecture_12/lecture_12.tex b/lecture_12/lecture_12.tex new file mode 100644 index 0000000..1265a06 --- /dev/null +++ b/lecture_12/lecture_12.tex @@ -0,0 +1,1015 @@ + +% Default to the notebook output style + + + + +% Inherit from the specified cell style. + + + + + +\documentclass[11pt]{article} + + + + \usepackage[T1]{fontenc} + % Nicer default font (+ math font) than Computer Modern for most use cases + \usepackage{mathpazo} + + % Basic figure setup, for now with no caption control since it's done + % automatically by Pandoc (which extracts  syntax from Markdown). + \usepackage{graphicx} + % We will generate all images so they have a width \maxwidth. This means + % that they will get their normal width if they fit onto the page, but + % are scaled down if they would overflow the margins. + \makeatletter + \def\maxwidth{\ifdim\Gin@nat@width>\linewidth\linewidth + \else\Gin@nat@width\fi} + \makeatother + \let\Oldincludegraphics\includegraphics + % Set max figure width to be 80% of text width, for now hardcoded. + \renewcommand{\includegraphics}[1]{\Oldincludegraphics[width=.8\maxwidth]{#1}} + % Ensure that by default, figures have no caption (until we provide a + % proper Figure object with a Caption API and a way to capture that + % in the conversion process - todo). + \usepackage{caption} + \DeclareCaptionLabelFormat{nolabel}{} + \captionsetup{labelformat=nolabel} + + \usepackage{adjustbox} % Used to constrain images to a maximum size + \usepackage{xcolor} % Allow colors to be defined + \usepackage{enumerate} % Needed for markdown enumerations to work + \usepackage{geometry} % Used to adjust the document margins + \usepackage{amsmath} % Equations + \usepackage{amssymb} % Equations + \usepackage{textcomp} % defines textquotesingle + % Hack from http://tex.stackexchange.com/a/47451/13684: + \AtBeginDocument{% + \def\PYZsq{\textquotesingle}% Upright quotes in Pygmentized code + } + \usepackage{upquote} % Upright quotes for verbatim code + \usepackage{eurosym} % defines \euro + \usepackage[mathletters]{ucs} % Extended unicode (utf-8) support + \usepackage[utf8x]{inputenc} % Allow utf-8 characters in the tex document + \usepackage{fancyvrb} % verbatim replacement that allows latex + \usepackage{grffile} % extends the file name processing of package graphics + % to support a larger range + % The hyperref package gives us a pdf with properly built + % internal navigation ('pdf bookmarks' for the table of contents, + % internal cross-reference links, web links for URLs, etc.) + \usepackage{hyperref} + \usepackage{longtable} % longtable support required by pandoc >1.10 + \usepackage{booktabs} % table support for pandoc > 1.12.2 + \usepackage[inline]{enumitem} % IRkernel/repr support (it uses the enumerate* environment) + \usepackage[normalem]{ulem} % ulem is needed to support strikethroughs (\sout) + % normalem makes italics be italics, not underlines + + + + + % Colors for the hyperref package + \definecolor{urlcolor}{rgb}{0,.145,.698} + \definecolor{linkcolor}{rgb}{.71,0.21,0.01} + \definecolor{citecolor}{rgb}{.12,.54,.11} + + % ANSI colors + \definecolor{ansi-black}{HTML}{3E424D} + \definecolor{ansi-black-intense}{HTML}{282C36} + \definecolor{ansi-red}{HTML}{E75C58} + \definecolor{ansi-red-intense}{HTML}{B22B31} + \definecolor{ansi-green}{HTML}{00A250} + \definecolor{ansi-green-intense}{HTML}{007427} + \definecolor{ansi-yellow}{HTML}{DDB62B} + \definecolor{ansi-yellow-intense}{HTML}{B27D12} + \definecolor{ansi-blue}{HTML}{208FFB} + \definecolor{ansi-blue-intense}{HTML}{0065CA} + \definecolor{ansi-magenta}{HTML}{D160C4} + \definecolor{ansi-magenta-intense}{HTML}{A03196} + \definecolor{ansi-cyan}{HTML}{60C6C8} + \definecolor{ansi-cyan-intense}{HTML}{258F8F} + \definecolor{ansi-white}{HTML}{C5C1B4} + \definecolor{ansi-white-intense}{HTML}{A1A6B2} + + % commands and environments needed by pandoc snippets + % extracted from the output of `pandoc -s` + \providecommand{\tightlist}{% + \setlength{\itemsep}{0pt}\setlength{\parskip}{0pt}} + \DefineVerbatimEnvironment{Highlighting}{Verbatim}{commandchars=\\\{\}} + % Add ',fontsize=\small' for more characters per line + \newenvironment{Shaded}{}{} + \newcommand{\KeywordTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\DataTypeTok}[1]{\textcolor[rgb]{0.56,0.13,0.00}{{#1}}} + \newcommand{\DecValTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\BaseNTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\FloatTok}[1]{\textcolor[rgb]{0.25,0.63,0.44}{{#1}}} + \newcommand{\CharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\StringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\CommentTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textit{{#1}}}} + \newcommand{\OtherTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{{#1}}} + \newcommand{\AlertTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\FunctionTok}[1]{\textcolor[rgb]{0.02,0.16,0.49}{{#1}}} + \newcommand{\RegionMarkerTok}[1]{{#1}} + \newcommand{\ErrorTok}[1]{\textcolor[rgb]{1.00,0.00,0.00}{\textbf{{#1}}}} + \newcommand{\NormalTok}[1]{{#1}} + + % Additional commands for more recent versions of Pandoc + \newcommand{\ConstantTok}[1]{\textcolor[rgb]{0.53,0.00,0.00}{{#1}}} + \newcommand{\SpecialCharTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\VerbatimStringTok}[1]{\textcolor[rgb]{0.25,0.44,0.63}{{#1}}} + \newcommand{\SpecialStringTok}[1]{\textcolor[rgb]{0.73,0.40,0.53}{{#1}}} + \newcommand{\ImportTok}[1]{{#1}} + \newcommand{\DocumentationTok}[1]{\textcolor[rgb]{0.73,0.13,0.13}{\textit{{#1}}}} + \newcommand{\AnnotationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\CommentVarTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\VariableTok}[1]{\textcolor[rgb]{0.10,0.09,0.49}{{#1}}} + \newcommand{\ControlFlowTok}[1]{\textcolor[rgb]{0.00,0.44,0.13}{\textbf{{#1}}}} + \newcommand{\OperatorTok}[1]{\textcolor[rgb]{0.40,0.40,0.40}{{#1}}} + \newcommand{\BuiltInTok}[1]{{#1}} + \newcommand{\ExtensionTok}[1]{{#1}} + \newcommand{\PreprocessorTok}[1]{\textcolor[rgb]{0.74,0.48,0.00}{{#1}}} + \newcommand{\AttributeTok}[1]{\textcolor[rgb]{0.49,0.56,0.16}{{#1}}} + \newcommand{\InformationTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + \newcommand{\WarningTok}[1]{\textcolor[rgb]{0.38,0.63,0.69}{\textbf{\textit{{#1}}}}} + + + % Define a nice break command that doesn't care if a line doesn't already + % exist. + \def\br{\hspace*{\fill} \\* } + % Math Jax compatability definitions + \def\gt{>} + \def\lt{<} + % Document parameters + \title{lecture\_12} + + + + + % Pygments definitions + +\makeatletter +\def\PY@reset{\let\PY@it=\relax \let\PY@bf=\relax% + \let\PY@ul=\relax \let\PY@tc=\relax% + \let\PY@bc=\relax \let\PY@ff=\relax} +\def\PY@tok#1{\csname PY@tok@#1\endcsname} +\def\PY@toks#1+{\ifx\relax#1\empty\else% + \PY@tok{#1}\expandafter\PY@toks\fi} +\def\PY@do#1{\PY@bc{\PY@tc{\PY@ul{% + \PY@it{\PY@bf{\PY@ff{#1}}}}}}} +\def\PY#1#2{\PY@reset\PY@toks#1+\relax+\PY@do{#2}} + +\expandafter\def\csname PY@tok@gd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@gu\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.50,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@gt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.27,0.87}{##1}}} +\expandafter\def\csname PY@tok@gs\endcsname{\let\PY@bf=\textbf} +\expandafter\def\csname PY@tok@gr\endcsname{\def\PY@tc##1{\textcolor[rgb]{1.00,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@cm\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@vg\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@vi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@mh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@cs\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@ge\endcsname{\let\PY@it=\textit} +\expandafter\def\csname PY@tok@vc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@il\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@go\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.53,0.53}{##1}}} +\expandafter\def\csname PY@tok@cp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.74,0.48,0.00}{##1}}} +\expandafter\def\csname PY@tok@gi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@gh\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@ni\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.60,0.60,0.60}{##1}}} +\expandafter\def\csname PY@tok@nl\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.63,0.63,0.00}{##1}}} +\expandafter\def\csname PY@tok@nn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@no\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.53,0.00,0.00}{##1}}} +\expandafter\def\csname PY@tok@na\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.49,0.56,0.16}{##1}}} +\expandafter\def\csname PY@tok@nb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@nd\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@ne\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.82,0.25,0.23}{##1}}} +\expandafter\def\csname PY@tok@nf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,1.00}{##1}}} +\expandafter\def\csname PY@tok@si\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@s2\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@nt\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@nv\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@s1\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ch\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@m\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@gp\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.00,0.50}{##1}}} +\expandafter\def\csname PY@tok@sh\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@ow\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.67,0.13,1.00}{##1}}} +\expandafter\def\csname PY@tok@sx\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@bp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c1\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@o\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kc\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@c\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@mf\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@err\endcsname{\def\PY@bc##1{\setlength{\fboxsep}{0pt}\fcolorbox[rgb]{1.00,0.00,0.00}{1,1,1}{\strut ##1}}} +\expandafter\def\csname PY@tok@mb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@ss\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.10,0.09,0.49}{##1}}} +\expandafter\def\csname PY@tok@sr\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.53}{##1}}} +\expandafter\def\csname PY@tok@mo\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kd\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@mi\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.40,0.40,0.40}{##1}}} +\expandafter\def\csname PY@tok@kn\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@cpf\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.25,0.50,0.50}{##1}}} +\expandafter\def\csname PY@tok@kr\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@s\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@kp\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@w\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.73,0.73}{##1}}} +\expandafter\def\csname PY@tok@kt\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.69,0.00,0.25}{##1}}} +\expandafter\def\csname PY@tok@sc\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@sb\endcsname{\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} +\expandafter\def\csname PY@tok@k\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.00,0.50,0.00}{##1}}} +\expandafter\def\csname PY@tok@se\endcsname{\let\PY@bf=\textbf\def\PY@tc##1{\textcolor[rgb]{0.73,0.40,0.13}{##1}}} +\expandafter\def\csname PY@tok@sd\endcsname{\let\PY@it=\textit\def\PY@tc##1{\textcolor[rgb]{0.73,0.13,0.13}{##1}}} + +\def\PYZbs{\char`\\} +\def\PYZus{\char`\_} +\def\PYZob{\char`\{} +\def\PYZcb{\char`\}} +\def\PYZca{\char`\^} +\def\PYZam{\char`\&} +\def\PYZlt{\char`\<} +\def\PYZgt{\char`\>} +\def\PYZsh{\char`\#} +\def\PYZpc{\char`\%} +\def\PYZdl{\char`\$} +\def\PYZhy{\char`\-} +\def\PYZsq{\char`\'} +\def\PYZdq{\char`\"} +\def\PYZti{\char`\~} +% for compatibility with earlier versions +\def\PYZat{@} +\def\PYZlb{[} +\def\PYZrb{]} +\makeatother + + + % Exact colors from NB + \definecolor{incolor}{rgb}{0.0, 0.0, 0.5} + \definecolor{outcolor}{rgb}{0.545, 0.0, 0.0} + + + + + % Prevent overflowing lines due to hard-to-break entities + \sloppy + % Setup hyperref package + \hypersetup{ + breaklinks=true, % so long urls are correctly broken across lines + colorlinks=true, + urlcolor=urlcolor, + linkcolor=linkcolor, + citecolor=citecolor, + } + % Slightly bigger margins than the latex defaults + + \geometry{verbose,tmargin=1in,bmargin=1in,lmargin=1in,rmargin=1in} + + + + \begin{document} + + + \maketitle + + + + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}27}]:} \PY{c}{\PYZpc{}plot \PYZhy{}\PYZhy{}format svg} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}28}]:} \PY{n}{setdefaults} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}29}]:} \PY{n}{A}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{4}\PY{p}{)} + + \PY{p}{[}\PY{n}{L}\PY{p}{,}\PY{n}{U}\PY{p}{,}\PY{n}{P}\PY{p}{]}\PY{p}{=}\PY{n+nb}{lu}\PY{p}{(}\PY{n}{A}\PY{p}{)} + + \PY{n+nb}{det}\PY{p}{(}\PY{n}{L}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 0.447394 0.357071 0.720915 0.499926 + 0.648313 0.323276 0.521677 0.288345 + 0.084982 0.581513 0.466420 0.142342 + 0.576580 0.658089 0.916987 0.923165 + +L = + + 1.00000 0.00000 0.00000 0.00000 + 0.13108 1.00000 0.00000 0.00000 + 0.69009 0.24851 1.00000 0.00000 + 0.88935 0.68736 0.68488 1.00000 + +U = + + 0.64831 0.32328 0.52168 0.28834 + 0.00000 0.53914 0.39804 0.10455 + 0.00000 0.00000 0.26199 0.27496 + 0.00000 0.00000 0.00000 0.40655 + +P = + +Permutation Matrix + + 0 1 0 0 + 0 0 1 0 + 1 0 0 0 + 0 0 0 1 + +ans = 1 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}44}]:} \PY{n}{A}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{100}\PY{p}{)}\PY{o}{\PYZsq{}}\PY{p}{;} + \PY{n}{A}\PY{p}{=}\PY{n}{A}\PY{o}{\PYZsq{}}\PY{o}{*}\PY{n}{A}\PY{p}{;} + \PY{n+nb}{size}\PY{p}{(}\PY{n}{A}\PY{p}{)} + \PY{n+nb}{min}\PY{p}{(}\PY{n+nb}{min}\PY{p}{(}\PY{n}{A}\PY{p}{)}\PY{p}{)} + \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{max}\PY{p}{(}\PY{n}{A}\PY{p}{)}\PY{p}{)} + \PY{n+nb}{cond}\PY{p}{(}\PY{n}{A}\PY{p}{)} + \PY{n}{C}\PY{p}{=}\PY{n+nb}{chol}\PY{p}{(}\PY{n}{A}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = + + 4 4 + +ans = 23.586 +ans = 35.826 +ans = 14.869 +C = + + 5.98549 4.28555 4.35707 4.31359 + 0.00000 3.63950 1.35005 1.45342 + 0.00000 0.00000 3.62851 1.50580 + 0.00000 0.00000 0.00000 3.21911 + + + \end{Verbatim} + + \subsection{My question from last +class}\label{my-question-from-last-class} + +\begin{figure}[htbp] +\centering +\includegraphics{det_L.png} +\caption{q1} +\end{figure} + +\begin{figure}[htbp] +\centering +\includegraphics{chol_pre.png} +\caption{q2} +\end{figure} + +\subsection{Your questions from last +class}\label{your-questions-from-last-class} + +\begin{enumerate} +\def\labelenumi{\arabic{enumi}.} +\item + Will the exam be more theoretical or problem based? +\item + Writing code is difficult +\item + What format can we expect for the midterm? +\item + Could we go over some example questions for the exam? +\item + Will the use of GitHub be tested on the Midterm exam? Or is it more + focused on linear algebra techniques/what was covered in the lectures? +\item + This is not my strong suit, getting a bit overwhelmed with matrix + multiplication. +\item + I forgot how much I learned in linear algebra. +\item + What's the most exciting project you've ever worked on with + Matlab/Octave? +\end{enumerate} + + \section{Matrix Inverse and +Condition}\label{matrix-inverse-and-condition} + +Considering the same solution set: + +\(y=Ax\) + +If we know that \(A^{-1}A=I\), then + +\(A^{-1}y=A^{-1}Ax=x\) + +so + +\(x=A^{-1}y\) + +Where, \(A^{-1}\) is the inverse of matrix \(A\). + +\(2x_{1}+x_{2}=1\) + +\(x_{1}+3x_{2}=1\) + +\(Ax=y\) + +\(\left[ \begin{array}{cc} 2 & 1 \\ 1 & 3 \end{array} \right] \left[\begin{array}{c} x_{1} \\ x_{2} \end{array}\right]= \left[\begin{array}{c} 1 \\ 1\end{array}\right]\) + +\(A^{-1}=\frac{1}{2*3-1*1}\left[ \begin{array}{cc} 3 & -1 \\ -1 & 2 \end{array} \right]= \left[ \begin{array}{cc} 3/5 & -1/5 \\ -1/5 & 2/5 \end{array} \right]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}45}]:} \PY{n}{A}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{]} + \PY{n}{invA}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{5}\PY{o}{*}\PY{p}{[}\PY{l+m+mi}{3}\PY{p}{,}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{]} + + \PY{n}{A}\PY{o}{*}\PY{n}{invA} + \PY{n}{invA}\PY{o}{*}\PY{n}{A} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 2 1 + 1 3 + +invA = + + 0.60000 -0.20000 + -0.20000 0.40000 + +ans = + + 1.00000 0.00000 + 0.00000 1.00000 + +ans = + + 1.00000 0.00000 + 0.00000 1.00000 + + + \end{Verbatim} + + How did we know the inverse of A? + +for 2$\times$2 matrices, it is always: + +$A=\left[ \begin{array}{cc} A_{11} & A_{12} \\ A_{21} & A_{22} \end{array} \right]$ + +$A^{-1}=\frac{1}{det(A)}\left[ \begin{array}{cc} A_{22} & -A_{12} \\ -A_{21} & A_{11} \end{array} \right]$ + + $AA^{-1}=\frac{1}{A_{11}A_{22}-A_{21}A_{12}}\left[ \begin{array}{cc} A_{11}A_{22}-A_{21}A_{12} & -A_{11}A_{12}+A_{12}A_{11} \\ A_{21}A_{22}-A_{22}A_{21} & -A_{21}A_{12}+A_{22}A_{11} \end{array} \right] =\left[ \begin{array}{cc} 1 & 0 \\ 0 & 1 \end{array} \right]$ + + What about bigger matrices? + +We can use the LU-decomposition + +\(A=LU\) + +\(A^{-1}=(LU)^{-1}=U^{-1}L^{-1}\) + +if we divide \(A^{-1}\) into n-column vectors, \(a_{n}\), then + +\(Aa_{1}=\left[\begin{array}{c} 1 \\ 0 \\ \vdots \\ 0 \end{array} \right]\) +\(Aa_{2}=\left[\begin{array}{c} 0 \\ 1 \\ \vdots \\ 0 \end{array} \right]\) +\(Aa_{n}=\left[\begin{array}{c} 0 \\ 0 \\ \vdots \\ 1 \end{array} \right]\) + +Which we can solve for each \(a_{n}\) with LU-decomposition, knowing the +lower and upper triangular decompositions, then + +\(A^{-1}=\left[ \begin{array}{cccc} | & | & & | \\ a_{1} & a_{2} & \cdots & a_{n} \\ | & | & & | \end{array} \right]\) + +\(Ld_{1}=\left[\begin{array}{c} 1 \\ 0 \\ \vdots \\ 0 \end{array} \right]\) +\(;~Ua_{1}=d_{1}\) + +\(Ld_{2}=\left[\begin{array}{c} 0 \\ 1 \\ \vdots \\ 0 \end{array} \right]\) +\(;~Ua_{2}=d_{2}\) + +\(Ld_{n}=\left[\begin{array}{c} 0 \\ 1 \\ \vdots \\ n \end{array} \right]\) +\(;~Ua_{n}=d_{n}\) + +Consider the following matrix: + +\(A=\left[ \begin{array}{ccc} 2 & -1 & 0\\ -1 & 2 & -1\\ 0 & -1 & 1 \end{array} \right]\) + + \paragraph{\texorpdfstring{Note on solving for \(A^{-1}\) column +1}{Note on solving for A\^{}\{-1\} column 1}}\label{note-on-solving-for-a-1-column-1} + +\(Aa_1=I(:,1)\) + +\(LUa_1=I(:,1)\) + +\((LUa_1-I(:,1))=0\) + +\(L(Ua_1-d_1)=0\) + +\(I(:,1)=Ld_1\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}56}]:} \PY{n}{A}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{2}\PY{p}{,}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{0}\PY{p}{;}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{,}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{,}\PY{o}{\PYZhy{}}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{]} + \PY{n}{U}\PY{p}{=}\PY{n}{A}\PY{p}{;} + \PY{n}{L}\PY{p}{=}\PY{n+nb}{eye}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{;} + \PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{p}{:}\PY{p}{)} + \PY{n}{L}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{/}\PY{n}{A}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 2 -1 0 + -1 2 -1 + 0 -1 1 + +U = + + 2.00000 -1.00000 0.00000 + 0.00000 1.50000 -1.00000 + 0.00000 -1.00000 1.00000 + +L = + + 1.00000 0.00000 0.00000 + -0.50000 1.00000 0.00000 + 0.00000 0.00000 1.00000 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}57}]:} \PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)} + \PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{p}{:}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{p}{:}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +L = + + 1.00000 0.00000 0.00000 + -0.50000 1.00000 0.00000 + 0.00000 -0.66667 1.00000 + +U = + + 2.00000 -1.00000 0.00000 + 0.00000 1.50000 -1.00000 + 0.00000 0.00000 0.33333 + + + \end{Verbatim} + + Now solve for \(d_1\) then \(a_1\), \(d_2\) then \(a_2\), and \(d_3\) +then \(a_{3}\) + +\(Ld_{1}=\left[\begin{array}{c} 1 \\ 0 \\ \vdots \\ 0 \end{array} \right]= \left[\begin{array}{ccc} 1 & 0 & 0 \\ -1/2 & 1 & 0 \\ 0 & -2/3 & 1 \end{array} \right]\left[\begin{array}{c} d1(1) \\ d1(2) \\ d1(3)\end{array} \right]=\left[\begin{array}{c} 1 \\ 0 \\ 0 \end{array} \right] ;~Ua_{1}=d_{1}\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}58}]:} \PY{n}{d1}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} + \PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +d1 = + + 1.00000 + 0.50000 + 0.33333 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}59}]:} \PY{n}{a1}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{;} + \PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)}\PY{p}{;} + \PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d1}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a1}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +a1 = + + 1.00000 + 1.00000 + 1.00000 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}60}]:} \PY{n}{d2}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{p}{;} + \PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +d2 = + + 0.00000 + 1.00000 + 0.66667 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}61}]:} \PY{n}{a2}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{;} + \PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)}\PY{p}{;} + \PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d2}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a2}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +a2 = + + 1.0000 + 2.0000 + 2.0000 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}62}]:} \PY{n}{d3}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{p}{;} + \PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{0}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{L}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +d3 = + + 0 + 0 + 1 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}63}]:} \PY{n}{a3}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{;} + \PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)}\PY{p}{;} + \PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{l+m+mi}{1}\PY{o}{/}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{*}\PY{p}{(}\PY{n}{d3}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{*}\PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{)}\PY{o}{\PYZhy{}}\PY{n}{U}\PY{p}{(}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{o}{*}\PY{n}{a3}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +a3 = + + 1.00000 + 2.00000 + 3.00000 + + + \end{Verbatim} + + Final solution for \(A^{-1}\) is \([a_{1}~a_{2}~a_{3}]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}69}]:} \PY{n}{invA}\PY{p}{=}\PY{p}{[}\PY{n}{a1}\PY{p}{,}\PY{n}{a2}\PY{p}{,}\PY{n}{a3}\PY{p}{]} + \PY{n}{I\PYZus{}app}\PY{p}{=}\PY{n}{A}\PY{o}{*}\PY{n}{invA} + \PY{n}{I\PYZus{}app}\PY{p}{(}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)} + \PY{n+nb}{eps} + + \PY{l+m+mi}{2}\PYZca{}\PY{o}{\PYZhy{}}\PY{l+m+mi}{8} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +invA = + + 1.00000 1.00000 1.00000 + 1.00000 2.00000 2.00000 + 1.00000 2.00000 3.00000 + +I\_app = + + 1.00000 0.00000 0.00000 + 0.00000 1.00000 -0.00000 + -0.00000 -0.00000 1.00000 + +ans = -4.4409e-16 +ans = 2.2204e-16 +ans = 0.0039062 + + \end{Verbatim} + + Now the solution of \(x\) to \(Ax=y\) is \(x=A^{-1}y\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}70}]:} \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{2}\PY{p}{;}\PY{l+m+mi}{3}\PY{p}{]} + \PY{n}{x}\PY{p}{=}\PY{n}{invA}\PY{o}{*}\PY{n}{y} + \PY{n}{xbs}\PY{p}{=}\PY{n}{A}\PY{o}{\PYZbs{}}\PY{n}{y} + \PY{n}{x}\PY{o}{\PYZhy{}}\PY{n}{xbs} + \PY{n+nb}{eps} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +y = + + 1 + 2 + 3 + +x = + + 6.0000 + 11.0000 + 14.0000 + +xbs = + + 6.0000 + 11.0000 + 14.0000 + +ans = + + -3.5527e-15 + -8.8818e-15 + -1.0658e-14 + +ans = 2.2204e-16 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}71}]:} \PY{n}{N}\PY{p}{=}\PY{l+m+mi}{100}\PY{p}{;} + \PY{n}{n}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{:}\PY{n}{N}\PY{p}{]}\PY{p}{;} + \PY{n}{t\PYZus{}inv}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{n}{N}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}bs}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{n}{N}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}mult}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{n}{N}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{k}{for} \PY{n}{i}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{:}\PY{n}{N} + \PY{n}{A}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{n}{i}\PY{p}{,}\PY{n}{i}\PY{p}{)}\PY{p}{;} + \PY{n+nb}{tic} + \PY{n}{invA}\PY{p}{=}\PY{n+nb}{inv}\PY{p}{(}\PY{n}{A}\PY{p}{)}\PY{p}{;} + \PY{n}{t\PYZus{}inv}\PY{p}{(}\PY{n}{i}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{n}{b}\PY{p}{=}\PY{n+nb}{rand}\PY{p}{(}\PY{n}{i}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} + \PY{n}{x}\PY{p}{=}\PY{n}{A}\PY{o}{\PYZbs{}}\PY{n}{b}\PY{p}{;} + \PY{n}{t\PYZus{}bs}\PY{p}{(}\PY{n}{i}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{n+nb}{tic}\PY{p}{;} + \PY{n}{x}\PY{p}{=}\PY{n}{invA}\PY{o}{*}\PY{n}{b}\PY{p}{;} + \PY{n}{t\PYZus{}mult}\PY{p}{(}\PY{n}{i}\PY{p}{)}\PY{p}{=}\PY{n+nb}{toc}\PY{p}{;} + \PY{k}{end} + \PY{n+nb}{plot}\PY{p}{(}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}inv}\PY{p}{,}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}bs}\PY{p}{,}\PY{n}{n}\PY{p}{,}\PY{n}{t\PYZus{}mult}\PY{p}{)} + \PY{n+nb}{axis}\PY{p}{(}\PY{p}{[}\PY{l+m+mi}{0} \PY{l+m+mi}{100} \PY{l+m+mi}{0} \PY{l+m+mf}{0.002}\PY{p}{]}\PY{p}{)} + \PY{n+nb}{legend}\PY{p}{(}\PY{l+s}{\PYZsq{}}\PY{l+s}{inversion\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{backslash\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{multiplication\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{Location\PYZsq{}}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{NorthWest\PYZsq{}}\PY{p}{)} +\end{Verbatim} + + \begin{center} + \adjustimage{max size={0.9\linewidth}{0.9\paperheight}}{lecture_12_files/lecture_12_24_0.pdf} + \end{center} + { \hspace*{\fill} \\} + + \subsection{Condition of a matrix}\label{condition-of-a-matrix} + +\subsubsection{\texorpdfstring{\emph{just checked in to see what +condition my condition was +in}}{just checked in to see what condition my condition was in}}\label{just-checked-in-to-see-what-condition-my-condition-was-in} + +\subsubsection{Matrix norms}\label{matrix-norms} + +The Euclidean norm of a vector is measure of the magnitude (in 3D this +would be: \(|x|=\sqrt{x_{1}^{2}+x_{2}^{2}+x_{3}^{2}}\)) in general the +equation is: + +\(||x||_{e}=\sqrt{\sum_{i=1}^{n}x_{i}^{2}}\) + +For a matrix, A, the same norm is called the Frobenius norm: + +\(||A||_{f}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{2}}\) + +In general we can calculate any \(p\)-norm where + +\(||A||_{p}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{p}}\) + +so the p=1, 1-norm is + +\(||A||_{1}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{1}}=\sum_{i=1}^{n}\sum_{i=1}^{m}|A_{i,j}|\) + +\(||A||_{\infty}=\sqrt{\sum_{i=1}^{n}\sum_{i=1}^{m}A_{i,j}^{\infty}}=\max_{1\le i \le n}\sum_{j=1}^{m}|A_{i,j}|\) + +\subsubsection{Condition of Matrix}\label{condition-of-matrix} + +The matrix condition is the product of + +\(Cond(A) = ||A||\cdot||A^{-1}||\) + +So each norm will have a different condition number, but the limit is +\(Cond(A)\ge 1\) + +An estimate of the rounding error is based on the condition of A: + +\(\frac{||\Delta x||}{x} \le Cond(A) \frac{||\Delta A||}{||A||}\) + +So if the coefficients of A have accuracy to \$10\^{}\{-t\} + +and the condition of A, \(Cond(A)=10^{c}\) + +then the solution for x can have rounding errors up to \(10^{c-t}\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}72}]:} \PY{n}{A}\PY{p}{=}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{3}\PY{p}{;}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{2}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{4}\PY{p}{;}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{4}\PY{p}{,}\PY{l+m+mi}{1}\PY{o}{/}\PY{l+m+mi}{5}\PY{p}{]} + \PY{p}{[}\PY{n}{L}\PY{p}{,}\PY{n}{U}\PY{p}{]}\PY{p}{=}\PY{n}{LU\PYZus{}naive}\PY{p}{(}\PY{n}{A}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +A = + + 1.00000 0.50000 0.33333 + 0.50000 0.33333 0.25000 + 0.33333 0.25000 0.20000 + +L = + + 1.00000 0.00000 0.00000 + 0.50000 1.00000 0.00000 + 0.33333 1.00000 1.00000 + +U = + + 1.00000 0.50000 0.33333 + 0.00000 0.08333 0.08333 + 0.00000 -0.00000 0.00556 + + + \end{Verbatim} + + Then, \(A^{-1}=(LU)^{-1}=U^{-1}L^{-1}\) + +\(Ld_{1}=\left[\begin{array}{c} 1 \\ 0 \\ 0 \end{array}\right]\), +\(Ux_{1}=d_{1}\) ... + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}75}]:} \PY{n}{invA}\PY{p}{=}\PY{n+nb}{zeros}\PY{p}{(}\PY{l+m+mi}{3}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{;} + \PY{n}{d1}\PY{p}{=}\PY{n}{L}\PY{o}{\PYZbs{}}\PY{p}{[}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{]}\PY{p}{;} + \PY{n}{d2}\PY{p}{=}\PY{n}{L}\PY{o}{\PYZbs{}}\PY{p}{[}\PY{l+m+mi}{0}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{]}\PY{p}{;} + \PY{n}{d3}\PY{p}{=}\PY{n}{L}\PY{o}{\PYZbs{}}\PY{p}{[}\PY{l+m+mi}{0}\PY{p}{;}\PY{l+m+mi}{0}\PY{p}{;}\PY{l+m+mi}{1}\PY{p}{]}\PY{p}{;} + \PY{n}{invA}\PY{p}{(}\PY{p}{:}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{o}{\PYZbs{}}\PY{n}{d1}\PY{p}{;} + \PY{n}{invA}\PY{p}{(}\PY{p}{:}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{o}{\PYZbs{}}\PY{n}{d2}\PY{p}{;} + \PY{n}{invA}\PY{p}{(}\PY{p}{:}\PY{p}{,}\PY{l+m+mi}{3}\PY{p}{)}\PY{p}{=}\PY{n}{U}\PY{o}{\PYZbs{}}\PY{n}{d3} + \PY{n}{invA}\PY{o}{*}\PY{n}{A} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +invA = + + 9.0000 -36.0000 30.0000 + -36.0000 192.0000 -180.0000 + 30.0000 -180.0000 180.0000 + +ans = + + 1.0000e+00 3.5527e-15 2.9976e-15 + -1.3249e-14 1.0000e+00 -9.1038e-15 + 8.5117e-15 7.1054e-15 1.0000e+00 + + + \end{Verbatim} + + Find the condition of A, \(cond(A)\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}74}]:} \PY{c}{\PYZpc{} Frobenius norm} + \PY{n}{normf\PYZus{}A} \PY{p}{=} \PY{n+nb}{sqrt}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{A}\PY{o}{.\PYZca{}}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{)}\PY{p}{)} + \PY{n}{normf\PYZus{}invA} \PY{p}{=} \PY{n+nb}{sqrt}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{invA}\PY{o}{.\PYZca{}}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{)}\PY{p}{)} + + \PY{n}{cond\PYZus{}f\PYZus{}A} \PY{p}{=} \PY{n}{normf\PYZus{}A}\PY{o}{*}\PY{n}{normf\PYZus{}invA} + + \PY{n+nb}{norm}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{fro\PYZsq{}}\PY{p}{)} + + \PY{c}{\PYZpc{} p=1, column sum norm} + \PY{n}{norm1\PYZus{}A} \PY{p}{=} \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{)} + \PY{n}{norm1\PYZus{}invA} \PY{p}{=} \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{invA}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)}\PY{p}{)} + \PY{n+nb}{norm}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)} + + \PY{n}{cond\PYZus{}1\PYZus{}A}\PY{p}{=}\PY{n}{norm1\PYZus{}A}\PY{o}{*}\PY{n}{norm1\PYZus{}invA} + + \PY{c}{\PYZpc{} p=inf, row sum norm} + \PY{n}{norminf\PYZus{}A} \PY{p}{=} \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{)} + \PY{n}{norminf\PYZus{}invA} \PY{p}{=} \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{sum}\PY{p}{(}\PY{n}{invA}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)}\PY{p}{)} + \PY{n+nb}{norm}\PY{p}{(}\PY{n}{A}\PY{p}{,}\PY{n+nb}{inf}\PY{p}{)} + + \PY{n}{cond\PYZus{}inf\PYZus{}A}\PY{p}{=}\PY{n}{norminf\PYZus{}A}\PY{o}{*}\PY{n}{norminf\PYZus{}invA} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +normf\_A = 1.4136 +normf\_invA = 372.21 +cond\_f\_A = 526.16 +ans = 1.4136 +norm1\_A = 1.8333 +norm1\_invA = 30.000 +ans = 1.8333 +cond\_1\_A = 55.000 +norminf\_A = 1.8333 +norminf\_invA = 30.000 +ans = 1.8333 +cond\_inf\_A = 55.000 + + \end{Verbatim} + + Consider the problem again from the intro to Linear Algebra, 4 masses +are connected in series to 4 springs with spring constants \(K_{i}\). +What does a high condition number mean for this problem? + +\begin{figure}[htbp] +\centering +\includegraphics{../lecture_09/mass_springs.png} +\caption{Springs-masses} +\end{figure} + +The masses haves the following amounts, 1, 2, 3, and 4 kg for masses +1-4. Using a FBD for each mass: + +\(m_{1}g+k_{2}(x_{2}-x_{1})-k_{1}x_{1}=0\) + +\(m_{2}g+k_{3}(x_{3}-x_{2})-k_{2}(x_{2}-x_{1})=0\) + +\(m_{3}g+k_{4}(x_{4}-x_{3})-k_{3}(x_{3}-x_{2})=0\) + +\(m_{4}g-k_{4}(x_{4}-x_{3})=0\) + +in matrix form: + +\(\left[ \begin{array}{cccc} k_{1}+k_{2} & -k_{2} & 0 & 0 \\ -k_{2} & k_{2}+k_{3} & -k_{3} & 0 \\ 0 & -k_{3} & k_{3}+k_{4} & -k_{4} \\ 0 & 0 & -k_{4} & k_{4} \end{array} \right] \left[ \begin{array}{c} x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \end{array} \right]= \left[ \begin{array}{c} m_{1}g \\ m_{2}g \\ m_{3}g \\ m_{4}g \end{array} \right]\) + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}21}]:} \PY{n}{k1}\PY{p}{=}\PY{l+m+mi}{10}\PY{p}{;} \PY{c}{\PYZpc{} N/m} + \PY{n}{k2}\PY{p}{=}\PY{l+m+mi}{100000}\PY{p}{;} + \PY{n}{k3}\PY{p}{=}\PY{l+m+mi}{10}\PY{p}{;} + \PY{n}{k4}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} + \PY{n}{m1}\PY{p}{=}\PY{l+m+mi}{1}\PY{p}{;} \PY{c}{\PYZpc{} kg} + \PY{n}{m2}\PY{p}{=}\PY{l+m+mi}{2}\PY{p}{;} + \PY{n}{m3}\PY{p}{=}\PY{l+m+mi}{3}\PY{p}{;} + \PY{n}{m4}\PY{p}{=}\PY{l+m+mi}{4}\PY{p}{;} + \PY{n}{g}\PY{p}{=}\PY{l+m+mf}{9.81}\PY{p}{;} \PY{c}{\PYZpc{} m/s\PYZca{}2} + \PY{n}{K}\PY{p}{=}\PY{p}{[}\PY{n}{k1}\PY{o}{+}\PY{n}{k2} \PY{o}{\PYZhy{}}\PY{n}{k2} \PY{l+m+mi}{0} \PY{l+m+mi}{0}\PY{p}{;} \PY{o}{\PYZhy{}}\PY{n}{k2} \PY{n}{k2}\PY{o}{+}\PY{n}{k3} \PY{o}{\PYZhy{}}\PY{n}{k3} \PY{l+m+mi}{0}\PY{p}{;} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k3} \PY{n}{k3}\PY{o}{+}\PY{n}{k4} \PY{o}{\PYZhy{}}\PY{n}{k4}\PY{p}{;} \PY{l+m+mi}{0} \PY{l+m+mi}{0} \PY{o}{\PYZhy{}}\PY{n}{k4} \PY{n}{k4}\PY{p}{]} + \PY{n}{y}\PY{p}{=}\PY{p}{[}\PY{n}{m1}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m2}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m3}\PY{o}{*}\PY{n}{g}\PY{p}{;}\PY{n}{m4}\PY{o}{*}\PY{n}{g}\PY{p}{]} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +K = + + 100010 -100000 0 0 + -100000 100010 -10 0 + 0 -10 11 -1 + 0 0 -1 1 + +y = + + 9.8100 + 19.6200 + 29.4300 + 39.2400 + + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}25}]:} \PY{n+nb}{cond}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{n+nb}{inf}\PY{p}{)} + \PY{n+nb}{cond}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{l+m+mi}{1}\PY{p}{)} + \PY{n+nb}{cond}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{l+s}{\PYZsq{}}\PY{l+s}{fro\PYZsq{}}\PY{p}{)} + \PY{n+nb}{cond}\PY{p}{(}\PY{n}{K}\PY{p}{,}\PY{l+m+mi}{2}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +ans = 3.2004e+05 +ans = 3.2004e+05 +ans = 2.5925e+05 +ans = 2.5293e+05 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor}26}]:} \PY{n+nb}{e}\PY{p}{=}\PY{n+nb}{eig}\PY{p}{(}\PY{n}{K}\PY{p}{)} + \PY{n+nb}{max}\PY{p}{(}\PY{n+nb}{e}\PY{p}{)}\PY{o}{/}\PY{n+nb}{min}\PY{p}{(}\PY{n+nb}{e}\PY{p}{)} +\end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +e = + + 7.9078e-01 + 3.5881e+00 + 1.7621e+01 + 2.0001e+05 + +ans = 2.5293e+05 + + \end{Verbatim} + + \begin{Verbatim}[commandchars=\\\{\}] +{\color{incolor}In [{\color{incolor} }]:} +\end{Verbatim} + + + % Add a bibliography block to the postdoc + + + + \end{document} diff --git a/lecture_12/lecture_12_files/lecture_12_21_0.pdf b/lecture_12/lecture_12_files/lecture_12_21_0.pdf new file mode 100644 index 0000000..6480131 Binary files /dev/null and b/lecture_12/lecture_12_files/lecture_12_21_0.pdf differ diff --git a/lecture_12/lecture_12_files/lecture_12_21_0.png b/lecture_12/lecture_12_files/lecture_12_21_0.png new file mode 100644 index 0000000..2633731 Binary files /dev/null and b/lecture_12/lecture_12_files/lecture_12_21_0.png differ diff --git a/lecture_12/lecture_12_files/lecture_12_21_0.svg b/lecture_12/lecture_12_files/lecture_12_21_0.svg new file mode 100644 index 0000000..44ef608 --- /dev/null +++ b/lecture_12/lecture_12_files/lecture_12_21_0.svg @@ -0,0 +1,148 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,390.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,298.2)"> + <text><tspan font-family="{}">0.0005</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,206.3)"> + <text><tspan font-family="{}">0.001</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,114.5)"> + <text><tspan font-family="{}">0.0015</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,22.7)"> + <text><tspan font-family="{}">0.002</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(70.5,408.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(163.4,408.0)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(256.3,408.0)"> + <text><tspan font-family="{}">40</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(349.2,408.0)"> + <text><tspan font-family="{}">60</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(442.1,408.0)"> + <text><tspan font-family="{}">80</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">100</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M78.8,169.7 L78.8,25.7 L311.8,25.7 L311.8,169.7 L78.8,169.7 Z " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>inversion</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,55.7)"> + <text><tspan font-family="{}">inversion</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,49.7 L143.8,49.7 M75.1,367.8 L79.8,374.3 L84.4,375.7 L89.1,375.5 L93.7,375.5 L98.4,375.2 L103.0,374.6 L107.7,374.5 L112.3,373.4 L117.0,372.8 L121.6,368.2 L126.2,372.4 L130.9,372.0 L135.5,371.5 L140.2,371.1 L144.8,369.7 L149.5,373.5 L154.1,250.8 L158.8,365.1 L163.4,364.9 L168.0,364.2 L172.7,362.5 L177.3,362.2 L182.0,361.1 L186.6,359.9 L191.3,360.1 L195.9,357.4 L200.6,358.3 L205.2,356.3 L209.9,362.5 L213.7,16.7 M215.3,16.7 L219.1,360.7 L223.8,360.5 L228.4,356.3 L233.1,354.6 L237.7,356.8 L242.4,354.4 L247.0,360.1 L251.7,359.6 L256.3,359.0 L260.9,358.5 L265.6,356.1 L270.2,356.5 L274.9,354.8 L279.5,354.1 L284.2,351.9 L288.8,351.3 L293.5,352.0 L298.1,350.0 L302.8,348.4 L307.4,348.0 L312.0,354.4 L316.7,351.5 L321.3,352.4 L326.0,351.3 L330.6,351.7 L335.3,346.3 L339.9,345.4 L344.6,347.3 L349.2,347.4 L353.8,345.2 L358.5,342.5 L363.1,344.3 L367.8,347.1 L372.4,338.9 L377.1,340.1 L381.7,340.1 L386.4,329.3 L391.0,337.0 L395.7,319.7 L400.3,338.6 L404.9,340.0 L409.6,336.3 L414.2,335.3 L418.9,333.7 L423.5,333.3 L428.2,330.2 L432.8,328.7 L437.5,332.8 L442.1,327.4 L446.7,325.6 L451.4,326.5 L456.0,325.2 L460.7,324.5 L465.3,320.3 L470.0,325.4 L474.6,319.4 L479.3,322.1 L483.9,319.7 L488.6,321.2 L493.2,315.7 L497.8,316.6 L502.5,299.5 L507.1,317.5 L511.8,310.4 L516.4,318.2 L521.1,314.0 L525.7,316.6 L530.4,311.8 L535.0,314.0 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>backslash</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,103.7)"> + <text><tspan font-family="{}">backslash</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,97.7 L143.8,97.7 M75.1,381.3 L79.8,377.7 L84.4,378.8 L89.1,378.7 L93.7,378.7 L98.4,377.2 L103.0,378.0 L107.7,378.0 L112.3,377.2 L117.0,376.6 L121.6,376.3 L126.2,376.1 L130.9,375.8 L135.5,375.9 L140.2,375.5 L144.8,377.6 L149.5,377.0 L154.1,370.4 L158.8,371.0 L163.4,371.0 L168.0,371.0 L172.7,369.3 L177.3,370.0 L182.0,369.3 L186.6,368.6 L191.3,368.0 L195.9,367.3 L200.6,366.6 L205.2,366.7 L209.9,370.3 L214.5,367.7 L219.1,369.5 L223.8,340.8 L228.4,367.3 L233.1,367.6 L237.7,367.1 L242.4,368.9 L247.0,369.3 L251.7,368.6 L256.3,368.8 L260.9,368.4 L265.6,367.7 L270.2,367.1 L274.9,365.3 L279.5,366.6 L284.2,364.2 L288.8,365.1 L293.5,365.6 L298.1,364.9 L302.8,363.1 L307.4,366.0 L312.0,366.2 L316.7,363.8 L321.3,365.6 L326.0,365.1 L330.6,365.3 L335.3,362.5 L339.9,362.3 L344.6,363.4 L349.2,363.1 L353.8,362.9 L358.5,364.0 L363.1,361.1 L367.8,363.8 L372.4,361.4 L377.1,352.7 L381.7,357.9 L386.4,359.7 L391.0,355.2 L395.7,358.3 L400.3,357.0 L404.9,358.5 L409.6,357.6 L414.2,356.8 L418.9,354.6 L423.5,355.1 L428.2,355.9 L432.8,353.1 L437.5,351.5 L442.1,351.9 L446.7,351.7 L451.4,351.1 L456.0,350.9 L460.7,350.5 L465.3,347.7 L470.0,350.4 L474.6,349.5 L479.3,349.3 L483.9,348.9 L488.6,348.4 L493.2,342.5 L497.8,346.5 L502.5,347.8 L507.1,347.8 L511.8,347.1 L516.4,347.6 L521.1,347.3 L525.7,346.2 L530.4,345.6 L535.0,346.0 " stroke="rgb( 0, 128, 0)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>multiplication</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,151.7)"> + <text><tspan font-family="{}">multiplication</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,145.7 L143.8,145.7 M75.1,382.0 L79.8,381.4 L84.4,381.8 L89.1,381.8 L93.7,381.8 L98.4,381.8 L103.0,381.8 L107.7,381.8 L112.3,381.8 L117.0,381.9 L121.6,381.8 L126.2,381.8 L130.9,382.0 L135.5,381.8 L140.2,381.8 L144.8,382.6 L149.5,382.3 L154.1,381.8 L158.8,381.8 L163.4,382.0 L168.0,381.8 L172.7,381.8 L177.3,381.8 L182.0,381.8 L186.6,381.8 L191.3,381.8 L195.9,381.6 L200.6,381.6 L205.2,381.8 L209.9,382.2 L214.5,381.9 L219.1,382.2 L223.8,382.0 L228.4,382.2 L233.1,382.2 L237.7,382.0 L242.4,382.6 L247.0,382.3 L251.7,382.6 L256.3,382.6 L260.9,382.4 L265.6,382.5 L270.2,382.5 L274.9,382.3 L279.5,382.3 L284.2,382.3 L288.8,382.5 L293.5,382.4 L298.1,382.3 L302.8,379.9 L307.4,382.7 L312.0,382.5 L316.7,382.5 L321.3,382.7 L326.0,382.7 L330.6,382.6 L335.3,382.6 L339.9,382.5 L344.6,382.6 L349.2,382.5 L353.8,382.6 L358.5,382.7 L363.1,382.6 L367.8,382.7 L372.4,382.5 L377.1,382.6 L381.7,382.5 L386.4,382.5 L391.0,382.6 L395.7,382.5 L400.3,382.5 L404.9,382.5 L409.6,382.6 L414.2,382.5 L418.9,382.5 L423.5,382.6 L428.2,382.6 L432.8,382.6 L437.5,382.3 L442.1,382.5 L446.7,382.6 L451.4,382.5 L456.0,382.5 L460.7,382.5 L465.3,382.4 L470.0,382.3 L474.6,382.3 L479.3,382.6 L483.9,382.4 L488.6,382.3 L493.2,382.3 L497.8,382.6 L502.5,382.6 L507.1,382.3 L511.8,382.3 L516.4,382.3 L521.1,382.6 L525.7,382.3 L530.4,382.3 L535.0,382.4 " stroke="rgb(255, 0, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb(255, 0, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_12/lecture_12_files/lecture_12_24_0.pdf b/lecture_12/lecture_12_files/lecture_12_24_0.pdf new file mode 100644 index 0000000..e2d1d9b Binary files /dev/null and b/lecture_12/lecture_12_files/lecture_12_24_0.pdf differ diff --git a/lecture_12/lecture_12_files/lecture_12_24_0.png b/lecture_12/lecture_12_files/lecture_12_24_0.png new file mode 100644 index 0000000..c8959a7 Binary files /dev/null and b/lecture_12/lecture_12_files/lecture_12_24_0.png differ diff --git a/lecture_12/lecture_12_files/lecture_12_24_0.svg b/lecture_12/lecture_12_files/lecture_12_24_0.svg new file mode 100644 index 0000000..4705883 --- /dev/null +++ b/lecture_12/lecture_12_files/lecture_12_24_0.svg @@ -0,0 +1,148 @@ +<svg height="420px" viewBox="0 0 560 420" width="560px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + +<title>Gnuplot</title> +<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc> + +<g id="gnuplot_canvas"> + +<rect fill="none" height="420" width="560" x="0" y="0"/> +<defs> + + <circle id="gpDot" r="0.5" stroke-width="0.5"/> + <path d="M-1,0 h2 M0,-1 v2" id="gpPt0" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,-1 L1,1 M1,-1 L-1,1" id="gpPt1" stroke="currentColor" stroke-width="0.222"/> + <path d="M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1" id="gpPt2" stroke="currentColor" stroke-width="0.222"/> + <rect height="2" id="gpPt3" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <rect fill="currentColor" height="2" id="gpPt4" stroke="currentColor" stroke-width="0.222" width="2" x="-1" y="-1"/> + <circle cx="0" cy="0" id="gpPt5" r="1" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt6" stroke="none" xlink:href="#gpPt5"/> + <path d="M0,-1.33 L-1.33,0.67 L1.33,0.67 z" id="gpPt7" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt8" stroke="none" xlink:href="#gpPt7"/> + <use id="gpPt9" stroke="currentColor" transform="rotate(180)" xlink:href="#gpPt7"/> + <use fill="currentColor" id="gpPt10" stroke="none" xlink:href="#gpPt9"/> + <use id="gpPt11" stroke="currentColor" transform="rotate(45)" xlink:href="#gpPt3"/> + <use fill="currentColor" id="gpPt12" stroke="none" xlink:href="#gpPt11"/> + <path d="M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z" id="gpPt13" stroke="currentColor" stroke-width="0.222"/> + <use fill="currentColor" id="gpPt14" stroke="none" xlink:href="#gpPt13"/> + <filter filterUnits="objectBoundingBox" height="1" id="textbox" width="1" x="0" y="0"> + <feFlood flood-color="white" flood-opacity="1" result="bgnd"/> + <feComposite in="SourceGraphic" in2="bgnd" operator="atop"/> + </filter> + <filter filterUnits="objectBoundingBox" height="1" id="greybox" width="1" x="0" y="0"> + <feFlood flood-color="lightgrey" flood-opacity="1" result="grey"/> + <feComposite in="SourceGraphic" in2="grey" operator="atop"/> + </filter> +</defs> +<g color="white" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <g shape-rendering="crispEdges" stroke="none"> + <polygon fill="rgb(255, 255, 255)" points="70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 "/> + </g> +</g> +<g color="black" fill="none" stroke="rgb(255, 255, 255)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,390.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,298.2)"> + <text><tspan font-family="{}">0.0005</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,206.3)"> + <text><tspan font-family="{}">0.001</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,114.5)"> + <text><tspan font-family="{}">0.0015</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(62.2,22.7)"> + <text><tspan font-family="{}">0.002</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(70.5,408.0)"> + <text><tspan font-family="{}">0</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(163.4,408.0)"> + <text><tspan font-family="{}">20</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(256.3,408.0)"> + <text><tspan font-family="{}">40</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(349.2,408.0)"> + <text><tspan font-family="{}">60</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(442.1,408.0)"> + <text><tspan font-family="{}">80</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 " stroke="black"/> <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="middle" transform="translate(535.0,408.0)"> + <text><tspan font-family="{}">100</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> + <path d="M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z " stroke="black"/></g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="1.00"> + <path d="M78.8,169.7 L78.8,25.7 L311.8,25.7 L311.8,169.7 L78.8,169.7 Z " stroke="black"/></g> + <g id="gnuplot_plot_1a"><title>inversion</title> +<g color="white" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,55.7)"> + <text><tspan font-family="{}">inversion</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,49.7 L143.8,49.7 M75.1,359.6 L79.8,366.2 L84.4,364.9 L89.1,365.8 L93.7,366.6 L98.4,366.2 L103.0,365.3 L107.7,365.3 L112.3,363.8 L117.0,363.2 L121.6,360.0 L126.2,347.8 L130.9,358.3 L135.5,362.7 L140.2,362.4 L144.8,361.4 L149.5,360.1 L154.1,323.0 L158.8,341.7 L163.4,341.7 L168.0,332.4 L172.7,338.1 L177.3,335.4 L182.0,342.0 L186.6,364.3 L191.3,371.9 L195.9,370.8 L200.6,371.3 L205.2,371.2 L209.9,370.2 L214.5,368.8 L219.1,369.7 L223.8,368.4 L228.4,364.2 L233.1,366.7 L237.7,366.9 L242.4,364.7 L247.0,365.3 L251.7,364.0 L256.3,364.6 L260.9,363.4 L265.6,362.2 L270.2,361.6 L274.9,361.6 L279.5,360.3 L284.2,358.3 L288.8,358.7 L293.5,359.0 L298.1,357.3 L302.8,354.8 L307.4,355.2 L312.0,355.4 L316.7,353.9 L321.3,353.1 L326.0,351.9 L330.6,352.8 L335.3,349.5 L339.9,350.0 L344.6,348.2 L349.2,349.1 L353.8,345.0 L358.5,346.2 L363.1,344.9 L367.8,346.9 L372.4,337.9 L377.1,341.0 L381.7,342.9 L386.4,341.2 L391.0,339.7 L395.7,339.0 L400.3,338.1 L404.9,337.3 L409.6,336.8 L414.2,336.3 L418.9,334.4 L423.5,330.6 L428.2,330.4 L432.8,332.9 L437.5,329.8 L442.1,330.6 L446.7,327.8 L451.4,326.2 L456.0,323.9 L460.7,323.0 L465.3,322.7 L470.0,321.2 L474.6,320.8 L479.3,312.8 L483.9,317.3 L488.6,317.1 L493.2,317.3 L497.8,315.7 L502.5,316.6 L507.1,315.7 L511.8,307.6 L516.4,315.5 L521.1,314.6 L525.7,311.8 L530.4,308.5 L535.0,310.2 " stroke="rgb( 0, 0, 255)"/></g> + </g> + <g id="gnuplot_plot_2a"><title>backslash</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,103.7)"> + <text><tspan font-family="{}">backslash</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,97.7 L143.8,97.7 M75.1,379.4 L79.8,372.8 L84.4,373.9 L89.1,368.0 L93.7,373.0 L98.4,373.0 L103.0,372.1 L107.7,372.1 L112.3,371.2 L117.0,370.6 L121.6,367.8 L126.2,366.0 L130.9,366.7 L135.5,369.9 L140.2,369.9 L144.8,369.3 L149.5,368.5 L154.1,354.8 L158.8,355.7 L163.4,355.4 L168.0,350.5 L172.7,354.1 L177.3,349.7 L182.0,334.4 L186.6,376.5 L191.3,376.1 L195.9,375.5 L200.6,375.8 L205.2,375.9 L209.9,375.0 L214.5,374.8 L219.1,374.6 L223.8,374.1 L228.4,370.8 L233.1,373.0 L237.7,373.0 L242.4,371.3 L247.0,371.9 L251.7,371.5 L256.3,371.7 L260.9,371.5 L265.6,370.6 L270.2,370.2 L274.9,369.9 L279.5,369.5 L284.2,369.1 L288.8,368.8 L293.5,368.7 L298.1,368.2 L302.8,367.5 L307.4,367.1 L312.0,366.9 L316.7,366.4 L321.3,366.0 L326.0,365.6 L330.6,365.8 L335.3,364.9 L339.9,364.5 L344.6,363.8 L349.2,363.8 L353.8,361.0 L358.5,362.9 L363.1,360.5 L367.8,363.2 L372.4,361.9 L377.1,357.7 L381.7,360.0 L386.4,359.6 L391.0,358.9 L395.7,358.6 L400.3,357.7 L404.9,356.1 L409.6,357.4 L414.2,356.8 L418.9,356.3 L423.5,357.7 L428.2,353.1 L432.8,355.2 L437.5,354.2 L442.1,352.8 L446.7,351.7 L451.4,350.8 L456.0,350.2 L460.7,350.6 L465.3,348.7 L470.0,348.7 L474.6,348.0 L479.3,343.4 L483.9,347.4 L488.6,345.2 L493.2,347.3 L497.8,347.8 L502.5,346.7 L507.1,346.2 L511.8,338.6 L516.4,347.8 L521.1,346.4 L525.7,344.3 L530.4,345.6 L535.0,347.1 " stroke="rgb( 0, 128, 0)"/></g> + </g> + <g id="gnuplot_plot_3a"><title>multiplication</title> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <g fill="rgb(0,0,0)" font-family="{}" font-size="16.00" stroke="none" text-anchor="end" transform="translate(311.8,151.7)"> + <text><tspan font-family="{}">multiplication</tspan></text> + </g> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="3.00"> + <path d="M90.0,145.7 L143.8,145.7 M75.1,380.5 L79.8,379.4 L84.4,379.6 L89.1,379.8 L93.7,379.6 L98.4,379.8 L103.0,379.8 L107.7,379.8 L112.3,379.8 L117.0,379.8 L121.6,378.1 L126.2,379.4 L130.9,380.1 L135.5,380.3 L140.2,380.3 L144.8,380.3 L149.5,380.3 L154.1,378.9 L158.8,378.8 L163.4,378.9 L168.0,378.7 L172.7,378.5 L177.3,379.6 L182.0,379.4 L186.6,382.7 L191.3,382.7 L195.9,382.7 L200.6,382.7 L205.2,382.7 L209.9,382.7 L214.5,382.9 L219.1,382.9 L223.8,382.9 L228.4,382.7 L233.1,382.7 L237.7,382.7 L242.4,382.7 L247.0,382.9 L251.7,382.7 L256.3,382.7 L260.9,382.6 L265.6,382.7 L270.2,382.7 L274.9,382.7 L279.5,382.7 L284.2,382.7 L288.8,382.5 L293.5,382.7 L298.1,382.7 L302.8,382.6 L307.4,382.5 L312.0,382.5 L316.7,382.5 L321.3,382.7 L326.0,382.7 L330.6,382.7 L335.3,382.6 L339.9,382.7 L344.6,382.7 L349.2,382.6 L353.8,382.7 L358.5,382.6 L363.1,382.7 L367.8,382.5 L372.4,382.5 L377.1,382.7 L381.7,382.5 L386.4,382.7 L391.0,382.5 L395.7,382.5 L400.3,382.6 L404.9,382.7 L409.6,382.6 L414.2,382.5 L418.9,382.6 L423.5,382.5 L428.2,382.5 L432.8,382.4 L437.5,382.5 L442.1,382.6 L446.7,382.6 L451.4,382.5 L456.0,382.4 L460.7,382.3 L465.3,382.5 L470.0,382.3 L474.6,382.6 L479.3,382.3 L483.9,382.4 L488.6,382.3 L493.2,382.3 L497.8,382.5 L502.5,382.3 L507.1,382.6 L511.8,382.4 L516.4,379.8 L521.1,382.3 L525.7,382.3 L530.4,382.5 L535.0,382.5 " stroke="rgb(255, 0, 0)"/></g> + </g> +<g color="white" fill="none" stroke="rgb(255, 0, 0)" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="2.00"> +</g> +<g color="black" fill="none" stroke="black" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +<g color="black" fill="none" stroke="currentColor" stroke-linecap="butt" stroke-linejoin="miter" stroke-width="0.50"> +</g> +</g> +</svg> \ No newline at end of file diff --git a/lecture_12/nohup.out b/lecture_12/nohup.out new file mode 100644 index 0000000..f0d30e1 --- /dev/null +++ b/lecture_12/nohup.out @@ -0,0 +1,2 @@ + +(evince:8926): Gtk-WARNING **: gtk_widget_size_allocate(): attempt to allocate widget with width -71 and height 20 diff --git a/lecture_12/octave-workspace b/lecture_12/octave-workspace new file mode 100644 index 0000000..41ef164 Binary files /dev/null and b/lecture_12/octave-workspace differ diff --git a/lecture_13/.ipynb_checkpoints/lecture_12-checkpoint.ipynb b/lecture_13/.ipynb_checkpoints/lecture_12-checkpoint.ipynb new file mode 100644 index 0000000..6a5dc68 --- /dev/null +++ b/lecture_13/.ipynb_checkpoints/lecture_12-checkpoint.ipynb @@ -0,0 +1,737 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "%plot --format svg" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [ + "setdefaults" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## My question from last class \n", + "\n", + "\n", + "## Your questions from last class\n", + "\n", + "1. Need more linear algebra review\n", + " \n", + " -We will keep doing Linear Algebra, try the practice problems in 'linear_algebra'\n", + "\n", + "2. How do I do HW3? \n", + " \n", + " -demo today\n", + "\n", + "3. For hw4 is the spring constant (K) suppose to be given? \n", + " \n", + " -yes, its 30 N/m\n", + " \n", + "4. Deapool or Joker?" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# LU Decomposition\n", + "### efficient storage of matrices for solutions\n", + "\n", + "Considering the same solution set:\n", + "\n", + "$y=Ax$\n", + "\n", + "Assume that we can perform Gauss elimination and achieve this formula:\n", + "\n", + "$Ux=d$ \n", + "\n", + "Where, $U$ is an upper triangular matrix that we derived from Gauss elimination and $d$ is the set of dependent variables after Gauss elimination. \n", + "\n", + "Assume there is a lower triangular matrix, $L$, with ones on the diagonal and same dimensions of $U$ and the following is true:\n", + "\n", + "$L(Ux-d)=Ax-y=0$\n", + "\n", + "Now, $Ax=LUx$, so $A=LU$, and $y=Ld$.\n", + "\n", + "$2x_{1}+x_{2}=1$\n", + "\n", + "$x_{1}+3x_{2}=1$\n", + "\n", + "\n", + "$\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "1 & 3 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]=\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "1\\end{array}\\right]$\n", + "\n", + "f21=0.5\n", + "\n", + "A(2,1)=1-1 = 0 \n", + "\n", + "A(2,2)=3-0.5=2.5\n", + "\n", + "y(2)=1-0.5=0.5\n", + "\n", + "$L(Ux-d)=\n", + "\\left[ \\begin{array}{cc}\n", + "1 & 0 \\\\\n", + "0.5 & 1 \\end{array} \\right]\n", + "\\left(\\left[ \\begin{array}{cc}\n", + "2 & 1 \\\\\n", + "0 & 2.5 \\end{array} \\right]\n", + "\\left[\\begin{array}{c} \n", + "x_{1} \\\\ \n", + "x_{2} \\end{array}\\right]-\n", + "\\left[\\begin{array}{c} \n", + "1 \\\\\n", + "0.5\\end{array}\\right]\\right)=0$\n" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "A =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "L =\n", + "\n", + " 1.00000 0.00000\n", + " 0.50000 1.00000\n", + "\n", + "U =\n", + "\n", + " 2.00000 1.00000\n", + " 0.00000 2.50000\n", + "\n", + "ans =\n", + "\n", + " 2 1\n", + " 1 3\n", + "\n", + "d =\n", + "\n", + " 1.00000\n", + " 0.50000\n", + "\n", + "y =\n", + "\n", + " 1\n", + " 1\n", + "\n" + ] + } + ], + "source": [ + "A=[2,1;1,3]\n", + "L=[1,0;0.5,1]\n", + "U=[2,1;0,2.5]\n", + "L*U\n", + "\n", + "d=[1;0.5]\n", + "y=L*d" + ] + }, + { + "cell_type": "code", + "execution_count": 5, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans = 5.0000\n", + "ans = 1\n", + "ans = 5\n", + "ans = 5\n", + "ans = 5.0000\n" + ] + } + ], + "source": [ + "% what is the determinant of L, U and A?\n", + "\n", + "det(A)\n", + "det(L)\n", + "det(U)\n", + "det(L)*det(U)\n", + "det(L*U)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Pivoting for LU factorization\n", + "\n", + "LU factorization uses the same method as Gauss elimination so it is also necessary to perform partial pivoting when creating the lower and upper triangular matrices. \n", + "\n", + "Matlab and Octave use pivoting in the command \n", + "\n", + "`[L,U,P]=lu(A)`\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "'lu' is a built-in function from the file libinterp/corefcn/lu.cc\n", + "\n", + " -- Built-in Function: [L, U] = lu (A)\n", + " -- Built-in Function: [L, U, P] = lu (A)\n", + " -- Built-in Function: [L, U, P, Q] = lu (S)\n", + " -- Built-in Function: [L, U, P, Q, R] = lu (S)\n", + " -- Built-in Function: [...] = lu (S, THRES)\n", + " -- Built-in Function: Y = lu (...)\n", + " -- Built-in Function: [...] = lu (..., \"vector\")\n", + " Compute the LU decomposition of A.\n", + "\n", + " If A is full subroutines from LAPACK are used and if A is sparse\n", + " then UMFPACK is used.\n", + "\n", + " The result is returned in a permuted form, according to the\n", + " optional return value P. For example, given the matrix 'a = [1, 2;\n", + " 3, 4]',\n", + "\n", + " [l, u, p] = lu (A)\n", + "\n", + " returns\n", + "\n", + " l =\n", + "\n", + " 1.00000 0.00000\n", + " 0.33333 1.00000\n", + "\n", + " u =\n", + "\n", + " 3.00000 4.00000\n", + " 0.00000 0.66667\n", + "\n", + " p =\n", + "\n", + " 0 1\n", + " 1 0\n", + "\n", + " The matrix is not required to be square.\n", + "\n", + " When called with two or three output arguments and a spare input\n", + " matrix, 'lu' does not attempt to perform sparsity preserving column\n", + " permutations. Called with a fourth output argument, the sparsity\n", + " preserving column transformation Q is returned, such that 'P * A *\n", + " Q = L * U'.\n", + "\n", + " Called with a fifth output argument and a sparse input matrix, 'lu'\n", + " attempts to use a scaling factor R on the input matrix such that 'P\n", + " * (R \\ A) * Q = L * U'. This typically leads to a sparser and more\n", + " stable factorization.\n", + "\n", + " An additional input argument THRES, that defines the pivoting\n", + " threshold can be given. THRES can be a scalar, in which case it\n", + " defines the UMFPACK pivoting tolerance for both symmetric and\n", + " unsymmetric cases. If THRES is a 2-element vector, then the first\n", + " element defines the pivoting tolerance for the unsymmetric UMFPACK\n", + " pivoting strategy and the second for the symmetric strategy. By\n", + " default, the values defined by 'spparms' are used ([0.1, 0.001]).\n", + "\n", + " Given the string argument \"vector\", 'lu' returns the values of P\n", + " and Q as vector values, such that for full matrix, 'A (P,:) = L *\n", + " U', and 'R(P,:) * A (:, Q) = L * U'.\n", + "\n", + " With two output arguments, returns the permuted forms of the upper\n", + " and lower triangular matrices, such that 'A = L * U'. With one\n", + " output argument Y, then the matrix returned by the LAPACK routines\n", + " is returned. If the input matrix is sparse then the matrix L is\n", + " embedded into U to give a return value similar to the full case.\n", + " For both full and sparse matrices, 'lu' loses the permutation\n", + " information.\n", + "\n", + " See also: luupdate, ilu, chol, hess, qr, qz, schur, svd.\n", + "\n", + "Additional help for built-in functions and operators is\n", + "available in the online version of the manual. Use the command\n", + "'doc <topic>' to search the manual index.\n", + "\n", + "Help and information about Octave is also available on the WWW\n", + "at http://www.octave.org and via the help@octave.org\n", + "mailing list.\n" + ] + } + ], + "source": [ + "help lu" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "data": { + "image/svg+xml": [ + "<svg height=\"420px\" viewBox=\"0 0 560 420\" width=\"560px\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n", + "\n", + "<title>Gnuplot</title>\n", + "<desc>Produced by GNUPLOT 5.0 patchlevel 3 </desc>\n", + "\n", + "<g id=\"gnuplot_canvas\">\n", + "\n", + "<rect fill=\"none\" height=\"420\" width=\"560\" x=\"0\" y=\"0\"/>\n", + "<defs>\n", + "\n", + "\t<circle id=\"gpDot\" r=\"0.5\" stroke-width=\"0.5\"/>\n", + "\t<path d=\"M-1,0 h2 M0,-1 v2\" id=\"gpPt0\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,-1 L1,1 M1,-1 L-1,1\" id=\"gpPt1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<path d=\"M-1,0 L1,0 M0,-1 L0,1 M-1,-1 L1,1 M-1,1 L1,-1\" id=\"gpPt2\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<rect height=\"2\" id=\"gpPt3\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<rect fill=\"currentColor\" height=\"2\" id=\"gpPt4\" stroke=\"currentColor\" stroke-width=\"0.222\" width=\"2\" x=\"-1\" y=\"-1\"/>\n", + "\t<circle cx=\"0\" cy=\"0\" id=\"gpPt5\" r=\"1\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt6\" stroke=\"none\" xlink:href=\"#gpPt5\"/>\n", + "\t<path d=\"M0,-1.33 L-1.33,0.67 L1.33,0.67 z\" id=\"gpPt7\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt8\" stroke=\"none\" xlink:href=\"#gpPt7\"/>\n", + "\t<use id=\"gpPt9\" stroke=\"currentColor\" transform=\"rotate(180)\" xlink:href=\"#gpPt7\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt10\" stroke=\"none\" xlink:href=\"#gpPt9\"/>\n", + "\t<use id=\"gpPt11\" stroke=\"currentColor\" transform=\"rotate(45)\" xlink:href=\"#gpPt3\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt12\" stroke=\"none\" xlink:href=\"#gpPt11\"/>\n", + "\t<path d=\"M0,1.330 L1.265,0.411 L0.782,-1.067 L-0.782,-1.076 L-1.265,0.411 z\" id=\"gpPt13\" stroke=\"currentColor\" stroke-width=\"0.222\"/>\n", + "\t<use fill=\"currentColor\" id=\"gpPt14\" stroke=\"none\" xlink:href=\"#gpPt13\"/>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"textbox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"white\" flood-opacity=\"1\" result=\"bgnd\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"bgnd\" operator=\"atop\"/>\n", + "\t</filter>\n", + "\t<filter filterUnits=\"objectBoundingBox\" height=\"1\" id=\"greybox\" width=\"1\" x=\"0\" y=\"0\">\n", + "\t <feFlood flood-color=\"lightgrey\" flood-opacity=\"1\" result=\"grey\"/>\n", + "\t <feComposite in=\"SourceGraphic\" in2=\"grey\" operator=\"atop\"/>\n", + "\t</filter>\n", + "</defs>\n", + "<g color=\"white\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<g shape-rendering=\"crispEdges\" stroke=\"none\">\n", + "\t\t<polygon fill=\"rgb(255, 255, 255)\" points=\"70.5,384.0 534.9,384.0 534.9,16.8 70.5,16.8 \"/>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"rgb(255, 255, 255)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L83.0,384.0 M535.0,384.0 L522.5,384.0 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,390.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,292.2 L83.0,292.2 M535.0,292.2 L522.5,292.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,298.2)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0005</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,200.3 L83.0,200.3 M535.0,200.3 L522.5,200.3 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,206.3)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.001</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,108.5 L83.0,108.5 M535.0,108.5 L522.5,108.5 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,114.5)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.0015</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L83.0,16.7 M535.0,16.7 L522.5,16.7 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(62.2,22.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">0.002</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,384.0 L70.5,371.5 M70.5,16.7 L70.5,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(70.5,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">0</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M163.4,384.0 L163.4,371.5 M163.4,16.7 L163.4,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(163.4,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">20</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M256.3,384.0 L256.3,371.5 M256.3,16.7 L256.3,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(256.3,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">40</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M349.2,384.0 L349.2,371.5 M349.2,16.7 L349.2,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(349.2,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">60</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M442.1,384.0 L442.1,371.5 M442.1,16.7 L442.1,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(442.1,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">80</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M535.0,384.0 L535.0,371.5 M535.0,16.7 L535.0,29.2 \" stroke=\"black\"/>\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"middle\" transform=\"translate(535.0,408.0)\">\n", + "\t\t<text><tspan font-family=\"{}\">100</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "\t<path d=\"M70.5,16.7 L70.5,384.0 L535.0,384.0 L535.0,16.7 L70.5,16.7 Z \" stroke=\"black\"/></g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"1.00\">\n", + "\t<path d=\"M349.7,121.7 L349.7,25.7 L526.7,25.7 L526.7,121.7 L349.7,121.7 Z \" stroke=\"black\"/></g>\n", + "\t<g id=\"gnuplot_plot_1a\"><title>LU decomp</title>\n", + "<g color=\"white\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,55.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">LU decomp</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,49.7 L414.7,49.7 M75.1,357.4 L79.8,366.4 L84.4,370.3 L89.1,369.9 L93.7,363.8 L98.4,369.5 L103.0,369.5 L107.7,362.2 L112.3,368.4 L117.0,368.0 L121.6,360.8 L126.2,366.5 L130.9,366.6 L135.5,355.4 L140.2,355.5 L144.8,353.0 L149.5,346.7 L154.1,360.0 L158.8,362.3 L163.4,361.2 L168.0,362.3 L172.7,355.7 L177.3,360.3 L182.0,356.9 L186.6,355.1 L191.3,357.9 L195.9,351.3 L200.6,356.6 L205.2,355.0 L209.9,355.4 L214.5,362.2 L219.1,360.9 L223.8,360.8 L228.4,359.7 L233.1,359.0 L237.7,356.5 L242.4,358.3 L247.0,356.6 L251.7,360.7 L256.3,360.3 L260.9,360.0 L265.6,359.0 L270.2,359.0 L274.9,357.6 L279.5,357.4 L284.2,356.2 L288.8,354.2 L293.5,359.6 L298.1,358.5 L302.8,357.9 L307.4,356.5 L312.0,356.5 L316.7,355.9 L321.3,355.1 L326.0,353.9 L330.6,352.4 L335.3,357.0 L339.9,356.6 L344.6,355.9 L349.2,355.2 L353.8,354.1 L358.5,353.1 L363.1,352.6 L367.8,351.5 L372.4,335.7 L377.1,356.3 L381.7,356.6 L386.4,352.6 L391.0,355.5 L395.7,355.5 L400.3,354.6 L404.9,355.1 L409.6,224.4 L414.2,352.4 L418.9,338.8 L423.5,351.5 L428.2,350.8 L432.8,350.4 L437.5,349.7 L442.1,350.4 L446.7,348.4 L451.4,347.8 L456.0,346.2 L460.7,347.0 L465.3,340.7 L470.0,338.6 L474.6,346.2 L479.3,347.3 L483.9,344.2 L488.6,343.8 L493.2,342.5 L497.8,343.2 L502.5,341.2 L507.1,342.5 L511.8,338.8 L516.4,342.3 L521.1,337.9 L525.7,338.3 L530.4,337.8 L535.0,339.2 \" stroke=\"rgb( 0, 0, 255)\"/></g>\n", + "\t</g>\n", + "\t<g id=\"gnuplot_plot_2a\"><title>Octave \\\\</title>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<g fill=\"rgb(0,0,0)\" font-family=\"{}\" font-size=\"16.00\" stroke=\"none\" text-anchor=\"end\" transform=\"translate(526.7,103.7)\">\n", + "\t\t<text><tspan font-family=\"{}\">Octave \\</tspan></text>\n", + "\t</g>\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"3.00\">\n", + "\t<path d=\"M360.9,97.7 L414.7,97.7 M75.1,371.7 L79.8,368.6 L84.4,372.8 L89.1,372.4 L93.7,371.3 L98.4,371.7 L103.0,371.3 L107.7,369.9 L112.3,370.3 L117.0,370.2 L121.6,368.6 L126.2,368.9 L130.9,364.9 L135.5,357.0 L140.2,358.5 L144.8,354.4 L149.5,353.0 L154.1,358.7 L158.8,359.8 L163.4,360.1 L168.0,360.7 L172.7,355.2 L177.3,353.7 L182.0,355.4 L186.6,337.5 L191.3,353.7 L195.9,349.1 L200.6,354.4 L205.2,350.4 L209.9,329.8 L214.5,357.6 L219.1,353.7 L223.8,357.6 L228.4,350.4 L233.1,354.4 L237.7,353.9 L242.4,352.4 L247.0,140.3 L251.7,355.1 L256.3,356.8 L260.9,355.5 L265.6,352.6 L270.2,353.3 L274.9,353.9 L279.5,351.7 L284.2,350.8 L288.8,341.2 L293.5,355.2 L298.1,353.0 L302.8,352.6 L307.4,350.6 L312.0,351.3 L316.7,343.8 L321.3,348.0 L326.0,347.3 L330.6,345.4 L335.3,351.5 L339.9,338.1 L344.6,348.7 L349.2,349.1 L353.8,347.3 L358.5,346.9 L363.1,343.2 L367.8,343.6 L372.4,343.2 L377.1,335.7 L381.7,342.7 L386.4,344.5 L391.0,345.8 L395.7,345.6 L400.3,332.4 L404.9,340.7 L409.6,341.9 L414.2,262.6 L418.9,340.1 L423.5,331.8 L428.2,339.4 L432.8,338.3 L437.5,334.6 L442.1,335.5 L446.7,328.7 L451.4,333.3 L456.0,328.7 L460.7,331.3 L465.3,329.7 L470.0,327.8 L474.6,323.0 L479.3,324.8 L483.9,114.6 L488.6,315.3 L493.2,314.0 L497.8,301.7 L502.5,315.3 L507.1,319.2 L511.8,314.6 L516.4,315.1 L521.1,311.6 L525.7,313.1 L530.4,302.3 L535.0,305.2 \" stroke=\"rgb( 0, 128, 0)\"/></g>\n", + "\t</g>\n", + "<g color=\"white\" fill=\"none\" stroke=\"rgb( 0, 128, 0)\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"2.00\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"black\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "<g color=\"black\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"butt\" stroke-linejoin=\"miter\" stroke-width=\"0.50\">\n", + "</g>\n", + "</g>\n", + "</svg>" + ], + "text/plain": [ + "<IPython.core.display.SVG object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "% time LU solution vs backslash\n", + "t_lu=zeros(100,1);\n", + "t_bs=zeros(100,1);\n", + "for N=1:100\n", + " A=rand(N,N);\n", + " y=rand(N,1);\n", + " [L,U,P]=lu(A);\n", + "\n", + " tic; d=inv(L)*y; x=inv(U)*d; t_lu(N)=toc;\n", + "\n", + " tic; x=inv(A)*y; t_bs(N)=toc;\n", + "end\n", + "plot([1:100],t_lu,[1:100],t_bs) \n", + "legend('LU decomp','Octave \\\\')" + ] + }, + { + "cell_type": "markdown", + "metadata": { + "collapsed": true + }, + "source": [ + "Consider the problem again from the intro to Linear Algebra, 4 masses are connected in series to 4 springs with K=10 N/m. What are the final positions of the masses? \n", + "\n", + "\n", + "\n", + "The masses haves the following amounts, 1, 2, 3, and 4 kg for masses 1-4. Using a FBD for each mass:\n", + "\n", + "$m_{1}g+k(x_{2}-x_{1})-kx_{1}=0$\n", + "\n", + "$m_{2}g+k(x_{3}-x_{2})-k(x_{2}-x_{1})=0$\n", + "\n", + "$m_{3}g+k(x_{4}-x_{3})-k(x_{3}-x_{2})=0$\n", + "\n", + "$m_{4}g-k(x_{4}-x_{3})=0$\n", + "\n", + "in matrix form:\n", + "\n", + "$\\left[ \\begin{array}{cccc}\n", + "2k & -k & 0 & 0 \\\\\n", + "-k & 2k & -k & 0 \\\\\n", + "0 & -k & 2k & -k \\\\\n", + "0 & 0 & -k & k \\end{array} \\right]\n", + "\\left[ \\begin{array}{c}\n", + "x_{1} \\\\\n", + "x_{2} \\\\\n", + "x_{3} \\\\\n", + "x_{4} \\end{array} \\right]=\n", + "\\left[ \\begin{array}{c}\n", + "m_{1}g \\\\\n", + "m_{2}g \\\\\n", + "m_{3}g \\\\\n", + "m_{4}g \\end{array} \\right]$" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n", + "y =\n", + "\n", + " 9.8100\n", + " 19.6200\n", + " 29.4300\n", + " 39.2400\n", + "\n" + ] + } + ], + "source": [ + "k=10; % N/m\n", + "m1=1; % kg\n", + "m2=2;\n", + "m3=3;\n", + "m4=4;\n", + "g=9.81; % m/s^2\n", + "K=[2*k -k 0 0; -k 2*k -k 0; 0 -k 2*k -k; 0 0 -k k]\n", + "y=[m1*g;m2*g;m3*g;m4*g]" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "This matrix, K, is symmetric. \n", + "\n", + "`K(i,j)==K(j,i)`\n", + "\n", + "Now we can use,\n", + "\n", + "## Cholesky Factorization\n", + "\n", + "We can decompose the matrix, K into two matrices, $U$ and $U^{T}$, where\n", + "\n", + "$K=U^{T}U$\n", + "\n", + "each of the components of U can be calculated with the following equations:\n", + "\n", + "$u_{ii}=\\sqrt{a_{ii}-\\sum_{k=1}^{i-1}u_{ki}^{2}}$\n", + "\n", + "$u_{ij}=\\frac{a_{ij}-\\sum_{k=1}^{i-1}u_{ki}u_{kj}}{u_{ii}}$\n", + "\n", + "so for K" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "K =\n", + "\n", + " 20 -10 0 0\n", + " -10 20 -10 0\n", + " 0 -10 20 -10\n", + " 0 0 -10 10\n", + "\n" + ] + } + ], + "source": [ + "K" + ] + }, + { + "cell_type": "code", + "execution_count": 12, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "u11 = 4.4721\n", + "u12 = -2.2361\n", + "u13 = 0\n", + "u14 = 0\n", + "u22 = 3.8730\n", + "u23 = -2.5820\n", + "u24 = 0\n", + "u33 = 3.6515\n", + "u34 = -2.7386\n", + "u44 = 1.5811\n", + "U =\n", + "\n", + " 4.47214 -2.23607 0.00000 0.00000\n", + " 0.00000 3.87298 -2.58199 0.00000\n", + " 0.00000 0.00000 3.65148 -2.73861\n", + " 0.00000 0.00000 0.00000 1.58114\n", + "\n" + ] + } + ], + "source": [ + "u11=sqrt(K(1,1))\n", + "u12=(K(1,2))/u11\n", + "u13=(K(1,3))/u11\n", + "u14=(K(1,4))/u11\n", + "u22=sqrt(K(2,2)-u12^2)\n", + "u23=(K(2,3)-u12*u13)/u22\n", + "u24=(K(2,4)-u12*u14)/u22\n", + "u33=sqrt(K(3,3)-u13^2-u23^2)\n", + "u34=(K(3,4)-u13*u14-u23*u24)/u33\n", + "u44=sqrt(K(4,4)-u14^2-u24^2-u34^2)\n", + "U=[u11,u12,u13,u14;0,u22,u23,u24;0,0,u33,u34;0,0,0,u44]" + ] + }, + { + "cell_type": "code", + "execution_count": 17, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "ans =\n", + "\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + " 1 1 1 1\n", + "\n" + ] + } + ], + "source": [ + "(U'*U)'==U'*U" + ] + }, + { + "cell_type": "code", + "execution_count": 18, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "average time spent for Cholesky factored solution = 1.465964e-05+/-9.806001e-06\n", + "average time spent for backslash solution = 1.555967e-05+/-1.048561e-05\n" + ] + } + ], + "source": [ + "% time solution for Cholesky vs backslash\n", + "t_chol=zeros(1000,1);\n", + "t_bs=zeros(1000,1);\n", + "for i=1:1000\n", + " tic; d=U'*y; x=U\\d; t_chol(i)=toc;\n", + " tic; x=K\\y; t_bs(i)=toc;\n", + "end\n", + "fprintf('average time spent for Cholesky factored solution = %e+/-%e',mean(t_chol),std(t_chol))\n", + "\n", + "fprintf('average time spent for backslash solution = %e+/-%e',mean(t_bs),std(t_bs))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "collapsed": true + }, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Octave", + "language": "octave", + "name": "octave" + }, + "language_info": { + "file_extension": ".m", + "help_links": [ + { + "text": "MetaKernel Magics", + "url": "https://github.com/calysto/metakernel/blob/master/metakernel/magics/README.md" + } + ], + "mimetype": "text/x-octave", + "name": "octave", + "version": "0.19.14" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/linear_algebra/LU_suggested.html b/linear_algebra/LU_suggested.html new file mode 100644 index 0000000..f1998e1 --- /dev/null +++ b/linear_algebra/LU_suggested.html @@ -0,0 +1,39 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml"> +<head> + <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> + <meta http-equiv="Content-Style-Type" content="text/css" /> + <meta name="generator" content="pandoc" /> + <title></title> + <style type="text/css">code{white-space: pre;}</style> + <script src="https://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type="text/javascript"></script> +</head> +<body> +<h1 id="linear-algebra-review">Linear Algebra Review</h1> +<h2 id="gauss-elimination-suggested-problems">(Gauss Elimination) Suggested problems</h2> +<h3 id="no-due-date">No due date</h3> +<ol style="list-style-type: decimal"> +<li><p>Determine the lower (L) and upper (U) triangular matrices with LU-decomposition for the following matrices:</p> +<ol style="list-style-type: lower-alpha"> +<li><p><span class="math inline">\(A=\left[ \begin{array}{cc} 1 & 3 \\ 2 & 1 \end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{cc} 1 & 1 \\ 2 & 3 \end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{cc} 1 & 1 \\ 2 & -2 \end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{ccc} 1 & 3 & 1 \\ -4 & -9 & 2 \\ 0 & 3 & 6\end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{ccc} 1 & 3 & 1 \\ -4 & -9 & 2 \\ 0 & 3 & 6\end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{ccc} 1 & 3 & -5 \\ 1 & 4 & -8 \\ -3 & -7 & 9\end{array} \right]\)</span></p></li> +<li><p><span class="math inline">\(A=\left[ \begin{array}{ccc} 1 & 2 & -1 \\ 2 & 2 & 2 \\ 1 & -1 & 2\end{array} \right]\)</span></p></li> +</ol></li> +<li><p>Calculate the determinant of A from 1a-g.</p></li> +<li><p>Determine the Cholesky factorization, C, of the following matrices, where</p> +<p><span class="math inline">\(C_{ii}=\sqrt{a_{ii}-\sum_{k=1}^{i-1}C_{ki}^{2}}\)</span></p> +<p><span class="math inline">\(C_{ij}=\frac{a_{ij}-\sum_{k=1}^{i-1}C_{ki}C_{kj}}{C_{ii}}\)</span>.</p> +<ol style="list-style-type: lower-alpha"> +<li><p>A=<span class="math inline">\(\left[ \begin{array}{cc} 3 & 2 \\ 2 & 1 \end{array} \right]\)</span></p></li> +<li><p>A=<span class="math inline">\(\left[ \begin{array}{cc} 10 & 5 \\ 5 & 20 \end{array} \right]\)</span></p></li> +<li><p>A=<span class="math inline">\(\left[ \begin{array}{ccc} 10 & -10 & 20 \\ -10 & 20 & 10 \\ 20 & 10 & 30 \end{array} \right]\)</span></p></li> +<li><p>A=<span class="math inline">\(\left[ \begin{array}{cccc} 21 & -1 & 0 & 0 \\ -1 & 21 & -1 & 0 \\ 0 & -1 & 21 & -1 \\ 0 & 0 & -1 & 1 \end{array} \right]\)</span></p></li> +</ol></li> +<li><p>Verify that <span class="math inline">\(C^{T}C=A\)</span> for 3a-d</p></li> +</ol> +</body> +</html> diff --git a/linear_algebra/LU_suggested.md b/linear_algebra/LU_suggested.md new file mode 100644 index 0000000..f809813 --- /dev/null +++ b/linear_algebra/LU_suggested.md @@ -0,0 +1,68 @@ +# Linear Algebra Review +## (Gauss Elimination) Suggested problems +### No due date + +1. Determine the lower (L) and upper (U) triangular matrices with LU-decomposition for the +following matrices: + + a. $A=\left[ \begin{array}{cc} + 1 & 3 \\ + 2 & 1 \end{array} \right]$ + + a. $A=\left[ \begin{array}{cc} + 1 & 1 \\ + 2 & 3 \end{array} \right]$ + + a. $A=\left[ \begin{array}{cc} + 1 & 1 \\ + 2 & -2 \end{array} \right]$ + + b. $A=\left[ \begin{array}{ccc} + 1 & 3 & 1 \\ + -4 & -9 & 2 \\ + 0 & 3 & 6\end{array} \right]$ + + c. $A=\left[ \begin{array}{ccc} + 1 & 3 & 1 \\ + -4 & -9 & 2 \\ + 0 & 3 & 6\end{array} \right]$ + + d. $A=\left[ \begin{array}{ccc} + 1 & 3 & -5 \\ + 1 & 4 & -8 \\ + -3 & -7 & 9\end{array} \right]$ + + d. $A=\left[ \begin{array}{ccc} + 1 & 2 & -1 \\ + 2 & 2 & 2 \\ + 1 & -1 & 2\end{array} \right]$ + +2. Calculate the determinant of A from 1a-g. + +3. Determine the Cholesky factorization, C, of the following matrices, where + + $C_{ii}=\sqrt{a_{ii}-\sum_{k=1}^{i-1}C_{ki}^{2}}$ + + $C_{ij}=\frac{a_{ij}-\sum_{k=1}^{i-1}C_{ki}C_{kj}}{C_{ii}}$. + + a. A=$\left[ \begin{array}{cc} + 3 & 2 \\ + 2 & 1 \end{array} \right]$ + + a. A=$\left[ \begin{array}{cc} + 10 & 5 \\ + 5 & 20 \end{array} \right]$ + + a. A=$\left[ \begin{array}{ccc} + 10 & -10 & 20 \\ + -10 & 20 & 10 \\ + 20 & 10 & 30 \end{array} \right]$ + + a. A=$\left[ \begin{array}{cccc} + 21 & -1 & 0 & 0 \\ + -1 & 21 & -1 & 0 \\ + 0 & -1 & 21 & -1 \\ + 0 & 0 & -1 & 1 \end{array} \right]$ + +4. Verify that $C^{T}C=A$ for 3a-d + diff --git a/linear_algebra/gauss_suggested.md b/linear_algebra/gauss_suggested.md new file mode 100644 index 0000000..6b1f6b6 --- /dev/null +++ b/linear_algebra/gauss_suggested.md @@ -0,0 +1,71 @@ +# Linear Algebra Review +## (Gauss Elimination) Suggested problems +### No due date + +1. Solve for x when Ax=b for the following problems: + + a. $A=\left[ \begin{array}{cc} + 1 & 3 \\ + 2 & 1 \end{array} \right] + b= + \left[\begin{array}{c} + 1 \\ + 1\end{array}\right]$ + + a. $A=\left[ \begin{array}{cc} + 1 & 1 \\ + 2 & 3 \end{array} \right] + b= + \left[\begin{array}{c} + 3 \\ + 4\end{array}\right]$ + + a. $A=\left[ \begin{array}{cc} + 1 & 1 \\ + 2 & -2 \end{array} \right] + b= + \left[\begin{array}{c} + 4 \\ + 2\end{array}\right]$ + + b. $A=\left[ \begin{array}{ccc} + 1 & 3 & 1 \\ + -4 & -9 & 2 \\ + 0 & 3 & 6\end{array} \right] + b= + \left[\begin{array}{c} + 0 \\ + 0 \\ + 0\end{array}\right]$ + + c. $A=\left[ \begin{array}{ccc} + 1 & 3 & 1 \\ + -4 & -9 & 2 \\ + 0 & 3 & 6\end{array} \right] + b= + \left[\begin{array}{c} + 1 \\ + -1 \\ + -3\end{array}\right]$ + + d. $A=\left[ \begin{array}{ccc} + 1 & 3 & -5 \\ + 1 & 4 & -8 \\ + -3 & -7 & 9\end{array} \right] + b= + \left[\begin{array}{c} + 1 \\ + -1 \\ + -3\end{array}\right]$ + + d. $A=\left[ \begin{array}{ccc} + 1 & 2 & -1 \\ + 2 & 2 & 2 \\ + 1 & -1 & 2\end{array} \right] + b= + \left[\begin{array}{c} + 2 \\ + 12 \\ + 5\end{array}\right]$ + +2. Calculate the determinant of A from 1a-g. diff --git a/linear_algebra/gauss_suggested.pdf b/linear_algebra/gauss_suggested.pdf new file mode 100644 index 0000000..a78b277 Binary files /dev/null and b/linear_algebra/gauss_suggested.pdf differ