Newer
Older
Lecture_repo / Lectures_my / NumMet / Lecture2 / mchrzasz.tex
@mchrzasz mchrzasz on 21 Sep 2016 24 KB small fix in Lecture 2
  1. \documentclass[11 pt,xcolor={dvipsnames,svgnames,x11names,table}]{beamer}
  2.  
  3. \usepackage[english]{babel}
  4. \usepackage{polski}
  5.  
  6.  
  7. \usetheme[
  8. bullet=circle, % Other option: square
  9. bigpagenumber, % circled page number on lower right
  10. topline=true, % colored bar at the top of the frame
  11. shadow=false, % Shading for beamer blocks
  12. watermark=BG_lower, % png file for the watermark
  13. ]{Flip}
  14.  
  15. %\logo{\kern+1.em\includegraphics[height=1cm]{SHiP-3_LightCharcoal}}
  16.  
  17. \usepackage[lf]{berenis}
  18. \usepackage[LY1]{fontenc}
  19. \usepackage[utf8]{inputenc}
  20. \usepackage{cases}
  21. \usepackage{mathtools}
  22. \usepackage{emerald}
  23. \usefonttheme{professionalfonts}
  24. \usepackage[no-math]{fontspec}
  25. \defaultfontfeatures{Mapping=tex-text} % This seems to be important for mapping glyphs properly
  26.  
  27. \setmainfont{Gillius ADF} % Beamer ignores "main font" in favor of sans font
  28. \setsansfont{Gillius ADF} % This is the font that beamer will use by default
  29. % \setmainfont{Gill Sans Light} % Prettier, but harder to read
  30.  
  31. \setbeamerfont{title}{family=\fontspec{Gillius ADF}}
  32.  
  33. \input t1augie.fd
  34.  
  35. %\newcommand{\handwriting}{\fontspec{augie}} % From Emerald City, free font
  36. %\newcommand{\handwriting}{\usefont{T1}{fau}{m}{n}} % From Emerald City, free font
  37. % \newcommand{\handwriting}{} % If you prefer no special handwriting font or don't have augie
  38.  
  39. %% Gill Sans doesn't look very nice when boldfaced
  40. %% This is a hack to use Helvetica instead
  41. %% Usage: \textbf{\forbold some stuff}
  42. %\newcommand{\forbold}{\fontspec{Arial}}
  43.  
  44. \usepackage{graphicx}
  45. \usepackage[export]{adjustbox}
  46.  
  47. \usepackage{amsmath}
  48. \usepackage{amsfonts}
  49. \usepackage{amssymb}
  50. \usepackage{bm}
  51. \usepackage{colortbl}
  52. \usepackage{mathrsfs} % For Weinberg-esque letters
  53. \usepackage{cancel} % For "SUSY-breaking" symbol
  54. \usepackage{slashed} % for slashed characters in math mode
  55. \usepackage{bbm} % for \mathbbm{1} (unit matrix)
  56. \usepackage{amsthm} % For theorem environment
  57. \usepackage{multirow} % For multi row cells in table
  58. \usepackage{arydshln} % For dashed lines in arrays and tables
  59. \usepackage{siunitx}
  60. \usepackage{xhfill}
  61. \usepackage{grffile}
  62. \usepackage{textpos}
  63. \usepackage{subfigure}
  64. \usepackage{tikz}
  65. \usepackage{hyperref}
  66. %\usepackage{hepparticles}
  67. \usepackage[italic]{hepparticles}
  68.  
  69. \usepackage{hepnicenames}
  70.  
  71. % Drawing a line
  72. \tikzstyle{lw} = [line width=20pt]
  73. \newcommand{\topline}{%
  74. \tikz[remember picture,overlay] {%
  75. \draw[crimsonred] ([yshift=-23.5pt]current page.north west)
  76. -- ([yshift=-23.5pt,xshift=\paperwidth]current page.north west);}}
  77.  
  78.  
  79.  
  80. % % % % % % % % % % % % % % % % % % % % % % % % % % % % % % % % % % %
  81. \usepackage{tikzfeynman} % For Feynman diagrams
  82. \usetikzlibrary{arrows,shapes}
  83. \usetikzlibrary{trees}
  84. \usetikzlibrary{matrix,arrows} % For commutative diagram
  85. % http://www.felixl.de/commu.pdf
  86. \usetikzlibrary{positioning} % For "above of=" commands
  87. \usetikzlibrary{calc,through} % For coordinates
  88. \usetikzlibrary{decorations.pathreplacing} % For curly braces
  89. % http://www.math.ucla.edu/~getreuer/tikz.html
  90. \usepackage{pgffor} % For repeating patterns
  91.  
  92. \usetikzlibrary{decorations.pathmorphing} % For Feynman Diagrams
  93. \usetikzlibrary{decorations.markings}
  94. \tikzset{
  95. % >=stealth', %% Uncomment for more conventional arrows
  96. vector/.style={decorate, decoration={snake}, draw},
  97. provector/.style={decorate, decoration={snake,amplitude=2.5pt}, draw},
  98. antivector/.style={decorate, decoration={snake,amplitude=-2.5pt}, draw},
  99. fermion/.style={draw=gray, postaction={decorate},
  100. decoration={markings,mark=at position .55 with {\arrow[draw=gray]{>}}}},
  101. fermionbar/.style={draw=gray, postaction={decorate},
  102. decoration={markings,mark=at position .55 with {\arrow[draw=gray]{<}}}},
  103. fermionnoarrow/.style={draw=gray},
  104. gluon/.style={decorate, draw=black,
  105. decoration={coil,amplitude=4pt, segment length=5pt}},
  106. scalar/.style={dashed,draw=black, postaction={decorate},
  107. decoration={markings,mark=at position .55 with {\arrow[draw=black]{>}}}},
  108. scalarbar/.style={dashed,draw=black, postaction={decorate},
  109. decoration={markings,mark=at position .55 with {\arrow[draw=black]{<}}}},
  110. scalarnoarrow/.style={dashed,draw=black},
  111. electron/.style={draw=black, postaction={decorate},
  112. decoration={markings,mark=at position .55 with {\arrow[draw=black]{>}}}},
  113. bigvector/.style={decorate, decoration={snake,amplitude=4pt}, draw},
  114. }
  115.  
  116. % TIKZ - for block diagrams,
  117. % from http://www.texample.net/tikz/examples/control-system-principles/
  118. % \usetikzlibrary{shapes,arrows}
  119. \tikzstyle{block} = [draw, rectangle,
  120. minimum height=3em, minimum width=6em]
  121.  
  122.  
  123.  
  124.  
  125. \usetikzlibrary{backgrounds}
  126. \usetikzlibrary{mindmap,trees} % For mind map
  127. \newcommand{\degree}{\ensuremath{^\circ}}
  128. \newcommand{\E}{\mathrm{E}}
  129. \newcommand{\Var}{\mathrm{Var}}
  130. \newcommand{\Cov}{\mathrm{Cov}}
  131. \newcommand\Ts{\rule{0pt}{2.6ex}} % Top strut
  132. \newcommand\Bs{\rule[-1.2ex]{0pt}{0pt}} % Bottom strut
  133.  
  134. \graphicspath{{images/}} % Put all images in this directory. Avoids clutter.
  135.  
  136. % SOME COMMANDS THAT I FIND HANDY
  137. % \renewcommand{\tilde}{\widetilde} % dinky tildes look silly, dosn't work with fontspec
  138. \newcommand{\comment}[1]{\textcolor{comment}{\footnotesize{#1}\normalsize}} % comment mild
  139. \newcommand{\Comment}[1]{\textcolor{Comment}{\footnotesize{#1}\normalsize}} % comment bold
  140. \newcommand{\COMMENT}[1]{\textcolor{COMMENT}{\footnotesize{#1}\normalsize}} % comment crazy bold
  141. \newcommand{\Alert}[1]{\textcolor{Alert}{#1}} % louder alert
  142. \newcommand{\ALERT}[1]{\textcolor{ALERT}{#1}} % loudest alert
  143. %% "\alert" is already a beamer pre-defined
  144. \newcommand*{\Scale}[2][4]{\scalebox{#1}{$#2$}}%
  145.  
  146. \def\Put(#1,#2)#3{\leavevmode\makebox(0,0){\put(#1,#2){#3}}}
  147.  
  148. \usepackage{gmp}
  149. \usepackage[final]{feynmp-auto}
  150.  
  151. \usepackage[backend=bibtex,style=numeric-comp,firstinits=true]{biblatex}
  152. \bibliography{bib}
  153. \setbeamertemplate{bibliography item}[text]
  154.  
  155. \makeatletter\let\frametextheight\beamer@frametextheight\makeatother
  156.  
  157. % suppress frame numbering for backup slides
  158. % you always need the appendix for this!
  159. \newcommand{\backupbegin}{
  160. \newcounter{framenumberappendix}
  161. \setcounter{framenumberappendix}{\value{framenumber}}
  162. }
  163. \newcommand{\backupend}{
  164. \addtocounter{framenumberappendix}{-\value{framenumber}}
  165. \addtocounter{framenumber}{\value{framenumberappendix}}
  166. }
  167.  
  168.  
  169. \definecolor{links}{HTML}{2A1B81}
  170. %\hypersetup{colorlinks,linkcolor=,urlcolor=links}
  171.  
  172. % For shapo's formulas:
  173. \def\lsi{\raise0.3ex\hbox{$<$\kern-0.75em\raise-1.1ex\hbox{$\sim$}}}
  174. \def\gsi{\raise0.3ex\hbox{$>$\kern-0.75em\raise-1.1ex\hbox{$\sim$}}}
  175. \newcommand{\lsim}{\mathop{\lsi}}
  176. \newcommand{\gsim}{\mathop{\gsi}}
  177. \newcommand{\wt}{\widetilde}
  178. %\newcommand{\ol}{\overline}
  179. \newcommand{\Tr}{\rm{Tr}}
  180. \newcommand{\tr}{\rm{tr}}
  181. \newcommand{\eqn}[1]{&\hspace{-0.7em}#1\hspace{-0.7em}&}
  182. \newcommand{\vev}[1]{\rm{$\langle #1 \rangle$}}
  183. \newcommand{\abs}[1]{\rm{$\left| #1 \right|$}}
  184. \newcommand{\eV}{\rm{eV}}
  185. \newcommand{\keV}{\rm{keV}}
  186. \newcommand{\GeV}{\rm{GeV}}
  187. \newcommand{\im}{\rm{Im}}
  188. \newcommand{\disp}{\displaystyle}
  189. \def\be{\begin{equation}}
  190. \def\ee{\end{equation}}
  191. \def\ba{\begin{eqnarray}}
  192. \def\ea{\end{eqnarray}}
  193. \def\d{\partial}
  194. \def\l{\left(}
  195. \def\r{\right)}
  196. \def\la{\langle}
  197. \def\ra{\rangle}
  198. \def\e{{\rm e}}
  199. \def\Br{{\rm Br}}
  200. \def\fixme{{\color{red} FIXME!}}
  201. \def\mc{{\color{Magenta}{MC}}\xspace}
  202. \def\pdf{{\rm p.d.f.}}
  203. \def\ARROW{{\color{JungleGreen}{$\Rrightarrow$}}\xspace}
  204. \def\ARROWR{{\color{WildStrawberry}{$\Rrightarrow$}}\xspace}
  205.  
  206. \author{ {\fontspec{Trebuchet MS}Marcin Chrz\k{a}szcz, Danny van Dyk} (UZH)}
  207. \institute{UZH}
  208. \title[Function interpolation]{Function Interpolation}
  209. \date{21 September 2016}
  210.  
  211.  
  212. \begin{document}
  213. \tikzstyle{every picture}+=[remember picture]
  214.  
  215. {
  216. \setbeamertemplate{sidebar right}{\llap{\includegraphics[width=\paperwidth,height=\paperheight]{bubble2}}}
  217. \begin{frame}[c]%{\phantom{title page}}
  218. \begin{center}
  219. \begin{center}
  220. \begin{columns}
  221. \begin{column}{0.9\textwidth}
  222. \flushright\fontspec{Trebuchet MS}\bfseries \Huge {Function Interpolation}
  223. \end{column}
  224. \begin{column}{0.2\textwidth}
  225. %\includegraphics[width=\textwidth]{SHiP-2}
  226. \end{column}
  227. \end{columns}
  228. \end{center}
  229. \quad
  230. \vspace{3em}
  231. \begin{columns}
  232. \begin{column}{0.6\textwidth}
  233. \flushright \vspace{-1.8em} {\fontspec{Trebuchet MS} \large Marcin Chrząszcz, Danny van Dyk\\\vspace{-0.1em}\small \href{mailto:mchrzasz@cern.ch}{mchrzasz@cern.ch}, \href{mailto:dany.van.dyk@gmail.com}{danny.van.dyk@gmail.com}}
  234.  
  235. \end{column}
  236. \begin{column}{0.4\textwidth}
  237. \includegraphics[height=1.3cm]{uzh-transp}
  238. \end{column}
  239. \end{columns}
  240.  
  241. \vspace{1em}
  242. % \footnotesize\textcolor{gray}{With N. Serra, B. Storaci\\Thanks to the theory support from M. Shaposhnikov, D. Gorbunov}\normalsize\\
  243. \vspace{0.5em}
  244. \textcolor{normal text.fg!50!Comment}{Numerical Methods, \\ 21 September, 2016}
  245. \end{center}
  246. \end{frame}
  247. }
  248.  
  249.  
  250.  
  251. \begin{frame}\frametitle{Interpolation - graphical interpretation}
  252. \begin{small}
  253.  
  254.  
  255. \ARROW Let's assume we have a given function in a tabular form:
  256. \begin{tabular}{c||c|c|c|c|c}
  257. $x_i$ & $x_1$ & $x_2$ & $x_3$ & ... & $x_n$ \\ \hline
  258. $f_i=f(x_i)$ & $f_1$ & $f_2$ & $f_3$ & ... & $f_n$ \\
  259. \end{tabular}\\
  260. \ARROWR The $x_i$ are data points.\\
  261. \ARROW The problem is how to calculate the function values between the points ({\it interpolation}) or outside ({\it extrapolation} - see next lecture!) .
  262. \end{small}
  263. \begin{center}
  264. \includegraphics[angle=-90,width=0.5\textwidth]{images/mass_resolution_Bconstr_afterSel_errBand_scaled.pdf}
  265. \end{center}
  266. \end{frame}
  267.  
  268.  
  269.  
  270. \begin{frame}\frametitle{Interpolation - formal formulation}
  271. \begin{small}
  272.  
  273. \ARROW On the interval: $\left[ a, b \right] \subset \mathbb{R}$ and set of points: $D=(x_i, y_i)$, $x_i \neq x_j~ \Leftrightarrow~ i \neq j$.\\
  274. \ARROW The interpolation is to find a function $F:\left[ a, b \right] \rightarrow \mathbb{R}$ that satisfies:
  275. \begin{align*}
  276. \forall (x_i,y_i) \in D:~~~ F(x_i)=y_i
  277. \end{align*}
  278. \ARROW The above equation is called the interpolation equation.\\
  279. \ARROW The interpolation error:
  280. \begin{align*}
  281. \epsilon(x)=f(x)-F(x),
  282. \end{align*}
  283. where $f(x)$ is the function that is being interpolated.\\
  284. \ARROW Each interpolation method has different errors, each of it can be estimated.
  285. \end{small}
  286.  
  287. \end{frame}
  288.  
  289.  
  290.  
  291. \begin{frame}\frametitle{Linear Interpolation}
  292. \begin{small}
  293.  
  294. \ARROW Let's say we have $n+1$ interpolation points: $(y_i, x_i)$.\\
  295. \ARROW The linear interpolation is given with with the equation:
  296. \begin{align*}
  297. F(x)=\sum_{j=0}^n a_j \psi_j(x)=a_0 \psi_0(x) + a_1 \psi_1(x) + a_2 \psi_2(x)+ ... + a_n \psi_n(x),
  298. \end{align*}
  299. where:
  300. \begin{itemize}
  301. \item $a_j$ - parameter,
  302. \item $\psi_j(x)$ - base function.
  303. \end{itemize}
  304. \ARROW Now the only thing one needs to do is to find the $a_i$ coefficients. Now there are infinite number such solutions so we need to assume that the number interpolation points is equal to number of base functions.
  305.  
  306.  
  307. \end{small}
  308.  
  309. \end{frame}
  310.  
  311.  
  312. \begin{frame}\frametitle{Linear Interpolation}
  313. \begin{small}
  314.  
  315. \ARROW Now to find all the $a_i$ one just needs to solve the linear equation system:
  316. \begin{align*}
  317. \begin{pmatrix}
  318. \psi_0(x_0) & \psi_1(x_0) & ... & \psi_n(x_0) \\
  319. \psi_0(x_1) & \psi_1(x_1) & ... & \psi_n(x_1) \\
  320. & ... \\
  321. \psi_0(x_0) & \psi_1(x_0) & ... & \psi_n(x_2)
  322. \end{pmatrix}
  323. \begin{pmatrix}
  324. a_0\\
  325. a_1\\
  326. ...\\
  327. a_n
  328. \end{pmatrix}=
  329. \begin{pmatrix}
  330. y_0\\
  331. y_1\\
  332. ...\\
  333. y_n
  334. \end{pmatrix}
  335. \end{align*}
  336. \ARROW The only necessary condition to solve the equation is that the:
  337. \begin{align*}
  338. \det \left[ \psi_i(x_j) \right] \neq 0
  339. \end{align*}
  340. \ARROW The polynomial of the order $n$ has $n+1$ base functions, so system has only one solution.\\
  341. \ARROW We can choose the base functions on many different ways. This depends on the input points and our own judgement. Often use are trigonometric functions and polynomials.\\
  342. \ARROW The proper selection of the base function can hugely simplify the problem by making the matrix triangular or even diagonal.
  343.  
  344. \end{small}
  345.  
  346. \end{frame}
  347.  
  348. \begin{frame}\frametitle{Linear Interpolation, simplest base}
  349. \begin{small}
  350. \begin{exampleblock}{Theorem:}
  351. If all of the interpolation points $x_0,x_1,...,x_n$ are pair different there exists one and only one solution of the interpolation function of the order max. $n$.
  352. \end{exampleblock}
  353.  
  354. The simplest base functions one can imagine to use is the natural base:
  355. \begin{align*}
  356. \psi_0=1,~~~\psi_1=x,~~~\psi_2=x^2,~~~...~~~, \psi_n=x^n
  357. \end{align*}
  358. \begin{alertblock}{Attention/Achtung:}
  359. This kind of interpolation is wrongly conditioned: small changes of input parameters will cause large output differences.
  360. \end{alertblock}
  361.  
  362. \ARROW Because of the above it is used almost not used in practice. \\
  363. \ARROW For education purposes we will analyse it.
  364. \end{small}
  365.  
  366. \end{frame}
  367.  
  368. \begin{frame}\frametitle{Linear Interpolation, simplest base}
  369. \begin{small}
  370. \ARROW When using natural base the interpolation polynomial will have the structure:
  371. \begin{align*}
  372. F(x)=a_0+a_1 x + a_2 x^2 + a_3 x^3 ... a_n x^n
  373. \end{align*}
  374. \ARROW Now base matrix (so-called Vandermonde matrix) has the form:
  375. \begin{align*}
  376. V=\begin{pmatrix}
  377. 1 & x_0 & x_0^2 & ... & x_0^n \\
  378. 1 & x_1 & x_1^2 & ... & x_1^n \\
  379. & ... \\
  380. 1 & x_n & x_n^2 & ... & x_n^n \\
  381. \end{pmatrix}
  382. \end{align*}
  383. \ARROW Now the only thing one needs to do is to solve:
  384. \begin{align*}
  385. \begin{pmatrix}
  386. 1 & x_0 & x_0^2 & ... & x_0^n \\
  387. 1 & x_1 & x_1^2 & ... & x_1^n \\
  388. & ... \\
  389. 1 & x_n & x_n^2 & ... & x_n^n \\
  390. \end{pmatrix}
  391. \begin{pmatrix}
  392. a_0\\
  393. a_1\\
  394. ...\\
  395. a_n
  396. \end{pmatrix}=
  397. \begin{pmatrix}
  398. y_0\\
  399. y_1\\
  400. ...\\
  401. y_n
  402. \end{pmatrix}
  403. \end{align*}
  404. \ARROW Because the natural base is wrongly conditioned the increase of the interpolation points significantly increases the condition parameter.
  405.  
  406. \end{small}
  407.  
  408. \end{frame}
  409.  
  410.  
  411. \begin{frame}\frametitle{Lagrange interpolation}
  412. \begin{small}
  413. \ARROW Now let's choose a better base function that are given by:
  414. \begin{align}
  415. \label{eq:langrange}
  416. l_i(x)= \prod_{j=0,~j \neq i}^n \frac{x-x_j}{x_i-x_j} = \frac{(x-x_0)(x-x_1)...(x-x_n)}{(x_i-x_0)(x_i-x_1)...(x_i-x_n)}
  417. \end{align}
  418. \ARROW It is easy to notice:
  419. \begin{align*}
  420. l_i(x_j)=\begin{cases}
  421. 0~~~i \neq j \\
  422. 1~~~i=j
  423. \end{cases}
  424. \end{align*}
  425. \ARROW Now putting this into base matrix we get:
  426. \begin{align*}
  427. \begin{pmatrix}
  428. 1 & 0 & 0 & ... & 0 \\
  429. 0 & 1 & 0 & ... & 0 \\
  430. & ... \\
  431. 0 & 0 & 0 & ... & 1 \\
  432. \end{pmatrix}
  433. \begin{pmatrix}
  434. a_0\\
  435. a_1\\
  436. ...\\
  437. a_n
  438. \end{pmatrix}=
  439. \begin{pmatrix}
  440. y_0\\
  441. y_1\\
  442. ...\\
  443. y_n
  444. \end{pmatrix}
  445. \end{align*}
  446. \ARROW Now this is something we like :) The interpolating function then takes the form:
  447. \begin{align*}
  448. F(x)=L_n(x)=\sum_{i=0}^n y_i l_i(x)
  449. \end{align*}
  450.  
  451. \end{small}
  452. \end{frame}
  453.  
  454.  
  455.  
  456. \begin{frame}\frametitle{Lagrange interpolation - the algorithm}
  457. \begin{small}
  458. \begin{enumerate}
  459. \item Get the input data $(x_i,y_i),~i=0,...,n$.
  460. \item The coefficients of the polynomial are $y_i$.
  461. \item Calculate the base functions from Eq.~\ref{eq:langrange}.
  462. \item Put everything together to get the $L_n$ Lagrange polynomial.
  463. \end{enumerate}
  464. \begin{alertblock}{Disadvantage:}
  465. The problem with this method is the fact that if you add another interpolation point you need to start over and recalculate everything.
  466. \end{alertblock}
  467.  
  468. \begin{exampleblock}{Advantege}
  469. \only<1>{
  470. It is very popular and simple method. It is used in many different places: differential equations, numerical integrations, etc. Because of this the precision of the method depends on the precision of the interpolation is self:
  471. \begin{align*}
  472. \epsilon(x) = f(x) - F(x) = \frac{f^{(n+1}(\xi) }{(n+1)!} \omega_n(x)
  473. \end{align*}
  474. }
  475. \only<2>{
  476. where:\\
  477. $\omega_n(x)=(x-x_0)(x-x_1)...(x-x_n)$\\
  478. $f$ function of class $C^{n+1}$ on $\left [a,b\right]$\\
  479. $\xi$ average values.h
  480. }
  481. \end{exampleblock}
  482.  
  483.  
  484. \end{small}
  485. \end{frame}
  486.  
  487.  
  488.  
  489. \begin{frame}\frametitle{Newton interpolation}
  490. \begin{small}
  491. \ARROW Sir Isaac Newton proposed a different base for the problem:
  492. \begin{align*}
  493. p_0(x) & =1\\
  494. p_1(x) & =(x-x_0)\\
  495. p_2(x) & =(x-x_0)(x-x_1)\\
  496. ...\\
  497. p_n(x) & =(x-x_0)(x-x_1)...(x-x_n)
  498. \end{align*}
  499. \only<1>{
  500. \ARROW Using the above functions the basis matrix takes a nice form:
  501. \begin{align*}
  502. V=\begin{pmatrix}
  503. 1 & 0 & 0 & ... & 0 \\
  504. 1 & p_1(x_1) & 0 & ... & 0 \\
  505. & ... \\
  506. 1 & p_1(x_n) & p_2(x_n) & ... & p_n(x_n) \\
  507. \end{pmatrix}
  508. \end{align*}
  509. }
  510. \only<2>{
  511. \ARROW And the linear equation system:
  512. \begin{align*}
  513. \begin{pmatrix}
  514. 1 & 0 & 0 & ... & 0 \\
  515. 1 & p_1(x_1) & 0 & ... & 0 \\
  516. & ... \\
  517. 1 & p_1(x_n) & p_2(x_n) & ... & p_n(x_n) \\
  518. \end{pmatrix}
  519. \begin{pmatrix}
  520. a_0\\
  521. a_1\\
  522. ...\\
  523. a_n
  524. \end{pmatrix}
  525. =
  526. \begin{pmatrix}
  527. y_0\\
  528. y_1\\
  529. ...\\
  530. y_n
  531. \end{pmatrix}
  532. \end{align*}
  533.  
  534.  
  535. }
  536. \end{small}
  537. \end{frame}
  538.  
  539.  
  540.  
  541. \begin{frame}\frametitle{Newton interpolation}
  542. \begin{small}
  543. \ARROW We can solve the aforementioned system by noticing that $a_0$ depends only on $y_0$, $a_1$ depends on $y_0$ and $y_1$, etc.\\
  544. \ARROW They can be calculated using difference quotient:
  545. \begin{align*}
  546. f\left[ x_0,x_1 \right] =\frac{y_1-y_0}{x_1-x_0},~~f\left[ x_1,x_2 \right] =\frac{y_2-y_1}{x_2-x_1}, \rm~etc.
  547. \end{align*}
  548. \begin{align*}
  549. f\left[ x_0,x_1, x_2 \right] = \frac{ f\left[ x_1,x_2 \right]- f\left[x_0,x_1 \right] }{x_2-x_1}
  550. \end{align*}
  551. \ARROW In general:
  552. \begin{align*}
  553. f\left[ x_i,x_{i+1},..., x_{i+k} \right] = \frac{ f\left[ x_{i+1},x_{i+2},...,x_{i+k} \right] - f\left[ x_{i},x_{i+1},...,x_{i+k-1} \right]}{x_{i+k}-x_i}
  554. \end{align*}
  555. \ARROW Using difference quotient we can calculate the coefficients:
  556. \begin{align*}
  557. a_i=f\left[x_0,x_1,...,x_i\right]
  558. \end{align*}
  559. \end{small}
  560. \end{frame}
  561.  
  562.  
  563.  
  564. \begin{frame}\frametitle{Newton interpolation, the algorithm}
  565. \begin{small}
  566.  
  567. \begin{itemize}
  568. \item We read the input interpolating points: $(x_i,y_i)$, $i=0,1,....,n$.
  569. \item Calculate the polynomial coefficients in an iterative way.
  570. \item Calculate the base functions.
  571. \item Put things together to get the Newton interpolation polynomial.
  572. \end{itemize}
  573.  
  574. \begin{exampleblock}{Why do we bother?}
  575. \ARROWR Despite the procedure seems more complicated then the Lagrange interpolation it has a huge advantage: adding one more interpolation point does require to repeat the whole procedure, but we can reuse the previous steps.
  576. \end{exampleblock}
  577.  
  578. \end{small}
  579. \end{frame}
  580. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  581. \begin{frame}\frametitle{Runge oscillation}
  582. \begin{small}
  583.  
  584. \ARROW If one has many points one needs to use a high order polynomial.\\
  585. \ARROW The problem with high order polynomials is that they start oscilationg at the edges $\mapsto$ so-called Runge oscillations.
  586.  
  587. \begin{center}
  588. \includegraphics[width=0.75\textwidth]{images/Runge.png}
  589. \end{center}
  590.  
  591. \ARROW Danny will tell you more about this next lecture.
  592.  
  593. \end{small}
  594. \end{frame}
  595. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  596. \begin{frame}\frametitle{First degree spline function}
  597. \begin{small}
  598.  
  599. \ARROW Till now using couple numerical methods we were able to calculate coefficients of a big single polynomial equation.\\
  600. \ARROW Now we are smarter then Newton and Lagrange were over 300 years ago!\\
  601. \ARROW We can use several interpolating functions and then glue them (splice) them together!\\
  602. \ARROW In order to do so we divide the domain of the $F$ function $\left[ a,b \right]$ into:
  603. \begin{align*}
  604. a=x_0<x_1<x_2<...<x_n=b
  605. \end{align*}
  606. \ARROW The simplest is to use linear functions:
  607. \begin{align*}
  608. s(x)=\begin{cases}
  609. s_0(x)~~~~x \in \left[x_0,x_1 \right)\\
  610. s_1(x)~~~~x \in \left[x_1,x_2 \right)\\
  611. ...\\
  612. s_{n-1}(x)~~~~x \in \left[x_{n-1},x_n \right),
  613. \end{cases}
  614. \end{align*}
  615. where
  616. \begin{align*}
  617. s_k(x)=a_{k,0}+a_{k,1}(x-x_k)~~x \in \left[ x_k, x_{k+1} \right)
  618. \end{align*}
  619.  
  620. \end{small}
  621. \end{frame}
  622.  
  623.  
  624. \begin{frame}\frametitle{First degree spline function}
  625. \begin{small}
  626.  
  627. \ARROW The above defined functions $s_k(x)$ need to obey the conditions:
  628. \begin{align*}
  629. s_k(x_k ) & = y_k\\
  630. s_k(x_{k+1}) & = s_{k+1}(x_{k+1})
  631. \end{align*}
  632. \ARROW From the above we can calculate the linear equation coefficients:
  633. \begin{align*}
  634. a_{k,0} & =y_k\\
  635. a_{k,1} & =\frac{y_{k+1} - y_k}{x_{k+1}-x_k}
  636. \end{align*}
  637.  
  638. \begin{exampleblock}{Advantage:}
  639. \ARROWR The biggest advantage of this method is it's simplicity. If you have a large number of interpolating points that are ''densely '' packed you can get very good and fast aproximation with this function.
  640. \end{exampleblock}
  641.  
  642. \begin{alertblock}{Disadvantage:}
  643. \ARROW The interpolating function is not smooth on the interpolation points.
  644. \end{alertblock}
  645.  
  646. \end{small}
  647. \end{frame}
  648.  
  649. \begin{frame}\frametitle{Third degree spline function}
  650. \begin{small}
  651. \ARROW As mentioned before the first degree spline function suffer from the continuity problem. \\
  652. \ARROW A solution would be to use the higher order polynomials to aproximate the function. For example the 3rd order:
  653. \begin{align*}
  654. s_k(x)=a_{k,0} + a_{k,1}(x-x_k)+ a_{k,2}(x-x_k)^2 + a_{k,3}(x-x_k)^3,~~~~x \in \left[x_k,x_{k+1} \right)
  655. \end{align*}
  656. \ARROW Now this polynomial needs to obey conditions:
  657. \begin{align*}
  658. s_k(x_k)&=y_k\\
  659. s_k(x_{k+1})& = s_{k+1}(x_{k+1})\\
  660. s^{\prime}_k(x_{k+1})& = s^{\prime}_{k+1}(x_{k+1})\\
  661. s^{\prime\prime}_k(x_{k+1})& = s^{\prime\prime}_{k+1}(x_{k+1})
  662. \end{align*}
  663. \ARROW In total we will have $4n$ coefficients to find. But we will only have $4n-2$ equations.\\
  664. \ARROW To solve the system we need to assume somethings about the endpoints (there are many options here).\\
  665. \ARROW The most popular ones are:
  666. \begin{align*}
  667. &s^{\prime}(a)=f^{\prime}(a)~~~~s^{\prime}(b)=f^{\prime}(b)~~~~ {\rm or}\\
  668. &s^{\prime\prime}(a)=s^{\prime\prime}(b)=0
  669. \end{align*}
  670.  
  671.  
  672. \end{small}
  673. \end{frame}
  674.  
  675.  
  676. \begin{frame}\frametitle{Third degree spline function}
  677. \begin{small}
  678. \ARROW Now to efficiently solve the system we will define temporary variables:
  679. \begin{align*}
  680. h_k&=x_{k+1}-x_k\\
  681. d_k&=\frac{y_{k+1}-y_k}{h_k}\\
  682. m_k&=s^{\prime\prime}(x_k)
  683. \end{align*}
  684. \ARROW Now the second derivative can be interpolated using the Lagrange polynomial:
  685. \begin{align*}
  686. s_k^{\prime\prime}(x)=s^{\prime\prime}(x)\frac{x-x_{k+1}}{x_{k}-x_{k+1}}+s^{\prime\prime}(x)\frac{x-x_{k}}{x_{k+1}-x_{k}}=\frac{m_k}{h_k}(x_{k+1}-x) + \frac{m_{k+}}{h_k}(x-x_k)
  687. \end{align*}
  688. \ARROW Now if we integrate the above equation (two times):
  689. \begin{align*}
  690. s_k^{\prime}(x)=-\frac{m_k}{2h_k}(x_{k+1}-x)^2 + \frac{m_{k+}}{2h_k}(x-x_k)^2 -p_k + q_k\\
  691. s_k(x)=\frac{m_k}{6h_k}(x_{k+1}-x)^3 + \frac{m_{k+1}}{3h_k}(x-x_k)^3+p_k(x_{k+1}-x)+q_k(x-x_k)
  692. \end{align*}
  693.  
  694. \end{small}
  695. \end{frame}
  696.  
  697.  
  698.  
  699. \begin{frame}\frametitle{Third degree spline function}
  700. \begin{small}
  701. \ARROW Now we need to calculate the $s_k(x)$ for $x_k$ and $x_{k+1}$ using relations: $s_k(x_k)=y_k$ and $s_k(x_k+1)=y_{k+1}$:
  702. \begin{align*}
  703. x_k(x_k) & =y_k = \frac{m_k}{6h_k}(x_{k+1}-x_k)^3 + p_k(x_{k+1}-x_k)\\
  704. x_k(x_{k+1}) & =y_{k+1} = \frac{m_{k+1}}{3h_k}(x_{k+1}-x_k)^3 + q_k (x_{k+1} -x_k)
  705. \end{align*}
  706. \ARROW From which we get:
  707. \begin{align*}
  708. p_k&=\frac{y_k}{h_k}-\frac{m_k h_k}{6}\\
  709. p_{k+1}&=\frac{y_{k+1}}{h_{k+1}}-\frac{m_{k+1} h_{k+1}}{6}
  710. \end{align*}
  711. \ARROW Putting all the things together:
  712. \begin{align}
  713. S_k(x)= &\frac{m_k}{6h_k} (x_k-x)^3 + \frac{m_{k+1}}{6h_k}(x-x_k)^3+ \left( \frac{y_k}{h_k} -\frac{m_k h_k}{6}\right) (x_{k+1}-x)\\ + & \left(\frac{y_{k+1}}{h_k} - \frac{m_{k+1} h_k}{6} \right) (x-x_k)
  714. \label{eq:almostthere}
  715. \end{align}
  716. \end{small}
  717. \end{frame}
  718.  
  719.  
  720. \begin{frame}\frametitle{Third degree spline function}
  721. \begin{small}
  722. \ARROW The only unknown in the above equation are the $m_i$ variables. To get those we need to use the equation: $S^{\prime}_{k-1}(x_k)=s^{\prime}(x_k)$:
  723. \begin{align*}
  724. -\frac{1}{3}m_k h_k - \frac{1}{6} m_{k+1}h_k + d_k = \frac{1}{3}m_k h_{k-1} + \frac{1}{6}m_{k-1}h_{k-1}+d_{k-1}
  725. \end{align*}
  726. \ARROW So the complete solution is:
  727. \begin{align*}
  728. a_{k,0}&=y_k\\
  729. a_{k,1}&=d_k -\frac{h_k}{6}(2m_k+m_{k+1})\\
  730. a_{k,2}&= \frac{m_k}{2}\\
  731. a_{k,3}&= \frac{m_{k+1}-m_k}{6 h_k}
  732. \end{align*}
  733. \ARROW To get the $m_0$ and $m_n$ one needs to use one of the aforementioned conditions.
  734.  
  735. \end{small}
  736. \end{frame}
  737.  
  738.  
  739. \begin{frame}\frametitle{Third degree spline function algorithm}
  740. \begin{small}
  741.  
  742. \begin{itemize}
  743. \item Get the input interpolation points.
  744. \item Calculate the temporary variables: $d_i, h_i$.
  745. \item Assume adequate conditions to get $m_0$, $m_n$.
  746. \item Solve linear equation system.
  747. \item Obtained values of the $a_{i,j}$ coefficients put in the interpolation equation.
  748. \end{itemize}
  749.  
  750.  
  751. \end{small}
  752. \end{frame}
  753.  
  754.  
  755.  
  756. \begin{frame}\frametitle{Summary}
  757. \begin{small}
  758.  
  759. \ARROW Interpolation playes essential role in almost all numerical methods!\\
  760. \ARROW Even very old algorithms like Lagrange are still used(we used it in splines).\\
  761. \ARROW There is a lot of algorithms on the market. From simple Lagrange and Newton interpolation algorithms up to modern splines.\\
  762. \ARROW The most common used today are spline. They require a bit of work but they work very effectively.\\
  763.  
  764.  
  765. \end{small}
  766. \end{frame}
  767.  
  768.  
  769. \backupbegin
  770.  
  771. \begin{frame}\frametitle{Backup}
  772.  
  773.  
  774. \end{frame}
  775.  
  776.  
  777.  
  778.  
  779.  
  780.  
  781.  
  782.  
  783.  
  784.  
  785. \backupend
  786. \end{document}