Go to file
Simon Klüttermann fe9966bcdc first commit 2022-03-31 16:46:30 +02:00
clock first commit 2022-03-31 16:46:30 +02:00
dics first commit 2022-03-31 16:46:30 +02:00
illustrations first commit 2022-03-31 16:46:30 +02:00
olddics first commit 2022-03-31 16:46:30 +02:00
topics first commit 2022-03-31 16:46:30 +02:00
README.md first commit 2022-03-31 16:46:30 +02:00
assigns.pdf first commit 2022-03-31 16:46:30 +02:00
assigns.png first commit 2022-03-31 16:46:30 +02:00
assigns.py first commit 2022-03-31 16:46:30 +02:00
beamercolorthemeTUDo.sty first commit 2022-03-31 16:46:30 +02:00
beamerfontthemeTUDo.sty first commit 2022-03-31 16:46:30 +02:00
beamerinnerthemeTUDo.sty first commit 2022-03-31 16:46:30 +02:00
beamerouterthemeTUDo.sty first commit 2022-03-31 16:46:30 +02:00
beamerthemeTUDo.sty first commit 2022-03-31 16:46:30 +02:00
bibliography.bib first commit 2022-03-31 16:46:30 +02:00
compile.sh first commit 2022-03-31 16:46:30 +02:00
config.tex first commit 2022-03-31 16:46:30 +02:00
configsupport.tex first commit 2022-03-31 16:46:30 +02:00
gentopic.py first commit 2022-03-31 16:46:30 +02:00
header.tex first commit 2022-03-31 16:46:30 +02:00
latexmkrc first commit 2022-03-31 16:46:30 +02:00
ls9.png first commit 2022-03-31 16:46:30 +02:00
shema.tex first commit 2022-03-31 16:46:30 +02:00
shema.tex_backup first commit 2022-03-31 16:46:30 +02:00
slides.aux first commit 2022-03-31 16:46:30 +02:00
slides.bbl first commit 2022-03-31 16:46:30 +02:00
slides.bcf first commit 2022-03-31 16:46:30 +02:00
slides.blg first commit 2022-03-31 16:46:30 +02:00
slides.log first commit 2022-03-31 16:46:30 +02:00
slides.nav first commit 2022-03-31 16:46:30 +02:00
slides.out first commit 2022-03-31 16:46:30 +02:00
slides.pdf first commit 2022-03-31 16:46:30 +02:00
slides.run.xml first commit 2022-03-31 16:46:30 +02:00
slides.snm first commit 2022-03-31 16:46:30 +02:00
slides.tex first commit 2022-03-31 16:46:30 +02:00
slides.toc first commit 2022-03-31 16:46:30 +02:00
slides.vrb first commit 2022-03-31 16:46:30 +02:00
summary.txt first commit 2022-03-31 16:46:30 +02:00

README.md

Benutzerhandbuch

Dieses Handbuch dokumentiert die Installation und Nutzung der AQUA-Vorlage für Präsentationen mit der LaTeX Beamer Class. Ergänzungen an Handbuch und Vorlage sind immer willkommen und können gerne per EMail eingereicht werden.

Voraussetzungen

Um die Vorlage zu nutzen, sind mehrere Komponenten nötig, die vom Nutzer installiert werden müssen.

TeX

Die Vorlage ist zur Verwendung mit einer aktuellen TeX-Distribution gedacht und wird nicht mit alten TeX-Compilern oder -Paketen funktionieren. Empfohlen wird eine der folgenden Distributionen:

  • MacTeX 2019 oder höher für Mac OS
  • MiKTeX für Windows oder Linux
  • TeXLive 2019 oder höher für Windows oder Linux

Wichtig ist, dass die vollständige TeX-Distribution installiert wird. Insbesondere in Linux-Distributionen ist es möglich, nur einen Teil der Distribution zu installieren. In diesem Fall funktioniert die Vorlage nicht und die fehlenden Teile müssen installiert werden.

Unter Linux-Distributionen wie Ubuntu werden leider oft nur veraltete TeXLive-Versionen durch die Paketverwaltung bereitgestellt. In diesem Fall ist ein Update des Betriebssystems nötig oder TeXLive muss manuell installiert werden. Für Debian und Ubuntu stellt die TUG dazu einen Leitfaden bereit.

Pygments

Zum Setzen von Quellcode müssen das Python-Paket Pygments (sowie ein Python-Interpreter) auf dem System installiert sein. Pygments übernimmt dann das Parsen und syntaktische Auszeichnen der Codeelemente.

Auf Linux-Distributionen sollte das Paket durch den Paketmanager installiert werden, hier ist darauf zu achten, dass das Programm pygmentize ebenfalls installiert wird (einige Distributionen trennen Bibliothek und Programm).

Auf anderen Betriebssystemen ist die Verwendung des Python-Paketmanagers pip notwendig. Dazu wird auf einer Kommandozeile pip install Pygments ausgeführt.

Kompilieren des Dokumentes

Das Kompilieren eines TeX-Dokuments erfordert mehrere Schritte, um u.A. Hilfsdateien zu erzeugen, zu verarbeiten und Referenzen im Text korrekt aufzulösen. Üblicherweise wird dazu die lokale TeX-Installation genutzt, es existieren aber auch Alternativen.

Lokale TeX-Installation

Viele TeX-Editoren wie TeXStudio automatisieren den Kompiliervorgang, ohne dass weitere Konfiguration nötig ist. In TeXStudio ist es allerdings nötig, die Erzeugung des Glossars manuell durchzuführen.

Zur Automatisierung des Kompiliervorgangs sind bereits folgende Werkzeuge eingerichtet, die mit TeXLive ausgeliefert werden:

  1. Arara wird über % arara:-Direktiven in der thesis.tex konfiguriert. In der mitgelieferten Konfiguration wird allerdings bei jedem Kompiliervorgang jeder Schritt durchgeführt, was zu langen Bauzeiten führt. Im Wurzelverzeichnis der Vorlage kann ein Bauvorgang mit arara thesis ausgelöst werden.
  2. Latexmk wird in der latexmkrc konfiguriert und ist selbstständig in der Lage, den Kompiliervorgang auf notwendige Schritte zu reduzieren. Im Wurzelverzeichnis der Vorlage kann ein Bauvorgang mit latexmk ausgelöst werden.

Manuelles Kompilieren der Vorlage erfordert folgende Schritte im Wurzelverzeichnis der Vorlage:

  1. lualatex --shell-escape slides kompiliert das Dokument. Hier ist zu beachten, dass der LuaLaTeX-Compiler genutzt wird, ein Kompilieren mit dem veralteten pdfLaTeX-Compiler ist nicht möglich. Die Option --shell-escape ermöglicht es, aus dem Dokument beliebige Programme aufzurufen. In der Vorlage wird dies nur zum Aufruf von pygmentize genutzt.
  2. biber slides verarbeitet die Bibliografie. Biber gehört zum modernen BibLaTeX-Paket, welches anstelle das alten BibTeX genutzt wird.
  3. lualatex --shell-escape slides kompiliert das Dokument erneut. In diesem Schritt werden die Bibliografie, der Glossar usw. korrekt eingebunden.
  4. lualatex --shell-escape slides kompiliert das Dokument ein letztes Mal, um alle Referenzen zu bereinigen.

Sollte sich die Bibliografie nicht geändert haben, kann auf die entsprechenden Schritte verzichtet werden. Auch können wiederholte Kompiliervorgänge eingespart werden, wenn sich Referenzen in einem früheren Schritt stabilisieren.

Nutzung von GitLab CI

Wenn die Arbeit auf einem GitLab (wie z.B. dem des LS14 entwickelt wird, kann die CI-Unterstützung des GitLabs benutzt werden, um die Versionsstände im Git zu bauen. Eine entsprechende Steuerdatei, die .gitlab-ci.yml, ist in der Vorlage enthalten. Die Vorlage muss dazu in der Wurzel des Git-Repositorys liegen.

Der Kompiliervorgang wird von Latexmk gesteuert. Veränderungen an der Latexmk-Konfiguration wirken sich also unmittelbar auf die CI-seitige Kompilierung aus.

Für andere CI-Systeme muss eine entsprechende Datei selber verfasst werden, entsprechende Patches sind willkommen.

Lokales Docker-Image

Das Docker-Image, welches zum CI-seitigen Kompilieren genutzt wird, kann auch lokal verwendet werden. Das Image umfasst allerdings mehrere GB und der Kompiliervorgang kann mehrere Minuten dauern. Eine lokale TeX-Installation ist also vorzuziehen.

Im Wurzelverzeichnis der Vorlage kann ein Docker-Bauvorgang mit docker run -v $(realpath .):/doc nopreserveroot/texlive-full latexmk ausgelöst werden, wobei statt $(realpath .) auch der absolute Pfad des aktuellen Verzeichnisses angegeben werden kann.

Konfigurieren der Metadaten

Die Metadaten des Dokumentes werden in der config.tex eingerichtet. Die Hilfsdatei configsupport.tex sollte dabei nicht verändert werden.

In der Datei werden zunächst die eigentlichen Metadaten definiert:

  • Der Title des Vortrags wird mit \settalktitle{Titel} definiert.
  • Der oder die Autoren können auf zwei Weisen definiert werden:
    • \settalkauthor{Autor} definiert einen einzelnen Autor und überschreibt dabei die bisherige Liste,
    • \addtalkauthor{Autor} fügt einen weiteren Autor hinzu. Dieses Kommando kann mehrfach benutzt werden.
  • Das Vortragsdatum wird via \settalkisodate{YYYY-MM-DD} gesetzt und muss dazu im ISO-Format YYYY-MM-DD angegeben werden.

Nun müssen noch die Daten des zugeordneten Lehrstuhls bzw. der betreuenden Arbeitsgruppe angegeben werden. Für die Arbeitsgruppe AQUA kann einfach der Befehl \aquaheader verwendet werden. Ansonsten müssen folgende Variablen gesetzt werden:

  • \setfaculty{Fakultät} definiert den Namen der Fakultät,
  • \setchair{Lehrstuhl} den des Lehrstuhles,
  • \setworkgroup{Arbeitsgruppe} den der Arbeitsgruppe (so vorhanden).

Als letztes wird ausgewählt, ob der Vortrag auf Deutsch (\germantalk) oder englisch (\englishtalk) verfasst wird.

Konfiguration und Nutzung der eingebundenen Pakete

Die Vorlage bindet in der header.tex eine große Menge Pakete ein und nimmt einige notwendige Konfigurationsschritte bereits vor. Es empfiehlt sich, die Handbücher der Pakete zumindest zu überfliegen. Dies kann über die aufgeführten Links geschehen, in einer vollständigen TeX-Installation können die Handbücher für ein Paket aber auch über den Befehl texdoc Paketname aufgerufen werden. In TeXstudio öffnet ein Control-Klick auf den Paketnamen die Dokumentation in der PDF-Vorschau.

Die Pakete und Konfigurationsoptionen sind hier in der Reihenfolge ihrer Verwendung in der header.tex aufgeführt.

  • beamer stellt das Grundgerüst des Dokumentes bereit. Dazu gehören Kommandos wie \section und das Format der Folien. Änderungen an der Konfiguration können in den Optionen der \documentclass vorgenommen werden. Folgende Pakete werden dabei mit geladen:
    • hyperref ermöglicht das Setzen von Hyperlinks und wandelt Referenzen automatisch in Hyperlinks um.
    • xcolor ermöglicht die farbige Gestaltung von Dokumenten. Die Option svgnames ermöglicht die Verwendung von SVG-Farbnamen.
  • fontspec dient zum Laden von Schriftarten. Konfiguration ist nicht nötig.
  • amsmath und unicode-math stellen mathematische Symbole bereit.
  • libertinus ersetzt die Standardschriftarten durch die Libertinus-Schriftenfamilie.
  • polyglossia dient zur Unterstützung nicht-englischer Dokumente. Das Kommando \languagesetup konfiguriert das Paket passend zur Schriftenauswahl in der config.tex.
  • datetime2 ist für die sprachspezifische Formatierung von Datumsangaben zuständig. Es wird primär innerhalb der Vorlage verwendet.
  • algorithm2e ermöglicht den Satz von Algorithmen in Pseudocode. Dazu stehen zahlreiche Konfigurationsoptionen bereit, auch die Verwendung deutscher Schlüsselwörter ist möglich.
  • authoraftertitle ermöglicht die Nutzung von Autor, Titel und Datum durch die Makros \MyAuthor, \MyTitle und \MyDate im Textkörper.
  • biblatex ist eine moderne Alternative zum Setzen von Literaturverzeichnissen und bietet zahllose Konfigurationsoptionen. Hier gilt es zu beachten, dass die von Verlagen bereitgestellten BibTeX-Exporte oft die Möglichkeiten von BibLaTeX nicht ausnutzen. Hier empfiehlt sich ein Nachbearbeiten des Exportes. Das Handbuch dokumentiert im Detail die möglichen Eintragstypen und Felder sowie Zitierkommandos. Eine Lektüre ist ratsam. Das zugehörige Kommandozeilentool ist biber.
  • booktabs stellt Kommandos bereits, um Tabellen für Druckerzeugnisse zu setzen. Üblicherweise missachten LaTeX-Tabellen gängige typographische Leitsätze durch zu geringe Abstände der Linien sowie die Verwendung vertikaler Linien. Das Handbuch dokumentiert die Verwendung und gibt eine Einführung in den korrekten Satz von Tabellen.
  • draftwatermark versieht Seiten mit einem Wasserzeichen. Das Paket wird standardmäßig nicht geladen, kann aber zusammen mit der Beispielkonfiguration einkommentiert werden, um ENTWURF α.1 in den Seitenhintergrund zu setzen. Dies kann helfen, Ausdrucke schnell auseinander zu halten.
  • graphicx ermöglicht das Einbinden diverser Grafikdateien in das Dokument.
  • microtype aktiviert die LaTeX-eigene Unterstützung für Mikrotypographie. Dabei werden unsichtbare Veränderungen der Schrift (z.B. Skalieren auf 99% der Breite) vorgenommen, um Silbentrennungen oder das Bedrucken des Seitenrandes zu vermeiden.
  • minted dient zum Satz von syntaktisch ausgezeichnetem Quellcode. Zur Verarbeitung des Quellcodes wird das Werkzeug Pygments genutzt.
  • mleftright stellt Makros \mleft und \mright bereit, die einige Probleme im mathematischen Textsatz mit \left und \right beseitigen.
  • pdfpages ermöglicht das Einbinden externer PDF-Dokumente als komplette Seite.
  • relsize stellt Befehle bereit, um die Schriftgröße relativ zur aktuell genutzten zu verändern.
  • tikz ermöglicht das programmatische Erzeugen komplexer Grafiken aus LaTeX heraus. Das Handbuch dokumentiert die Möglichkeiten des Paketes, im Internet lassen sich zahllose Beispiele für die Verwendung des Paketes finden. Wird der Befehl \tikzexternalize einkommentiert, werden TikZ-Grafiken in einem separaten Prozess gerendert und dann eingebunden. Dies funktioniert jedoch nicht, wenn ein Text z.B. eine Referenz oder einen Abkürzungsverweis enthält. Folgende Bibliotheken werden in der Vorlage aktiviert:
    • babel beseitigt einen Fehler in TikZ, der bei der Verwendung von Umlauten auftreten kann,
    • calc erweitert Koordinatenausdrücke um Berechnungen,
    • external erlaubt das externe Rendern von Bildern, um die Kompilation zu beschleunigen und
    • positioning erweitert die zulässige Syntax für relative Positionen.
  • pgfplots ermöglicht das Setzen von Diagrammen auf Basis von TikZ.
  • csquotes stellt den Befehl \enquote bereit, der korrekte Anführungszeichen für die gewählte Sprache um ein Stück Text setzt. Dies wird auch von biblatex genutzt.
  • \def\UrlBreaks{\do\/\do-} erlaubt das Umbrechen von URLs an / und -. Diese Liste kann nach Belieben erweitert werden.
  • Im Block % Neat + for et al wird das Plus-Zeichen für lange Autorenlisten (z.B. [ABC+03]) verkleinert. Eine ähnliche Technik lässt sich nutzen, um z.B. den Namen C++ zu setzen.
  • Die Blöcke % Remove algorithm captions, see examples und % Use minted's line numbers for algorithm2e vereinheitlichen die Gestaltung von Algorithmen und Quellcode.
  • Der Befehl \usemintedstyle wählt ein Farbschema für die Syntaxauszeichnung in Quellcode aus. friendly eignet sich zum Druck besser als die leuchtenden Standardfarben.
  • Der Befehl \addbibresource teilt biblatex die verwendeten Bibliographien mit. Standard ist die bibliography.bib.
  • Im Abschnitt % Internal metadata setup werden die in der config.tex gewählten Metadaten geladen.