Aktuelles PDF gibt's auch hier: https://flavigny.de/lecture/pdf/analysis2 zum bequemeren Lesen.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

253 line
7.3KB

  1. \ProvidesClass{lecture}
  2. \LoadClass[a4paper]{book}
  3. \RequirePackage[utf8]{inputenc}
  4. \RequirePackage[T1]{fontenc}
  5. \RequirePackage{textcomp}
  6. \RequirePackage[ngerman]{babel}
  7. \RequirePackage{amsmath, amssymb, amsthm}
  8. \RequirePackage{mdframed}
  9. \RequirePackage{geometry}
  10. \RequirePackage{import}
  11. \RequirePackage{pdfpages}
  12. \RequirePackage{transparent}
  13. \RequirePackage{xcolor}
  14. \RequirePackage{array}
  15. \RequirePackage[shortlabels]{enumitem}
  16. \RequirePackage{tikz}
  17. \RequirePackage{pgfplots}
  18. \RequirePackage[pagestyles, nobottomtitles]{titlesec}
  19. \RequirePackage{listings}
  20. \RequirePackage{mathtools}
  21. \RequirePackage{forloop}
  22. \RequirePackage{totcount}
  23. \RequirePackage[hidelinks, unicode]{hyperref} %[unicode, hidelinks]{hyperref}
  24. \RequirePackage{bookmark}
  25. \RequirePackage{wasysym}
  26. \RequirePackage{environ}
  27. \RequirePackage{stackrel}
  28. \usetikzlibrary{quotes, angles, math}
  29. \pgfplotsset{compat=1.15} % or \pgfplotsset{compat=newest}
  30. \geometry{
  31. bottom=35mm
  32. }
  33. %\DeclareOption*{\PassOptionsToClass{\CurrentOption}{article}}
  34. \DeclareOption{uebung}{
  35. \makeatletter
  36. \lhead{\@title}
  37. \rhead{\@author}
  38. \makeatother
  39. }
  40. \ProcessOptions\relax
  41. % PARAGRAPH no indent but skip
  42. \setlength{\parskip}{3mm}
  43. \setlength{\parindent}{0mm}
  44. \theoremstyle{definition}
  45. \newmdtheoremenv{satz}{Satz}[chapter]
  46. \newmdtheoremenv{lemma}[satz]{Lemma}
  47. \newmdtheoremenv{korollar}[satz]{Korollar}
  48. \newmdtheoremenv{definition}[satz]{Definition}
  49. \newtheorem{bsp}[satz]{Beispiel}
  50. \newtheorem{bem}[satz]{Bemerkung}
  51. \newtheorem{aufgabe}{Aufgabe}
  52. % enable aufgaben counting
  53. \regtotcounter{aufgabe}
  54. \newcommand{\N}{\mathbb{N}}
  55. \newcommand{\R}{\mathbb{R}}
  56. \newcommand{\Z}{\mathbb{Z}}
  57. \newcommand{\Q}{\mathbb{Q}}
  58. \renewcommand{\C}{\mathbb{C}}
  59. % HEADERS
  60. %\newpagestyle{main}[\small]{
  61. % \setheadrule{.55pt}%
  62. % \sethead[\thepage]% even-left
  63. % []% even-center
  64. % [\thechapter~\chaptertitle]% even-right
  65. % {\thesection~\sectiontitle}% odd-left
  66. % {}% odd-center
  67. % {\thepage}% odd-right
  68. %}
  69. %\pagestyle{main}
  70. \newcommand{\incfig}[1]{%
  71. \def\svgwidth{\columnwidth}
  72. \import{./figures/}{#1.pdf_tex}
  73. }
  74. \pdfsuppresswarningpagegroup=1
  75. % horizontal rule
  76. \newcommand\hr{
  77. \noindent\rule[0.5ex]{\linewidth}{0.5pt}
  78. }
  79. % punkte tabelle
  80. \newcommand{\punkte}{
  81. \@punkten{\totvalue{aufgabe}}
  82. }
  83. \def\@punkten#1{
  84. \newcounter{n}
  85. \begin{tabular}{|c|*{#1}{m{1cm}|}m{1cm}|@{}m{0cm}@{}}
  86. \hline
  87. Aufgabe
  88. \forloop{n}{1}{\not{\value{n} > #1}}{
  89. & \centering A\then
  90. }
  91. & \centering $\sum$ & \\[5mm] \hline
  92. Punkte
  93. \forloop{n}{1}{\not{\value{n} > #1}}{
  94. &
  95. }
  96. & & \\[5mm] \hline
  97. \end{tabular}
  98. }
  99. % code listings, define style
  100. \lstdefinestyle{mystyle}{
  101. commentstyle=\color{gray},
  102. keywordstyle=\color{blue},
  103. numberstyle=\tiny\color{gray},
  104. stringstyle=\color{black},
  105. basicstyle=\ttfamily\footnotesize,
  106. breakatwhitespace=false,
  107. breaklines=true,
  108. captionpos=b,
  109. keepspaces=true,
  110. numbers=left,
  111. numbersep=5pt,
  112. showspaces=false,
  113. showstringspaces=false,
  114. showtabs=false,
  115. tabsize=2
  116. }
  117. % activate my colour style
  118. \lstset{style=mystyle}
  119. % better stackrel
  120. \let\oldstackrel\stackrel
  121. \renewcommand{\stackrel}[3][]{%
  122. \oldstackrel[\mathclap{#1}]{\mathclap{#2}}{#3}
  123. }%
  124. % integral d sign
  125. \makeatletter \renewcommand\d[2][]{\ensuremath{%
  126. \,\mathrm{d}^{#1}#2\@ifnextchar^{}{\@ifnextchar\d{}{\,}}}}
  127. \makeatother
  128. % remove page before chapters
  129. \let\cleardoublepage=\clearpage
  130. %josua
  131. \newcommand{\norm}[1]{\left\Vert#1\right\Vert}
  132. % contradiction
  133. \newcommand{\contr}{\text{\Large\lightning}}
  134. % people seem to prefer varepsilon over epsilon
  135. \renewcommand{\epsilon}{\varepsilon}
  136. \ExplSyntaxOn
  137. % S-tackrelcompatible ALIGN environment
  138. % some might also call it the S-uper ALIGN environment
  139. % uses regular expressions to calculate the widest stackrel
  140. % to put additional padding on both sides of relation symbols
  141. \NewEnviron{salign}
  142. {
  143. \begin{align}
  144. \lec_insert_padding:V \BODY
  145. \end{align}
  146. }
  147. % starred version that does no equation numbering
  148. \NewEnviron{salign*}
  149. {
  150. \begin{align*}
  151. \lec_insert_padding:V \BODY
  152. \end{align*}
  153. }
  154. % some helper variables
  155. \tl_new:N \l__lec_text_tl
  156. \seq_new:N \l_lec_stackrels_seq
  157. \int_new:N \l_stackrel_count_int
  158. \int_new:N \l_idx_int
  159. \box_new:N \l_tmp_box
  160. \dim_new:N \l_tmp_dim_a
  161. \dim_new:N \l_tmp_dim_b
  162. \dim_new:N \l_tmp_dim_c
  163. \dim_new:N \l_tmp_dim_needed
  164. % function to insert padding according to widest stackrel
  165. \cs_new_protected:Nn \lec_insert_padding:n
  166. {
  167. \tl_set:Nn \l__lec_text_tl { #1 }
  168. % get all stackrels in this align environment
  169. \regex_extract_all:nnN { \c{stackrel}(\[.*?\])?{(.*?)}{(.*?)} } { #1 } \l_lec_stackrels_seq
  170. % get number of stackrels
  171. \int_set:Nn \l_stackrel_count_int { \seq_count:N \l_lec_stackrels_seq }
  172. \int_set:Nn \l_idx_int { 1 }
  173. \dim_set:Nn \l_tmp_dim_needed { 0pt }
  174. % iterate over stackrels
  175. \int_while_do:nn { \l_idx_int <= \l_stackrel_count_int }
  176. {
  177. % calculate width of text
  178. \hbox_set:Nn \l_tmp_box {$\seq_item:Nn \l_lec_stackrels_seq { \l_idx_int + 1 }$}
  179. \dim_set:Nn \l_tmp_dim_a {\box_wd:N \l_tmp_box}
  180. \hbox_set:Nn \l_tmp_box {$\seq_item:Nn \l_lec_stackrels_seq { \l_idx_int + 2 }$}
  181. \dim_set:Nn \l_tmp_dim_c {\box_wd:N \l_tmp_box}
  182. \dim_set:Nn \l_tmp_dim_a {\dim_max:nn{ \l_tmp_dim_c} {\l_tmp_dim_a}}
  183. % calculate width of relation symbol
  184. \hbox_set:Nn \l_tmp_box {$\seq_item:Nn \l_lec_stackrels_seq { \l_idx_int + 3 }$}
  185. \dim_set:Nn \l_tmp_dim_b {\box_wd:N \l_tmp_box}
  186. % check if 0.5*(a-b) > minimum padding, if yes updated minimum padding
  187. \dim_compare:nNnTF
  188. { 1pt * \dim_ratio:nn { \l_tmp_dim_a - \l_tmp_dim_b } { 2pt } } > { \l_tmp_dim_needed }
  189. { \dim_set:Nn \l_tmp_dim_needed { 1pt * \dim_ratio:nn { \l_tmp_dim_a - \l_tmp_dim_b } { 2pt } } }
  190. { }
  191. % increment list index by three, as every stackrel produces three list entries
  192. \int_incr:N \l_idx_int
  193. \int_incr:N \l_idx_int
  194. \int_incr:N \l_idx_int
  195. \int_incr:N \l_idx_int
  196. }
  197. % replace all relations with align characters (&) and add the needed padding
  198. \regex_replace_all:nnN
  199. { (\c{leq}&|&\c{leq}|\c{geq}&|&\c{geq}|\c{iff}&|&\c{iff}|\c{impliedby}&|&\c{impliedby}|\c{implies}&|&\c{implies}|\c{approx}&|&\c{approx}|\c{equiv}&|&\c{equiv}|=&|&=|\c{le}&|&\c{le}|\c{ge}&|&\c{ge}|&\c{stackrel}(\[.*?\])?{.*?}{.*?}|\c{stackrel}(\[.*?\])?{.*?}{.*?}&|&\c{neq}|\c{neq}&|>&|&>|<&|&<) }
  200. { \c{kern} \u{l_tmp_dim_needed} \1 \c{kern} \u{l_tmp_dim_needed} }
  201. \l__lec_text_tl
  202. \l__lec_text_tl
  203. }
  204. \cs_generate_variant:Nn \lec_insert_padding:n { V }
  205. \NewEnviron{leftright}
  206. {
  207. \lec_replace_parens:V \BODY
  208. }
  209. % function to replace parens with left right
  210. \cs_new_protected:Nn \lec_replace_parens:n
  211. {
  212. \tl_set:Nn \l__lec_text_tl { #1 }
  213. % replace all parantheses with \left( \right)
  214. \regex_replace_all:nnN { \( } { \c{left}( } \l__lec_text_tl
  215. \regex_replace_all:nnN { \) } { \c{right}) } \l__lec_text_tl
  216. \regex_replace_all:nnN { \[ } { \c{left}[ } \l__lec_text_tl
  217. \regex_replace_all:nnN { \] } { \c{right}] } \l__lec_text_tl
  218. \l__lec_text_tl
  219. }
  220. \cs_generate_variant:Nn \lec_replace_parens:n { V }
  221. \ExplSyntaxOff