lysa.ltx 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426
  1. \documentclass[12pt]{book}
  2. % Append yourself to this list. Aliases are fine (e.g. darkf), but please do
  3. % include an email where people can email you. If applicable, also include your
  4. % middle initial, as is the convention in academia.
  5. \author{
  6. \pharpend
  7. }
  8. \newcommand{\editors}{
  9. \aneditor{Randy Brown}{randy@beingbrown.net}
  10. \aneditor{Nick Chambers}{DTSCode@gmail.com}
  11. \aneditor{Anton Golov}{jesyspa@gmail.com}
  12. \aneditor{Ng Wei En}{wei2912.supp0rt@gmail.com}
  13. \aneditor{Ben Z RF}{benzrf@benzrf.com}
  14. \aneditor{Alexander G Bauer}{sasha@crofter.org}
  15. }
  16. \usepackage{amsmath}
  17. \usepackage{amsfonts}
  18. \usepackage{amssymb}
  19. \usepackage{amsthm}
  20. \usepackage[toc,page]{appendix}
  21. \usepackage[backend=bibtex]{biblatex}
  22. % \usepackage[english]{babel}
  23. \usepackage[scaled]{beramono}
  24. \usepackage{centernot}
  25. \usepackage[mathcal,mathscr]{euscript}
  26. \usepackage[answerdelayed]{exercise}
  27. \usepackage[T1]{fontenc}
  28. \usepackage{graphics}
  29. \usepackage[utf8]{inputenc}
  30. \usepackage{listings}
  31. \usepackage{mathtools}
  32. \usepackage{relsize}
  33. \usepackage{mathptmx}
  34. \usepackage{scrextend}
  35. \usepackage{setspace}
  36. \usepackage{solarized-light}
  37. \usepackage{tabu}
  38. \usepackage{ulem}
  39. \usepackage{url}
  40. \usepackage{xkeyval}
  41. \usepackage[hidelinks]{hyperref}
  42. \usepackage{cleveref}
  43. \crefname{chapter}{\S}{\S}
  44. \crefname{section}{\S}{\S}
  45. \crefname{subsection}{\S}{\S}
  46. \crefname{subsubsection}{\S}{\S}
  47. \crefname{paragraph}{\S}{\S}
  48. \Crefname{chapter}{\S}{\S}
  49. \Crefname{section}{\S}{\S}
  50. \Crefname{subsection}{\S}{\S}
  51. \Crefname{subsubsection}{\S}{\S}
  52. \Crefname{paragraph}{\S}{\S}
  53. \crefname{Exercise}{ex.}{ex.}
  54. \Crefname{Exercise}{Ex.}{Ex.}
  55. \addbibresource{lysa.bib}
  56. \usepackage{listings}
  57. \usepackage{color}
  58. \definecolor{mygreen}{rgb}{0.3,0.6,0.3}
  59. \definecolor{mygray}{rgb}{0.8,0.8,0.8}
  60. \definecolor{mymauve}{rgb}{0.58,0,0.82}
  61. \lstset{ %
  62. % backgroundcolor=\color{white}, % choose the background color; you must add \usepackage{color} or \usepackage{xcolor}
  63. basicstyle=\footnotesize\ttfamily, % the size of the fonts that are used for the code
  64. breakatwhitespace=false, % sets if automatic breaks should only happen at whitespace
  65. breaklines=false, % sets automatic line breaking
  66. captionpos=b, % sets the caption-position to bottom
  67. commentstyle=\color{mygreen}, % comment style
  68. deletekeywords={...}, % if you want to delete keywords from the given language
  69. escapeinside={\%*}{*)}, % if you want to add LaTeX within your code
  70. extendedchars=true, % lets you use non-ASCII characters; for 8-bits encodings only, does not work with UTF-8
  71. frame=single, % adds a frame around the code
  72. keepspaces=true, % keeps spaces in text, useful for keeping indentation of code (possibly needs columns=flexible)
  73. % keywordstyle=\color{blue}, % keyword style
  74. % Actually, we are using Idris, but Haskell is close enough
  75. % language=\null, % the language of the code
  76. % morekeywords={*,...}, % if you want to add more keywords to the set
  77. numbers=left, % where to put the line-numbers; possible values are (none, left, right)
  78. numbersep=5pt, % how far the line-numbers are from the code
  79. numberstyle=\footnotesize\ttfamily, % the style that is used for the line-numbers
  80. rulecolor=\color{mygray}, % if not set, the frame-color may be changed on line-breaks within not-black text (e.g. comments (green here))
  81. showspaces=false, % show spaces everywhere adding particular underscores; it overrides 'showstringspaces'
  82. showstringspaces=false, % underline spaces within strings only
  83. showtabs=false, % show tabs within strings adding particular underscores
  84. stepnumber=1, % the step between two line-numbers. If it's 1, each line will be numbered
  85. % stringstyle=\color{mymauve}, % string literal style
  86. tabsize=2, % sets default tabsize to 2 spaces
  87. title=\lstname, % show the filename of files included with \lstinputlisting; also try caption instead of title
  88. caption=\lstname , % show the filename of files included with \lstinputlisting; also try caption instead of title
  89. }
  90. % Print-friendly links
  91. % \newcommand{\anauthor}[2]
  92. % {#1 {\href{mailto:#2}<{\tt #2}>} \\
  93. % }
  94. \newcommand{\aneditor}[2]{#1 {\href{mailto:#2}{<{#2}>}}}
  95. \let\anauthor\aneditor
  96. \newcommand{\btrurl}[1]{{\footnotesize\url{#1}}}
  97. \newcommand{\link}[2]{#2 (\btrurl{#1})}
  98. % Section & Chapter he
  99. \newcommand{\ch}[1]{\chapter{#1}\label{ch: #1}}
  100. \newcommand{\s}[1]{\section{#1}\label{s: #1}}
  101. \renewcommand{\ss}[1]{\subsection{#1}\label{ss: #1}}
  102. \newcommand{\sss}[1]{\subsubsection{#1}\label{sss: #1}}
  103. \newcommand{\pg}[2]{\paragraph{#1}\label{pg: #1}}
  104. % Math shortcuts
  105. \newcommand{\N}{\mathbb{N}}
  106. \newcommand{\R}{\mathbb{R}}
  107. \newcommand{\Z}{\mathbb{Z}}
  108. \renewcommand{\emptyset}{\varnothing}
  109. % \newcommand{\nil}{\varnothing}
  110. \newcommand{\nil}{\emptyset}
  111. \newcommand{\subof}{\subset}
  112. \newcommand{\subeq}{\subseteq}
  113. \newcommand{\subofnm}{$\subset$}
  114. \newcommand{\subeqnm}{$\subseteq$}
  115. \newcommand{\supof}{\supset}
  116. \newcommand{\supeq}{\supseteq}
  117. \newcommand{\supofnm}{$\supset$}
  118. \newcommand{\supeqnm}{$\supseteq$}
  119. \newcommand{\mset}[1]{\left\{\,#1\,\right\}}
  120. \newcommand{\parens}[1]{\left(#1\right)}
  121. \newcommand{\brackets}[1]{\left[\,#1\,\right]}
  122. \newcommand{\Qimplies}{\stackrel{?}{\implies}}
  123. \newcommand{\Qimpliedby}{\stackrel{?}{\impliedby}}
  124. \newcommand{\comma}{,\,}
  125. \newcommand{\notimplies}{\centernot\implies}
  126. \newcommand{\notimpliedby}{\centernot\impliedby}
  127. \newcommand{\notiff}{\centernot\iff}
  128. \newcommand{\Qin}{\stackrel{?}{\in}}
  129. \newcommand{\Qiff}{\stackrel{?}{\iff}}
  130. \newcommand{\truenm}{$\true$}
  131. \newcommand{\falsenm}{$\false$}
  132. \newcommand{\true}{\mathrm{True}}
  133. \newcommand{\false}{\mathrm{False}}
  134. \newcommand{\bigand}[1]{\land\brackets{#1}}
  135. \newcommand{\semicolon}{;\;}
  136. \newcommand{\mlist}[1]{\left(\,#1\,\right)}
  137. \newcommand{\sfall}{\semicolon\forall}
  138. \newcommand{\ld}[1]{\lambda\mlist{#1} \to}
  139. \newcommand{\evalbf}[2]{\evalat{\mathbf{#1}}{#2}}
  140. \newcommand{\evalrm}[2]{\evalat{\mathrm{#1}}{#2}}
  141. \newcommand{\domain}{\evalbf{dom}}
  142. \let\dom\domain
  143. \newcommand{\codomain}{\evalbf{codom}}
  144. \let\codom\codomain
  145. \newcommand{\bool}{\mathbb{B}}
  146. \newcommand{\boolnm}{$\mathrm{\bool}$}
  147. \newcommand{\bracketset}[1]{\brackets{ #1 }}
  148. \newcommand{\evalat}[2]{#1 \parens{#2}}
  149. \newenvironment{alignmath}[1]
  150. {\begin{displaymath}\begin{array}{#1}}
  151. {\end{array}\end{displaymath}}
  152. \newenvironment{alignedmath}
  153. {\begin{alignmath}{l}}
  154. {\end{alignmath}}
  155. \newcommand{\lto}{\lambda\to}
  156. \newcommand{\arc} {\evalrm{arc}}
  157. \newcommand{\im} {\evalrm{im}}
  158. \newcommand{\preim}{\evalrm{preim}}
  159. \newcommand{\Set}{\mathbf{Set}}
  160. \newcommand{\Qsubof}{\stackrel{?}{\subof}}
  161. \newcommand{\Qsubeq}{\stackrel{?}{\subeq}}
  162. \newcommand{\Qsupof}{\stackrel{?}{\supof}}
  163. \newcommand{\Qsupeq}{\stackrel{?}{\supeq}}
  164. \newcommand{\notsubof}{\centernot{\subof}}
  165. \newcommand{\notsubeq}{\centernot{\subeq}}
  166. \newcommand{\notsupof}{\centernot{\supof}}
  167. \newcommand{\notsupeq}{\centernot{\supeq}}
  168. \newcommand{\superbracket}[2]{
  169. {
  170. ^{
  171. {#1}
  172. }
  173. \brackets{
  174. {#2}
  175. }
  176. }
  177. }
  178. \renewcommand{\ng}{`}
  179. \newcommand{\Q}{\mathbb{Q}}
  180. \newcommand{\evalateq}[2]{#1 {\bracketset{#2}}}
  181. % \renewcommand{\succ}[1]{\evalat{\mathrm{succ}}{x}}
  182. \newcommand{\semic}{;\;}
  183. \newcommand{\pharpend}{\anauthor{Peter Harpending}{peter@harpending.org}}
  184. \let\xti\textit %italicize
  185. \let\xtb\textbf %boldface
  186. \newcommand{\code}[1]{{\footnotesize\ttfamily #1}}
  187. \let\crappycode\code %boldface
  188. \let\terminal\code
  189. \let\term\xti
  190. \let\xtv\code
  191. \let\tilde\textasciitilde
  192. \let\mvec\mlist
  193. \setlength{\parskip}{2ex}
  194. \newenvironment{ExcList}
  195. {
  196. % \newpage
  197. \ss{Exercises}
  198. \begin{ExerciseList}
  199. }
  200. {
  201. \end{ExerciseList}
  202. % \newpage
  203. % \sss{Answers}
  204. % \shipoutAnswer
  205. % \newpage
  206. }
  207. \newenvironment{iquote}{\begin{quote}\it}{\end{quote}}
  208. \newcommand{\bugtracker}{\link{https://gitlab.com/lysa/lysa/issues/new}{bug tracker}}
  209. \newcommand{\emailme}{email me at \code{peter@harpending.org}}
  210. \lstnewenvironment{plainfile}[1][]
  211. {\noindent\minipage{\linewidth}\medskip
  212. \lstset{
  213. #1
  214. }}
  215. {\endminipage}
  216. \lstnewenvironment{haskell}[1][]
  217. {\noindent\minipage{\linewidth}\medskip
  218. \lstset{
  219. language=Haskell,
  220. #1
  221. }}
  222. {\endminipage}
  223. \lstnewenvironment{shellsession}[1][]
  224. {\lstset{
  225. numbers=none,
  226. #1
  227. }}
  228. {}
  229. \let\filepath\code
  230. \newcommand{\Qforall}{\stackrel{?}{\forall}}
  231. \newcommand{\Qexists}{\stackrel{?}{\exists}}
  232. \newcommand{\nilnm}{$\nil$}
  233. \newcommand{\nm}[1]{${#1}$}
  234. \newcommand{\fn}[2]{\ld{#1} {#2}}
  235. \let\n\eta
  236. \newcommand{\notexists}{\centernot\exists}
  237. \newcommand{\amb}{\mathscr{A}}
  238. \newcommand{\inamb}{\in\amb}
  239. \newcommand{\Qequiv}{\stackrel{?}{\equiv}}
  240. \let\eva\evalat
  241. \newcommand{\id}{\mathrm{id}}
  242. \newcommand{\inclgraph}{\includegraphics[width=0.8\textwidth]}
  243. \newcommand{\flip}{\mathrm{flip}}
  244. % \newcommand{\comp}{\mathrm{comp}}
  245. \newcommand{\compl}[1]{{#1}^c}
  246. \let\bs\setminus
  247. \newenvironment{rclmath}{\begin{alignmath}{rcl}}{\end{alignmath}}
  248. \newcommand{\answergraph}[1]{\begin{center}\inclgraph{{#1}}\end{center}}
  249. \let\cnot\centernot
  250. \newcommand{\notequiv}{\cnot\equiv}
  251. \let\union\cup
  252. \let\intersect\cap
  253. \newcommand{\ce}{:=}
  254. \newcommand{\termref}[2]{\term{#1} (\cref{#2})}
  255. \newcommand{\C}{\mathbb{C}}
  256. \let\of\circ
  257. \newcommand{\mtb}[1]{$\mathbf{#1}$}
  258. \let\st\semic
  259. \newcommand{\suc}{\mathscr{S}}
  260. \renewcommand{\succ}[1]{\eva{\suc}{#1}}
  261. \newcommand{\I}{\mathbb{I}}
  262. \newcommand{\Setof}{\eva{\Set}}
  263. \newcommand{\Class}{\mathbf{Class}}
  264. \newcommand{\Classof}{\eva{\Class}}
  265. \let\ntimes\cdot %ntimes= ``numeric times''
  266. \newcommand{\recip}{\frac{1}}
  267. \renewcommand{\ae}{\stackrel{\mathrm{c}}{=}}
  268. \newcommand{\alnull}{\aleph_0}
  269. \newcommand{\ngp}[1]{\ng{\parens{#1}}}
  270. \newcommand{\ngfrac}[2]{\ngp{\frac{#1}{#2}}}
  271. \newcommand{\fracil}[2]{#1 \div #2}
  272. \newcommand{\ngfracil}[2]{\ngp{\fracil{#1}{#2}}}
  273. \newcommand{\ngfracilpf}[2]{\ngp{\fracil{\parens{#1}}{#2}}}
  274. \renewcommand{\sin}[1]{\eva{\mathrm{sin}}{#1}}
  275. \renewcommand{\cos}[1]{\eva{\mathrm{cos}}{#1}}
  276. % Sage graphs
  277. \lstdefinestyle{sage}{float=h, language=Python}
  278. \newcommand{\sageinput}{\lstinputlisting[style=sage]}
  279. % \define@key{sagegraph}{source}{\sageinput{#1}}
  280. % \define@key{sagegraph}{caption}{\caption{#1}}
  281. % \define@key{sagegraph}{label}[\null]{\label{#1}}
  282. % \define@key{sagegraph}{position}[ht]{#1}
  283. % \newcommand{\sagegraph}[1]{
  284. % \begin{figure}[\KV@sagegraph@position]
  285. % \centering
  286. % \inclgraph{#1}
  287. % \KV@sagegraph@caption
  288. % \KV@sagegraph@label
  289. % \end{figure}
  290. % \KV@sagegraph@source
  291. % }
  292. \let\cleardoublepage\clearpage
  293. \newenvironment{rclproof}
  294. {\begin{proof}\begin{rclmath}}
  295. {\end{rclmath}\end{proof}}
  296. \newcommand{\ageqq}{\stackrel{\mathrm{c}}{\geqq}}
  297. \newcommand{\aleqq}{\stackrel{\mathrm{c}}{\leqq}}
  298. \newcommand{\agt}{\stackrel{\mathrm{c}}{>}}
  299. \newcommand{\alt}{\stackrel{\mathrm{c}}{>}}
  300. \newtheorem{theorem}{Theorem}
  301. \newtheorem{axiom}{Axiom}
  302. % ASIDE BOX, stolen from https://github.com/jambonrose/latex-code-example/blob/master/0_preamble.tex
  303. %
  304. % Copyright 2013, Andrew Pinkham
  305. %
  306. \usepackage[framemethod=TikZ]{mdframed}
  307. \definecolor{light-gray}{gray}{0.85}
  308. \newmdenv[ %
  309. usetwoside=false,%
  310. font=\footnotesize\it,
  311. nobreak=false,%
  312. roundcorner=0pt,%
  313. outerlinewidth=0.2pt,%
  314. linecolor=lightgray,%
  315. skipabove=12pt,%
  316. skipbelow=12pt,%
  317. % topmargin=24pt,%
  318. % bottommargin=24pt,%
  319. rightmargin=10pt,%
  320. leftmargin=10pt,%
  321. % innertopmargin=\baselineskip,%
  322. % innerbottommargin=\baselineskip,%
  323. innerrightmargin=10pt,%
  324. innerleftmargin=10pt,%
  325. backgroundcolor=light-gray,%
  326. ]{asidebox}
  327. % End of ASIDE BOX
  328. \newenvironment{aside}[1][Default]
  329. { %
  330. \begin{samepage} %
  331. \begin{asidebox}[frametitle=Aside - {#1}] %
  332. }
  333. {\end{asidebox}\end{samepage}}
  334. \title{Learn You Some Algebras for Glorious Good!}
  335. \begin{document}
  336. \maketitle
  337. \newpage
  338. \topskip0pt
  339. \vspace*{\fill}
  340. {\footnotesize
  341. \begin{center}
  342. Copyright © 2014-2015 \pharpend
  343. \end{center}
  344. % \noindent
  345. \begin{center}
  346. Permission is granted to copy, distribute and/or modify this document under
  347. the terms of the GNU Free Documentation License, Version 1.3 or any later
  348. version published by the Free Software Foundation; with no Invariant
  349. Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the
  350. license is included in \cref{gfdl}.
  351. \end{center}
  352. }
  353. \vspace*{\fill}
  354. % \newpage
  355. % \section*{Editors \& Noted Contributors}
  356. % \begin{addmargin}[4em]{2em}
  357. % \begin{tabular}{l l}
  358. % \editors
  359. % \end{tabular}
  360. % \end{addmargin}
  361. \newpage
  362. \tableofcontents
  363. \newpage
  364. \input{1-introduction.ltx}
  365. \input{2-boolean-algebra.ltx}
  366. \input{3-sets.ltx}
  367. \input{4-functions.ltx}
  368. \input{5-more-sets.ltx}
  369. % Citations
  370. % \nocite{lyah}
  371. % \nocite{jobs-programming}
  372. % \nocite{w-functions}
  373. % \nocite{landau-analysis}
  374. % \nocite{expeditions}
  375. % \nocite{axler-linalg}
  376. % \nocite{taylor-analysis}
  377. % \nocite{hungerford}
  378. % \nocite{mathstats}
  379. % \nocite{lang-linalg}
  380. % \nocite{reid-commalg}
  381. % \nocite{jech-set-theory}
  382. \begin{appendices}
  383. {\footnotesize
  384. \setlength{\parskip}{0ex}
  385. % \setlength{\parindent}{0ex}
  386. \input{a-fdl.ltx}
  387. }
  388. \input{b-how-to-learn.ltx}
  389. \input{c-philosophy.ltx}
  390. \input{d-identities.ltx}
  391. \input{e-graph-listings.ltx}
  392. % Appendix F
  393. \ch{Answers to the exercises}
  394. \label{ex-solutions}
  395. \shipoutAnswer
  396. \input{g-peano-axioms.ltx}
  397. \end{appendices}
  398. \newpage
  399. \printbibliography
  400. \end{document}