mirror of
https://github.com/MartinThoma/LaTeX-examples.git
synced 2025-04-26 06:48:04 +02:00
more pseudocode
This commit is contained in:
parent
2274a07a62
commit
241e9ec502
4 changed files with 172 additions and 0 deletions
|
@ -0,0 +1,64 @@
|
|||
\documentclass{article}
|
||||
\usepackage[pdftex,active,tightpage]{preview}
|
||||
\setlength\PreviewBorder{2mm}
|
||||
|
||||
\usepackage[utf8]{inputenc} % this is needed for umlauts
|
||||
\usepackage[ngerman]{babel} % this is needed for umlauts
|
||||
\usepackage[T1]{fontenc} % this is needed for correct output of umlauts in pdf
|
||||
\usepackage{amssymb,amsmath,amsfonts} % nice math rendering
|
||||
\usepackage{braket} % needed for \Set
|
||||
\usepackage{algorithm,algpseudocode}
|
||||
|
||||
\begin{document}
|
||||
\begin{preview}
|
||||
\begin{algorithm}[H]
|
||||
\begin{algorithmic}
|
||||
\Function{Gauss}{$A \in \mathbb{R}^{n \times {n+1}}$}
|
||||
\For{($i=1$; $\;i \leq n$; $\;i$++)}
|
||||
\State // Search for maximum in this column
|
||||
\State $maxEl = |A_{i,i}|$
|
||||
\State $maxRow = i$
|
||||
\For{($k=i+1$; $\;k \leq n$; $\;k$++)}
|
||||
\If{$|A_{k,i}| > maxEl$}
|
||||
\State $maxEl = A_{k,i}$
|
||||
\State $maxRow = k$
|
||||
\EndIf
|
||||
\EndFor
|
||||
\\
|
||||
\State // Swap maximum row with current row
|
||||
\For{($k=i$; $\;k \leq n$; $\;k$++)}
|
||||
\State $tmp = A_{maxRow,k}$
|
||||
\State $A_{maxRow,k} = A_{i,k}$
|
||||
\State $A_{i,k} = tmp$
|
||||
\EndFor
|
||||
\\
|
||||
\State // Make all rows below this one 0 in current column
|
||||
\For{($k=i+1$; $\;k \leq n$; $\;k$++)}
|
||||
\State $c = -\frac{A_{k,i}}{A_{i,i}}$
|
||||
\For{($j=i$; $\;j \leq n$; $\;j$++)}
|
||||
\If{$i == j$}
|
||||
\State $A_{k,j} = 0$
|
||||
\Else
|
||||
\State $A_{k,j} += c \cdot A_{i,j}$
|
||||
\EndIf
|
||||
\EndFor
|
||||
\EndFor
|
||||
\EndFor
|
||||
\\
|
||||
\State // Solve equation for an upper triangular matrix
|
||||
\State $x = \Set{0} \in \mathbb{R^n}$
|
||||
\For{($i=n$; $\;i \geq 1$; $\;i$-\--)}
|
||||
\State $x_i = \frac{A_{i,n+1}}{A_{i,i}}$
|
||||
\For{($k=i-1$; $\;k \geq 1$; $\;k$-\--)}
|
||||
\State $A_{k,n+1} -= A_{k,i} \cdot x_{i}$
|
||||
\EndFor
|
||||
\EndFor
|
||||
\\
|
||||
\State \Return $x$
|
||||
\EndFunction
|
||||
\end{algorithmic}
|
||||
\caption{Gaussian elimination}
|
||||
\label{alg:seq1}
|
||||
\end{algorithm}
|
||||
\end{preview}
|
||||
\end{document}
|
35
source-code/Pseudocode/Gaussian-elimination/Makefile
Normal file
35
source-code/Pseudocode/Gaussian-elimination/Makefile
Normal file
|
@ -0,0 +1,35 @@
|
|||
SOURCE = Gaussian-elimination
|
||||
DELAY = 80
|
||||
DENSITY = 300
|
||||
WIDTH = 500
|
||||
|
||||
make:
|
||||
pdflatex $(SOURCE).tex -output-format=pdf
|
||||
make clean
|
||||
|
||||
clean:
|
||||
rm -rf $(TARGET) *.class *.html *.log *.aux *.data *.gnuplot
|
||||
|
||||
gif:
|
||||
pdfcrop $(SOURCE).pdf
|
||||
convert -verbose -delay $(DELAY) -loop 0 -density $(DENSITY) $(SOURCE)-crop.pdf $(SOURCE).gif
|
||||
make clean
|
||||
|
||||
png:
|
||||
make
|
||||
make svg
|
||||
inkscape $(SOURCE).svg -w $(WIDTH) --export-png=$(SOURCE).png
|
||||
|
||||
transparentGif:
|
||||
convert $(SOURCE).pdf -transparent white result.gif
|
||||
make clean
|
||||
|
||||
svg:
|
||||
make
|
||||
#inkscape $(SOURCE).pdf --export-plain-svg=$(SOURCE).svg
|
||||
pdf2svg $(SOURCE).pdf $(SOURCE).svg
|
||||
# Necessary, as pdf2svg does not always create valid svgs:
|
||||
inkscape $(SOURCE).svg --export-plain-svg=$(SOURCE).svg
|
||||
rsvg-convert -a -w $(WIDTH) -f svg $(SOURCE).svg -o $(SOURCE)2.svg
|
||||
inkscape $(SOURCE)2.svg --export-plain-svg=$(SOURCE).svg
|
||||
rm $(SOURCE)2.svg
|
Loading…
Add table
Add a link
Reference in a new issue