% UCI Dissertation Style for AmSTeX. % @(#)$Id: diss.sty,v 1.1.1.1 2005/04/18 14:46:05 kono Exp $ % Tim Morgan with many suggestions, bug fixes, etc, from Marshall Rose % Based originally on Michael Spivak's AMSPPT.STY. % When edits are made to this file, the version number should be incremented. \def\version{103} \let\fmtversion=\version % These two control sequences are defined \def\fmtname{dissertation} % in plain.tex, so we do it here too. % Assumes the following hidden definitions from plain.tex: % \z@ is defined from plain.tex as 0pt (and magically can % be used as the integer constant 0 also). % \p@ is the same, but 1pt % \@ne is 1 % \m@ne is -1 % \tw@ is 2 % \thr@@ is 3 % \@m is 1000 % \@M is 10000 % And the following scratch register definitions: % \dimen@ is \dimendef'd to be \dimen0 % \skip@ is \skipdef'd to be \skip0 % \count@ is \count255 \catcode`\@=11 % So we can use a special character %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % PARAMETERS DIFFERENT THAN IN PLAIN % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % These are words which TeX doesn't hyphenate perfectly. % Unfortunately, the plural forms must be included also. \hyphenation{com-put-er com-mun ap-pen-dix cart-wheel data-base Dijk-stra} \hyphenation{in-fra-struc-ture man-u-script mi-cro-fiche para-mil-i-tary} \hyphenation{post-am-ble pre-am-ble sub-scrib-er wave-guide sub-scrib-ers} \hyphenation{com-put-ers cart-wheels data-bases in-fra-struc-tures} \hyphenation{man-u-scripts mi-cro-fiches post-am-bles pre-am-bles} \hyphenation{buf-fer buf-fers des-ig-na-ted par-a-graph par-a-graphs} \hyphenation{key-stroke key-strokes usu-al-ly} \def\normal@topskip{0.48cm} \topskip=\normal@topskip % For correct page positioning, do NOT \hoffset=0.5in % change any of these values!!! \voffset=0.07cm \hsize=15.2cm \vsize=22.2cm \normallineskiplimit=\p@ % Min. dist. btw. lines. \parindent=1cm % Normal indentation. \hfuzz=0.115\p@ % So we hear fewer complaints. Good up to \vfuzz=0.115\p@ % 300 dpi. \pretolerance=200 % At 12pt, these margins are kind of narrow \tolerance=300 % so we have to be more tolerant. \clubpenalty=\@M % Never allow these. \widowpenalty=\@M \newlinechar=`\^^J % For writing output to tty. \uchyph=\z@ % Don't take any chances. \brokenpenalty=\@M % Never hyphenate last line on a page. \newcount\defaultinterlinepenalty % This probably won't make any \defaultinterlinepenalty=\thr@@ % difference, so why not?? \interlinepenalty=\defaultinterlinepenalty %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % PARAMETERS DIFFERENT from AmSTeX % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \TagsOnRight % Set tags like a sane person does %%%%%%%%%%%%%%%%%%%%%%%% % EXTRA FONTS NEEDED % %%%%%%%%%%%%%%%%%%%%%%%% \newif\ifolddigits \olddigitsfalse % Allow use of amcscod10 for citations \def\useolddigits{% \olddigitstrue \oktell{Old Digits Mode}% } \font\sixrm=cmr6 \font\sixbf=cmbx6 \font\sixi=cmmi6 \skewchar\sixi='177 \font\sixsy=cmsy6 \skewchar\sixsy='60 \font\eightrm=cmr8 \font\eightsl=cmsl8 \font\eightit=cmti8 \font\eightsy=cmsy8 \skewchar\eightsy='60 \skewchar\eightsy='60 \font\eightbf=cmbx8 \font\eightex=cmex10 at 8\p@ \font\eighti=cmmi8 \skewchar\eighti='177 \font\ninerm=cmr9 \font\nineit=cmti9 \font\ninei=cmmi9 \skewchar\ninei='177 \font\ninesy=cmsy9 \skewchar\ninesy='60 \font\ninesl=cmsl9 \font\ninebf=cmbx9 \font\twelvecsc=cmcsc10 scaled \magstep1 \font\tencsc=cmcsc10 \font\eightcsc=cmcsc10 at 8\p@ \font\elevencsc=cmcsc10 scaled \magstephalf \font\ninecsc=cmcsc10 at 9\p@ \let\tencscod=\tencsc \let\eightcscod=\eightcsc \font\eightsf=cmss10 at 8\p@ \font\tensf=cmss10 \font\twelvesf=cmss10 at 12\p@ \font\twelvett=cmtt10 scaled \magstep1 \font\eighttt=cmtt10 at 8\p@ % \tentt is predefined in plain.tex \font\twelvebti=cmbti at 12\p@ \font\tenbti=cmbti \font\eightbti=cmbti at 8\p@ \font\twelveex=cmex10 scaled \magstep1 \font\twelverm=cmr10 scaled \magstep1 \font\twelvesl=cmsl10 scaled \magstep1 \font\twelvebf=cmbx10 scaled \magstep1 \font\twelvei=cmmi10 scaled \magstep1 \skewchar\twelvei='177 \font\twelvesy=cmsy10 scaled \magstep1 \skewchar\twelvesy='60 \font\twelveit=cmti10 scaled \magstep1 \font\twelvechap@font=cmssbx10 at 14\p@ \font\twelvesec@font=cmss10 at 13\p@ \font\twelvesubsec@font=cmssi10 scaled \magstep1 \font\tenchap@font=cmssbx10 scaled \magstep1 \font\tensec@font=cmssbx10 scaled \magstephalf \font\tensubsec@font=cmssi10 \font\eightchap@font=cmssbx10 \font\eightsec@font=cmss10 at 9\p@ \font\eightsubsec@font=cmssqi8 % Font selection \newcount\font@no \def\curfont{\ifcase\font@no\rm\or\it\or\sl\or\bf\or\tt\or\csc\or\bti\or\sf \else\errmessage{Internal font confusion}\fi} %%%%%%%%%%%%%%%%%%%%% % SPACING CONTROL % %%%%%%%%%%%%%%%%%%%%% \newskip\normalabovedisplayskip \newskip\normalbelowdisplayskip \newskip\normalabovedisplayshortskip \newskip\normalbelowdisplayshortskip \newdimen\normalparskip \normalparskip=22.5\p@ \newdimen\parstretch \parstretch=8\p@ \newif\ifsinglespacing % Tells if we are currently in single space mode \newif\ifhalfspacing % Special version of singlespacing, a little bigger. % Actually tell TeX what spacing is wanted \def\setbaselines{% \baselineskip=\normalbaselineskip \abovedisplayskip=\normalabovedisplayskip \belowdisplayskip=\normalbelowdisplayskip \abovedisplayshortskip=\normalabovedisplayshortskip \belowdisplayshortskip=\normalbelowdisplayshortskip % Compute \parskip for even paragraph spacing at all pt sizes \dimen@=\normalparskip \advance\dimen@ by -\normalbaselineskip \parskip=\dimen@ plus\parstretch } % Go from double to single spacing \def\reducespacing{% \normalbaselineskip=0.64\normalbaselineskip \normalabovedisplayskip=0.64\normalabovedisplayskip \normalbelowdisplayskip=0.64\normalbelowdisplayskip \normalabovedisplayshortskip=0.64\normalabovedisplayshortskip \normalbelowdisplayshortskip=0.64\normalbelowdisplayshortskip } % Set halfspacing baseline etc starting from singlespacing mode \def\sethalfspacing{% \normalbaselineskip=1.28125\normalbaselineskip \abovedisplayskip=1.28125\abovedisplayskip \belowdisplayskip=1.28125\belowdisplayskip \abovedisplayshortskip=1.28125\abovedisplayshortskip \belowdisplayshortskip=1.28125\belowdisplayshortskip } % Go to single spacing if we're not there already \def\singlespace{% \normalspacing \reducespacing \halfspacingfalse \singlespacingtrue \setbaselines } % Go to 1-1/2 spacing. \def\halfspace{% \normalspacing \reducespacing \sethalfspacing \singlespacingtrue \halfspacingtrue \setbaselines } % Go to normal, doublespacing mode \def\doublespace{% \normalspacing \singlespacingfalse \halfspacingfalse \setbaselines } % Make sure we're doing the spacing we're supposed to be. \def\setspacing{% \normalspacing \ifsinglespacing \reducespacing \ifhalfspacing \sethalfspacing \fi \fi \setbaselines } %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % FOUR DIFFERENT POINT SIZES % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \def\twelvepoint{% \def\big@@AmS{10.2\p@}% \def\Big@@AmS{13.8\p@}% \def\bigg@@AmS{17.4\p@}% \def\Bigg@@AmS{21.0\p@}% \let\smallertype=\tenpoint \let\curtype=\twelvepoint \def\biggertype{\errmessage{No larger point size available}}% \def\normalspacing{% \normalbaselineskip=22.8\p@ \normalabovedisplayskip=14.5\p@ plus 3\p@ minus 9\p@ \normalbelowdisplayskip=14.5\p@ plus 3\p@ minus 9\p@ \normalabovedisplayshortskip=\z@ plus 4\p@ \normalbelowdisplayshortskip=9\p@ plus 4\p@ minus 5\p@ }% \def\rm{\font@no=0\fam\z@\twelverm}% \def\it{\font@no=1\fam\itfam\twelveit}% \def\sl{\font@no=2\fam\slfam\twelvesl}% \def\bf{\font@no=3\fam\bffam\twelvebf}% \def\tt{\font@no=4\fam\ttfam\twelvett \spaceskip.5em plus.25em minus.15em }% \def\csc{\font@no=5\twelvecsc}% \def\bti{\font@no=6\twelvebti}% \def\sf{\font@no=7\twelvesf}% \let\sc=\csc \ifolddigits \let\cite@font=\tencscod \else \let\cite@font=\elevencsc \fi \textfont\z@=\twelverm \scriptfont\z@=\ninerm \scriptscriptfont\z@=\sixrm \textfont\@ne=\twelvei \scriptfont\@ne=\ninei \scriptscriptfont\@ne=\sixi \textfont\tw@=\twelvesy \scriptfont\tw@=\ninesy \scriptscriptfont\tw@=\sixsy \textfont\thr@@=\twelveex \scriptfont\thr@@=\twelveex \scriptscriptfont\thr@@=\twelveex \textfont\itfam=\twelveit \textfont\slfam=\twelvesl \textfont\ttfam=\twelvett \textfont\bffam=\twelvebf \scriptfont\bffam=\ninebf \scriptscriptfont\bffam=\sixbf \let\chap@font=\twelvechap@font \let\sec@font=\twelvesec@font \let\subsec@font=\twelvesubsec@font \let\subsubsec@font=\twelvebf \def\oldstyle{\fam1\twelvei}% \setspacing \curfont \ifundefined{everypointsize}\else\everypointsize{twelve}{12}\fi } \def\tenpoint{% \def\big@@AmS{8.5\p@}% \def\Big@@AmS{11.5\p@}% \def\bigg@@AmS{14.5\p@}% \def\Bigg@@AmS{17.5\p@}% \let\smallertype=\eightpoint \let\curtype=\tenpoint \let\biggertype=\twelvepoint \def\normalspacing{% \normalbaselineskip=18.9\p@ \normalabovedisplayskip=12\p@ plus 3\p@ minus 9\p@ \normalbelowdisplayskip=12\p@ plus 3\p@ minus 9\p@ \normalabovedisplayshortskip=\z@ plus 3\p@ \normalbelowdisplayshortskip=7\p@ plus 3\p@ minus 4\p@ }% \def\rm{\font@no=0\fam\z@\tenrm}% \def\it{\font@no=1\fam\itfam\tenit}% \def\sl{\font@no=2\fam\slfam\tensl}% \def\bf{\font@no=3\fam\bffam\tenbf}% \def\tt{\font@no=4\fam\ttfam\tentt \spaceskip.5em plus.25em minus.15em }% \def\csc{\font@no=5\tencsc} \def\bti{\font@no=6\tenbti}% \def\sf{\font@no=7\tensf}% \let\sc=\csc \ifolddigits \let\cite@font=\eightcscod \else \let\cite@font=\ninecsc \fi \textfont\z@=\tenrm \scriptfont\z@=\sevenrm \scriptscriptfont\z@=\fiverm \textfont\@ne=\teni \scriptfont\@ne=\seveni \scriptscriptfont\@ne=\fivei \textfont\tw@=\tensy \scriptfont\tw@=\sevensy \scriptscriptfont\tw@=\fivesy \textfont\thr@@=\tenex \scriptfont\thr@@=\tenex \scriptscriptfont\thr@@=\tenex \textfont\itfam=\tenit \textfont\slfam=\tensl \textfont\ttfam=\tentt \textfont\bffam=\tenbf \scriptfont\bffam=\sevenbf \scriptscriptfont\bffam=\fivebf \let\chap@font=\tenchap@font \let\sec@font=\tensec@font \let\subsec@font=\tensubsec@font \let\subsubsec@font=\tenbf \def\oldstyle{\fam1\teni}% \setspacing \curfont \ifundefined{everypointsize}\else\everypointsize{ten}{10}\fi } \def\eightpoint{% \def\big@@AmS{6.8\p@}% \def\Big@@AmS{9.2\p@}% \def\bigg@@AmS{11.6\p@}% \def\Bigg@@AmS{14.0\p@}% \def\smallertype{\errmessage{No smaller point size available}}% \let\curtype=\eightpoint \let\biggertype=\tenpoint \def\normalspacing{% \normalbaselineskip=15\p@ \normalabovedisplayskip=10\p@ plus 2.4\p@ minus 7.2\p@ \normalbelowdisplayskip=10\p@ plus 2.4\p@ minus 7.2\p@ \normalabovedisplayshortskip=\z@ plus 2.4\p@ \normalbelowdisplayshortskip=55.6\p@ plus 2.4\p@ minus 3.2\p@ }% \def\rm{\font@no=0\fam\z@\eightrm}% \def\it{\font@no=1\fam\itfam\eightit}% \def\sl{\font@no=2\fam\slfam\eightsl}% \def\bf{\font@no=3\fam\bffam\eightbf}% \def\tt{\font@no=4\fam\ttfam\eighttt \spaceskip.5em plus.25em minus.15em }% \def\csc{\font@no=5\eightcsc}% \def\bti{\font@no=6\eightbti}% \def\sf{\font@no=7\eightsf}% \let\sc=\csc \def\cite@font{\errmessage{You may not do citations in 8 point}} \textfont\z@=\eightrm \scriptfont\z@=\sixrm \scriptscriptfont\z@=\fiverm \textfont\@ne=\eighti \scriptfont\@ne=\sixi \scriptscriptfont\@ne=\fivei \textfont\tw@=\eightsy \scriptfont\tw@=\sixsy \scriptscriptfont\tw@=\fivesy \textfont\thr@@=\eightex \scriptfont\thr@@=\eightex \scriptscriptfont\thr@@=\eightex \textfont\itfam=\eightit \textfont\slfam=\eightsl \textfont\ttfam=\eighttt \textfont\bffam=\eightbf \scriptfont\bffam=\sixbf \scriptscriptfont\bffam=\fivebf \let\chap@font=\eightchap@font \let\sec@font=\eightsec@font \let\subsec@font=\eightsubsec@font \let\subsubsec@font=\eightbf \def\oldstyle{\fam1\eighti}% \setspacing \curfont \ifundefined{everypointsize}\else\everypointsize{eight}{10}\fi } %%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % TABLE of CONTENTS Macros % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % This set of macros allows you to build a table of contents for a document % automatically in TeX. There are only three control sequences which you % will need to use. The first is \inicont, which initializes the macros. % This package works by writing the appropriate lines into a file called % \jobname.toc in your account. This file is read by \printcontents or % by \printcont in PRINT-PRELIM.TEX. % \newwrite\cont@file % Get a free channel to write to \newif\ifcont@closed \cont@closedtrue % Haven't opened contents file yet \newwrite\fig@file \newwrite\tab@file \newif\iffig@closed \fig@closedtrue % Or the list of figures file \newif\iftab@closed \tab@closedtrue % Or the tables file \def\contitle{\jobname.toc} % Default name of contents file \def\figtitle{\jobname.lof} % ditto for figures file \def\tabtitle{\jobname.lot} % ditto for tables file % Make sure the contents file is open before writing to it \def\opencontfile{% \ifcont@closed \immediate\openout\cont@file=\contitle \cont@closedfalse \fi } % % This control sequence adds its argument to the table of contents. % \def\content#1{% \opencontfile \let\\=\space \write\cont@file{\string\Z{#1}{\the\pageno}}% } % % This control sequence is the same as \content except that the first % box written will have two leading spaces to indent it. % \def\subcontent#1{% \opencontfile \let\\=\space \write\cont@file{\string\Z{\string\hskip \parindent{}#1}{\the\pageno}}% } % And the same thing for sub-sections \def\subsubcontent#1{% \opencontfile \let\\=\space \write\cont@file{\string\Z{\string\hskip 2\parindent{}#1}{\the\pageno}}% } % And the same thing for sub-sub-sections \def\subsubsubcontent#1{% \opencontfile \let\\=\space \write\cont@file{\string\Z{\string\hskip 3\parindent{}#1}{\the\pageno}}% } % Simple table-of-contents printer for \articlestyle. % For dissertations, use the one in print-prelim.tex. % Use this macro as the last thing in your report, since it makes % the page numbers be in romannumerals at the bottom of the page. \def\printcontents{% \closeout \cont@file \null\vfill\supereject % Close output, end last page \twelvepoint\rm % Make sure we're in normal mode \pageno=\m@ne % Contents get roman numerals. \plain@page@numbers % Put page #s at bottom only \oktell{Table of Contents} \null \vskip .8in minus\baselineskip \centerline{\chap@font Contents} \vskip \tw@\baselineskip \rightline{Page} \begingroup % Temporarily change \baselineskip to avoid % underfull \vbox's during output errors. \baselineskip=\@ne\baselineskip plus .05\baselineskip \def\Z##1##2{\line{\ignorespaces##1\leaders \hbox to.7em{.\hfil}\hfil\hbox to2em{\hss##2}}} \catcode`@=11 \let\\=\space \input\contitle \relax \endgroup % Also undoes the \catcode change } %%%%%%%%%%%%%%%%%%%%%%%% % NUMBERED FOOTNOTES % %%%%%%%%%%%%%%%%%%%%%%%% % First, modify \vfootnote from Plain to use smallertype and singlespace \def\vfootnote#1{% \insert\footins\bgroup\tenpoint\singlespace \interlinepenalty\interfootnotelinepenalty \splittopskip\ht\strutbox % top baseline for broken footnotes \splitmaxdepth\dp\strutbox \floatingpenalty\@MM \leftskip\z@skip \rightskip\z@skip \spaceskip\z@skip \xspaceskip\z@skip \parindent=.13in \textindent{#1}\footstrut\futurelet\next\fo@t } % Allocate a counter for the numbered footnotes \newcount\note@count \note@count=\@ne \def\nfootnote#1{% \unskip\footnote{$^{\number\note@count}$}{#1}% \global\advance\note@count by\@ne } % Same except that trailing period or comma is ``tucked'' under % the note mark. \ntucknote provides auto numbering. \def\ntucknote#1#2{\nfootnote{#1}\llap{#2}} \def\tucknote#1#2#3{\footnote{#1}{#2}\llap{#3}} %%%%%%%%%%%%%%%%%%%% % UTILITY MACROS % %%%%%%%%%%%%%%%%%%%% % Insert a discretionary hyphen. For use in restricted % horizontal mode, as in the bibliography. \def\hyphenbreak{\discretionary{-}{}{-}} % Check if a macro name is currently undefined (from The TeXbook) \def\ifundefined#1{\expandafter\ifx\csname#1\endcsname\relax} % Terminal input and output routines and auxilary stuff \newwrite\undef@out@chan % Allocate a channel for the tty \def\tell#1{{\let\\=\space\immediate\write\undef@out@chan{#1}}} \def\ask#1{\read-16 to #1} % Read from tty w/o prompt % Sanitize a string before \write'ing it. % Call with \unexpanded{op}{msg} % Modified from version in The TeXbook, originally by Todd Allen \long\def\unexpanded#1#2{% \def\finwrite{#1}% {\aftergroup\finwrite\aftergroup{\sanitize@uci#2\endsanity@uci}}% } \def\sanitize@uci{\futurelet\next@uci\sanswitch@uci} \def\sanswitch@uci{\ifx\next@uci\endsanity@uci \else\ifx\next@uci\\\aftergroup\space\let\next@uci=\eat@uci \else\ifcat\noexpand\next@uci\space\aftergroup\space\let\next@uci=\eat@uci \else\ifcat\noexpand\next@uci\bgroup\aftergroup{\let\next@uci=\eat@uci \else\ifcat\noexpand\next@uci\egroup\aftergroup}\let\next@uci=\eat@uci \else\let\next@uci=\copytoken@uci\fi\fi\fi\fi\fi \next@uci } \def\eat@uci{\afterassignment\sanitize@uci \let\next@uci= } \long\def\copytoken@uci#1{% \ifcat\noexpand#1\relax\aftergroup\noexpand \else\ifcat\noexpand#1\noexpand~\aftergroup\noexpand \fi \fi \aftergroup#1\sanitize@uci } \def\endsanity@uci\endsanity@uci{} % Now use the sanity stuff to make a sane tell command. This macro % actually takes one argument, but since it's the last for \unexpanded, % we avoid scanning it twice by not picking it up here. \def\sanetell{\unexpanded{\immediate\write\undef@out@chan}} % Produce verbatim listings of various sorts \def\uncatcodespecials{\def\do##1{\catcode`##1=12 } \dospecials} \def\setupverbatim{% \par \tt \spaceskip=\z@ % Want fixed tt spacing now \obeylines \uncatcodespecials \obeyspaces \verbatimdefs } % This macro turns on verbatim mode until ?endverbatim is seen. \def\verbatim{% \begingroup \setupverbatim \parskip=\z@ plus .05\baselineskip \parindent=\z@ \catcode`\ =13 \catcode`\^^M=13 \catcode`\?=\z@ \verbatimgobble } {\catcode`\^^M=13{\catcode`\ =13\gdef\verbatimdefs{\def^^M{\ \par}\let =\ }} \gdef\verbatimgobble#1^^M{}% } % This defines ?endverbatim to end the group which begins with \verbatim \let\endverbatim=\endgroup % Input a file in verbatim mode. Sometimes useful for including % real-life examples into a paper. \def\verbfile#1{% \begingroup\setupverbatim \parskip=\z@ plus .05\baselineskip \parindent=\z@ \input#1 \endgroup } % This is the same as the above, but it adds line numbers to each % line of the file printed. \lineno@uci has the obvious use. \newcount\lineno@uci \def\listing#1{% \lineno@uci=\z@ \begingroup\setupverbatim \parskip=\z@ plus .05\baselineskip \parindent=20\p@ \everypar{\advance\lineno@uci by\@ne \llap{\the\lineno@uci\ \ }}% \input#1 \endgroup } % Draw a little qed symbol (black box) \def\qed{\hbox{\hskip\p@ \vrule width4\p@ height6\p@ depth1.5\p@ \hskip\p@}} % Conditions -- from AmSppt \newif\ifrunin@AmS \runin@AmSfalse \let\runin=\runin@AmStrue \newdimen\cond@dimen \newdimen\condindent % Amount each nested condition is indented \condindent=.5in % Default indentation amount % This is used in \conditions \def\firstcon@AmS#1:{% \ifrunin@AmS {\rm\ignorespaces#1\unskip}\ignorespaces \runin@AmSfalse \else \par \ifdim\lastskip<\smallskipamount \removelastskip \penalty55 \smallskip \fi \\#1:% \fi } % Do one item of the conditions. This is really \\ in disguise. \def\cond@item#1:{% \par\noindent \hbox to \cond@dimen{\hfil\rm\ignorespaces#1\unskip\quad}% \hangafter1 \hangindent\cond@dimen\ignorespaces } \cond@dimen=\z@ % Value for outermost block % Do the main stuff for \conditions. \def\conditions{% \par \let\\=\cond@item \begingroup \advance\cond@dimen by\condindent \firstcon@AmS } % Exit special stuff for \conditions. \def\endconditions{% \par\smallbreak\endgroup \ifdim\cond@dimen>\z@ \cond@item \fi % If ending an inner condition } % Automatically numbered items \newcount\item@count \newdimen\item@dimen \item@dimen=\z@ \def\item@prefix{} \def\beginitems{% \begingroup \advance \parindent by\item@dimen \ifnum\item@dimen>\z@ \edef\item@prefix{\item@prefix\number\item@count.} \else \item@dimen=1cm \fi \item@count=\z@ \singlespace \interlinepenalty=200 } \def\enditems{\par\endgroup} \def\nitem{\advance\item@count by\@ne \item{\item@prefix\number\item@count.}} % Turn back on the \+ construct of plain TeX. \def\tabalign{\us@true\m@ketabbox} \outer\def\+{\tabalign} % Fix AmSTeX's definition used in its definition of ~ (tie). \def\s@AmS{\penalty\@M\ifx\tok@AmS\Space@AmS\else\ \fi} % And make \/ work the way it does in plain.tex \let\/=\ic@AmS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % PAGE CONTROL and OBJECT MANIPULATION % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % This definition doesn't blow up if you're in vertical mode already \def\pagebreak{\ifhmode\vadjust{\break}\else\break\relax} % This definition clears out all previous inserts etc to % guarantee that the following stuff is at the top of a page. \def\clearpage{\vfill\supereject} % This macro keeps the stuff in the argument on the same page, leaving % blank space on this page if necessary \def\keep{\par\setbox\z@=\vbox\bgroup} \def\endkeep{% \egroup \dimen@=\ht\z@ \advance\dimen@ by\dp\z@ \vskip\z@ plus\dimen@ \penalty\z@ \vskip\z@ plus-\dimen@ \vskip\parskip \box\z@ \goodbreak } \def\filkeep{% \egroup \filbreak \vskip\parskip \box\z@ \goodbreak } % List macros from the TeXbook \toksdef\ta=\z@ \toksdef\tb=\tw@ \newif\ifresult@uci % usage: \newlist\list \def\newlist#1{\let#1=\empty} % usage: \append{item}\to\list \def\append#1\to#2{\ta={\\{#1}}\tb=\expandafter{#2}\edef#2{\the\tb\the\ta}} \def\gappend#1\to#2{\ta={\\{#1}}\tb=\expandafter{#2}\xdef#2{\the\tb\the\ta}} % usage: \cardinality\list\to\counter \def\cardinality#1\to#2{#2=\z@ \long\def\\##1{\advance#2 by\@ne }#1} % usage: \ifismember{item}\of\list ... \else ... \fi \def\ifismember#1\of#2{% \def\given@uci{#1}% \result@ucifalse \def\\##1{% \def\next@uci{##1}% \ifx\next@uci\given@uci \result@ucitrue\fi }% #2% \ifresult@uci } % usage: \ifwasmember{item}\of\list ... \else ... \fi % side effect: removes {item} from \list if present \def\ifwasmember#1\of#2{% \newlist\ref@mtr \def\given@uci{#1}% \result@ucifalse \def\\##1{% \def\next@uci{##1}% \ifx\next@uci\given@uci \result@ucitrue \else \append ##1\to\ref@mtr \fi }% #2% \let#2=\ref@mtr \ifresult@uci } % Append #1 to list #2 if #1 is not already in #2 \def\addtolist#1\to#2{% \ifismember#1\of#2% \else \append #1\to #2% \fi } % Same thing, but do it \global'ly \def\gaddtolist#1\to#2{% \ifismember#1\of#2% \else \gappend#1\to#2% \fi } %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % STUFF for BIBLIOGRAPHY and APPENDICES % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % Bibliography Package: % Original version by Michal Spivak % Updated for JACM format and automated by Tim Morgan % Final cleanup, and much-improved automation, by Marshall Rose % Additional work and IEEE support by TM. % Simple appendix entry builder \def\appendix#1#2{% \par \clearpage \ifoddpages \ifodd\pageno \else \null\vfill\eject\fi \fi \pageno@foot \begingroup \setbox\z@=\hbox{#1}% \ifdim\wd\z@>\z@ \content{Appendix #1: #2}% \oktell{Appendix #1: #2}% \def\title{Appendix #1\\#2}% \else \content{Appendix: #2}% \oktell{Appendix: #2}% \def\title{Appendix\\#2}% \fi \let\\=\cr \tabskip=\z@ \chap@font \halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\title\cr}% \endgroup \nobreak \vskip 1.0in minus 0.15in } % Citations: % We keep a running list, \ref@set, which is % all the things which were \cite'd throughout the paper, with % only one entry for each different key. % % There are three versions of each of the citation % commands: % 1. The \def'd version is the normal one used throughout the paper. % 2. Within a figure, table, etc,'s caption, because of the use of % \def and \edef, a special version which just produces the % citation without the \gaddtolist command is used. These % definitions are predefined, and are \let to be \cite etc with % \no@cites, for speed. % % When the user requests a citation with key, we first look it up % in a translation table called \key@table, organized as a list of % pairs, to see if it really should be % printed differently. The user can specify this translation table using % the \printkey command. If a key is not in the table, it is printed % as-is. % We keep the dimension \key@size as the largest printed key so far. % This value can then be used to print the keys in the bibliography % optimally, rather than just trying to guess. Each time we print a % (in \use@key), we see if it's longer than \key@size, and if so then % we set \key@size = its width. \newdimen\key@size \key@size=\z@ % Init. value so \key@size is made as small as possible % Invisible citation. usage: \icite{key} \def\icite#1{% \gaddtolist#1\to\ref@set } % Management of \key@table stuff. This table is formatted as % \\{real-key}{printed-key}... \newlist\key@table % Add a pair of items to the list. This should be done before any % citations are made, for obvious reasons. % #1=real key (the one you use in the paper and bibliography) % #2=the key that gets printed in the output \def\printkey#1#2{% \ta={\\{#1}{#2}}% \tb=\expandafter{\key@table}% \xdef\key@table{\the\tb\the\ta}% } % Print a key, looking it up in the table. #1 is \whatever which % expands to the key used by the user. The definition of \\ here % makes use of the format of the \key@table, so that the table is % actually EXECUTED, hence making lookup relatively fast. \newif\if@not@printed@ \def\use@key#1{% \@not@printed@true \def\\##1##2{% \if@not@printed@ \def\temp@uci{##1}% \ifx\temp@uci#1% \@not@printed@false \setbox\z@=\hbox{[##2]\enspace}% \ifdim\wd\z@>\key@size \global\key@size=\wd\z@ \fi ##2% \fi \fi }% \key@table \if@not@printed@ \setbox\z@=\hbox{\cite@font[\ignorespaces#1\unskip]\enspace}% \ifdim\wd\z@>\key@size \global\key@size=\wd\z@ \fi #1% \fi } % This macro moves forward until it hits \end, skipping spaces. % Each time it hits a comma, or when it hits and \end, it % adds whatever has been collected so far (in \@total) to % \ref@set and to the output list. It is assumed that \@total % has been set to \empty before this routine is called (this is done % by \@@cite, below). \def\@icite#1{% \if#1\end \expandafter\gaddtolist\@total\to\ref@set \use@key\@total \let\@next=\relax % Exit loop after this time \else \if#1,% % We have a complete key now. \expandafter\gaddtolist\@total\to\ref@set \use@key\@total,\space \global\let\@total=\empty \else \xdef\@total{\@total#1}% Add new char to total \fi \let\@next=\@icite % Continue looping until done \fi \@next } % Initialize and call \@icite. Used in \cite, \citep, \citepp \def\@@cite#1{\global\let\@total=\empty\@icite#1\end} % usage: \cite{key [, key...]} \def\cite#1{% {\cite@font[\@@cite{#1}]}% } % usage: \citep{key}{page} \def\citep#1#2{% {\cite@font[\@@cite{#1}, \hbox{\rm p \ignorespaces#2\unskip}]}% } % usage: \citepp{key}{pages} \def\citepp#1#2{% {\cite@font[\@@cite{#1}, \hbox{\rm pp \ignorespaces#2\unskip}]}% } % These three definitions are used in \no@cites, below. They % don't handle extraneous spaces as well as the normal % definition, but they should be sufficient for most people. \def\i@cite#1{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1}]}} \def\i@citep#1#2{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1},\space \hbox{\noexpand\noexpand\noexpand\rm p \ignorespaces#2\unskip}]}% } \def\i@citepp#1#2{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1},\space \hbox{\noexpand\noexpand\noexpand\rm pp \ignorespaces#2\unskip}]}% } % Turn off adding citations to \ref@set. This is needed when % using \cite etc inside a caption for tables, figures, etc. % \no@cites is undone by exiting an enclosing group. \def\no@cites{% \let\citepp=\i@citepp \let\citep=\i@citep \let\cite=\i@cite } %%%%%%%%%%%%%%%%%%%%%% % References Section % %%%%%%%%%%%%%%%%%%%%%% % The basic strategy is as follows. We read the bib. file, which is % assumed to be in sorted order of keys/author names. Each % entry is of the form \ref{key}. We see if that key is in the table % \ref@set, which is a table of all the keys we've \cite'd. If the key % isn't in the list, we print it in parens and go on to the next entry. % Otherwise, we print the key in square brackets, and format the % bibliography entry according to the format (JACM or IEEE). We print a % warning if the key is in the \ref@seen list. We add the key to % the \ref@seen list. The key is removed from the \ref@set list if it % was there. At the end of the references (\endreferences), we check % if there are any keys left in \ref@set. If so, the bib. file was % deficient, and we print a warning message (it should probably be a % fatal error message). % Annotation control \newif\ifinclude@annos % Should annotations be printed? \include@annosfalse % By default, no \def\annotate{% % ``official'' command \include@annostrue \oktell{Annotating bibliography}% } \newif\ifin@anno % True while doing an annotation \in@annofalse \def\refi@AmS{F} % This starts as False % Begin an annotation -- must be in vertical mode. Just gather % text into box0 for use by \endanno. We do a couple of consistency % checks at the beginning. \def\anno{% \ifhmode \message{You forgot the \noexpand\endref command!} \message{I've inserted one for you.} \endanno \fi \if F\refi@AmS \errmessage{No \noexpand\ref command before first \noexpand\anno} \fi \let\\=\newline \in@annotrue \setbox\z@=\vbox\bgroup } % End of an annotation. Decide if it should be typeset or skipped. \def\endanno{% \egroup % End the group for box0 \in@annofalse % No longer doing an annotation \if T\refed@uci % If previous reference was used, \ifinclude@annos {% And if we're producing an annotated bib., \vskip\parskip \interlinepenalty=\defaultinterlinepenalty \unvbox\z@ % Then include annotation as normal paragraph(s) \par }\fi \fi } \global\newlist\ref@set % list of all references cited \global\newlist\ref@seen % list of all references defined \def\reftitle{References} % Default title for bibliography % usage: \references (begin the References section) \def\references{% \vfill\supereject % Begin new page, clear out everything \ifoddpages % Make sure start on even page. \ifodd\pageno \relax \else \null\vfill\eject \fi \fi \begingroup % Following changes are local to bib. \twelvepoint % Get good appearance \singlespace \no@cites % \cite's just produce [key] \parskip=0.6\baselineskip plus5\p@ minus4\p@ \tolerance=5000 % Must be extremely tolerant! \pretolerance=300 \interlinepenalty=400 % To discourage breaking a reference % across page boundaries \uchyph=\@ne % Needed to try hyphenating title words \sfcode`.=\@m % Like \frenchspacing, but only for % periods % Now we output the title and so forth. \centerline{\csc \reftitle}% \nobreak \medskip \content\reftitle % Tell user and TOC. \oktell\reftitle \pageno@foot % Put page # in special place % Special definitions within reference mode \let\year=\yr \let\month=\mon } % usage: \endreferences (end the References section) \def\endreferences{% \par % Make sure last printed reference is finished up. \cardinality\ref@set\to\count@ \ifnum\count@>\z@ \def\\##1{[##1] } \ifnum\count@>1 \message{Warning: \number\count@\space undefined citations: \ref@set} \else \message{Warning: One undefined citation: \ref@set} \fi \fi \endgroup % End of \references group } % References Database \newbox\bybox@AmS \newbox\bysamebox@AmS \newbox\paperbox@AmS \newbox\paperinfobox@AmS \newbox\jourbox@AmS \newbox\jourinfobox@AmS \newbox\volbox@AmS \newbox\issuebox@AmS \newbox\monbox@AmS \newbox\yrbox@AmS \newbox\pagesbox@AmS \newbox\editorbox@AmS \newbox\bookbox@AmS \newbox\bookinfobox@AmS \newbox\publbox@AmS \newbox\publaddrbox@AmS \newbox\finalinfobox@AmS\newbox\wastebox@uci \newbox\talkbox@AmS \newbox\keybox@AmS \newbox\editorsbox@AmS \def\using@IEEE{F} % By default, not using IEEE format % reset a \keyword to the ``not used'' condition \def\refset@AmS#1{% \expandafter\gdef\csname is\expandafter\eat@AmS \string#1@AmS\endcsname{F}\expandafter \setbox\csname\expandafter\eat@AmS\string#1box@AmS\endcsname=\null } % reset \keyword's \def\ref@AmS{% \refset@AmS\key \refset@AmS\finalinfo \refset@AmS\by \gdef\isbysame@AmS{F}% \refset@AmS\paper \refset@AmS\paperinfo \refset@AmS\jour \refset@AmS\jourinfo \refset@AmS\vol \refset@AmS\issue \refset@AmS\mon \refset@AmS\yr \refset@AmS\pages \gdef\ispage@AmS{F}% \refset@AmS\book \refset@AmS\bookinfo \refset@AmS\publ \refset@AmS\publaddr \refset@AmS\editor \refset@AmS\talk \refset@AmS\editors \gdef\istoappear@AmS{F}% \gdef\isinbook@AmS{F}% \bgroup \ignorespaces } % usage: \ref{citation} \keywords arguments ... \endref. We make sure % we aren't still doing an \anno first. \def\ref#1{% \ifin@anno \message{You forgot an \noexpand\endanno command,} \message{but I forgive you this time.} \endanno \fi \def\refi@AmS{T}% \ifwasmember#1\of\ref@set \def\refed@uci{T}% \okmessage{[#1]}% \else \def\refed@uci{F}% \okmessage{(#1)}% \fi \ifismember#1\of\ref@seen \sanetell{multiply defined: [#1]}% \else \append#1\to\ref@seen \fi \def\refl@AmS{F}% \def\\{\egroup\endref@AmS\gdef\refi@AmS{F}\ref@AmS}% \ref@AmS \gdef\@total{#1}% \key \if T\refed@uci \use@key\@total \fi\egroup\setbox\wastebox@uci=\hbox\bgroup\ignorespaces } % End of a reference. % % Note that \endref@AmS is \let to be whichever \endref@xxx command % is being used; default is \endref@JACM for JACM format. % % If we printed the reference, \endref@AmS will % have set \bysamebox@AmS to be a box containing a box % containing a rule and a period. This is unboxed if a subsequent % reference which gets printed uses \bysame. Otherwise, we here % save the \by field (if given) so that if a subsequent reference % using \bysame gets used, we'll know who the author was, even though % the reference which gave the author(s) wasn't printed. Tricky, huh? \def\endref{% \egroup\gdef\refl@AmS{T}% \if T\refed@uci \endref@AmS \else \if T\isby@AmS \setbox\bysamebox@AmS=\box\bybox@AmS \fi \fi \par } % define a \keyword. #1=keyword, #2=font to use, or {} \def\refdef@AmS#1#2{% \def#1{% \egroup \expandafter\gdef \csname is\expandafter\eat@AmS\string#1@AmS\endcsname{T}% \expandafter\setbox \csname\expandafter\eat@AmS\string#1box@AmS\endcsname =\hbox\bgroup#2\ignorespaces }% } % define the keywords \refdef@AmS\by\by@font \refdef@AmS\paper{} \refdef@AmS\paperinfo{} \refdef@AmS\jour\book@font \refdef@AmS\vol\book@font \refdef@AmS\issue{} \refdef@AmS\mon{} \refdef@AmS\yr{} \refdef@AmS\pages{} \refdef@AmS\talk{} \refdef@AmS\book\book@font \refdef@AmS\bookinfo{} \refdef@AmS\publ{} \refdef@AmS\publaddr{} \refdef@AmS\finalinfo{} \refdef@AmS\editor{} \refdef@AmS\jourinfo{} \refdef@AmS\key\cite@font \refdef@AmS\editors{} % These don't fit the normal pattern. \def\bysame{\egroup\gdef\isbysame@AmS{T}\bgroup} \def\page{\egroup\gdef\ispage@AmS{T}\setbox\pagesbox@AmS=\hbox\bgroup \ignorespaces} \def\toappear{\egroup\gdef\istoappear@AmS{T}\bgroup} \def\inbook{\egroup\gdef\isinbook@AmS{T}\setbox\bookbox@AmS=\hbox\bgroup \book@font\ignorespaces } % This is the font we normally print book and journal titles in, but we % use \twelveit for IEEE format. \let\book@font=\twelvesl % Similarly, this is the font to use for the author's name(s). % Optionally, the user can ask for the cite font instead (this is % not necessarily related to use of the IEEE format). \let\by@font=\twelverm % As an option, the user can have the author's name(s) in caps-small-caps. \def\AuthorsInCSC{% \let\by@font=\elevencsc \oktell{Authors in CSC mode}% } % Define some aliases for some of the above, for user convenience. \let\pp=\pages \let\pgs=\pages \let\pg=\page \let\p=\page \let\journal=\jour \let\volume=\vol \let\author=\by \let\authors=\by \let\ieee@editors=\editors % Save it in case we use IEEE format \let\editors=\editor % If using default JACM format \let\other=\talk \let\no=\issue % Helpers to \endref@AmS, which speed things up a lot, and/or % make the code more compact. \def\a@comma{, } % Used in next routine. Predefined for speed of \let. \def\setpunct@AmS{\let\prepunct@AmS=\a@comma} \def\ppunbox@AmS#1{\prepunct@AmS\unhbox#1\unskip} % Actually do some typesetting (finally). As mentioned above, % \endref@AmS is called to print a reference if we want it. It % is \let to be either \endref@JACM or \endref@IEEE (or possibly % some other format in the future) depending on the desired % format. % % For some reason, the ~'s don't see to tie things, so some % \hbox's were introduced. % % There is unfortunately a lot of common code between the % different formats. Here are some sections which were easy to % pull out: \def\endref@startup{% % Test to see if there is anything in the wastebox \setbox\wastebox@uci=\hbox{\unhbox\wastebox@uci\unskip}% \ifdim\wd\wastebox@uci>\z@ \errmessage{Keyword omitted after \noexpand\ref}% \fi \let\prepunct@AmS=\empty \vskip\parskip \noindent \hangafter=\@ne } % This is the text printed for the JACM format for papers % appearing in a book. \def\appearing@in{Appearing in } % Common code at the end of \endref@JACM and \endref@IEEE. % The argument is the date routine to use. \def\endref@finishup#1{% \if T\istalk@AmS \dimen@=\wd\talkbox@AmS \ifdim\dimen@>\z@ \ppunbox@AmS\talkbox@AmS\setpunct@AmS \fi \fi \if T\isbook@AmS \ppunbox@AmS\bookbox@AmS \setpunct@AmS \editor@ref \fi \if T\isinbook@AmS \prepunct@AmS\appearing@in\unhbox\bookbox@AmS\unskip \setpunct@AmS \editor@ref \gdef\isbook@AmS{T}% \fi \if T\isbookinfo@AmS \ppunbox@AmS\bookinfobox@AmS\setpunct@AmS \fi \if T\using@IEEE \if T\ispubladdr@AmS \ppunbox@AmS\publaddrbox@AmS \if T\ispubl@AmS \def\prepunct@AmS{: }\else\setpunct@AmS\fi \fi \if T\ispubl@AmS \ppunbox@AmS\publbox@AmS\setpunct@AmS \fi \else \if T\ispubl@AmS \ppunbox@AmS\publbox@AmS\setpunct@AmS \fi \if T\ispubladdr@AmS \ppunbox@AmS\publaddrbox@AmS\setpunct@AmS \fi \fi \if T\isbook@AmS \if T\isvol@AmS \prepunct@AmS Vol.~\unhbox\volbox@AmS\unskip\setpunct@AmS \fi \if T\isyr@AmS \ppunbox@AmS\yrbox@AmS\setpunct@AmS \fi \if T\istoappear@AmS \ (to appear)\setpunct@AmS \fi \if T\ispages@AmS \prepunct@AmS pp.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS \fi \if T\ispage@AmS \prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS \fi \fi \if T\istalk@AmS #1% This is the date routine to use. \fi \if T\isfinalinfo@AmS \period\unhbox\finalinfobox@AmS \else \if T\refl@AmS . \else ; \fi \fi } % Print editor(s) if and as appropriate. \def\editor@ref{% \if T\using@IEEE \if T\iseditor@AmS \ppunbox@AmS\editorbox@AmS, Ed.\setpunct@AmS \fi \if T\iseditors@AmS \ppunbox@AmS\editorsbox@AmS, Eds.\setpunct@AmS \fi \else \if T\iseditor@AmS \ppunbox@AmS\editorbox@AmS\ (ed.)\setpunct@AmS \fi \fi } % This routine prints the date in the JACM format \def\date@JACM{% \if T\isyr@AmS \/\ (% \if T\ismon@AmS \unhbox\monbox@AmS\unskip, \fi \unhbox\yrbox@AmS\unskip)\setpunct@AmS \else \if T\ismon@AmS \ppunbox@AmS\monbox@AmS\setpunct@AmS \fi \fi } % This prints the date in the IEEE format. \def\date@IEEE{% \if T\isyr@AmS \prepunct@AmS \if T\ismon@AmS \unhbox\monbox@AmS\unskip\a@comma \fi \unhbox\yrbox@AmS\unskip\setpunct@AmS \else \if T\ismon@AmS \ppunbox@AmS\monbox@AmS\setpunct@AmS \fi \fi } % This version produces JACM format references. \def\endref@JACM{% \endref@startup \if T\refi@AmS \hbox to \key@size{\cite@font [\unhbox\keybox@AmS\unskip]\hfil}% \hangindent=\key@size \if T\isby@AmS \unhcopy\bybox@AmS\unskip \def\prepunct@AmS{\hskip7\p@ plus5\p@\relax}% \setbox\z@=\hbox{\unhbox\bybox@AmS\unskip}% \dimen@=\wd\z@ % We want \dimen0=max(\wd0, 2in) \ifdim\dimen@>2in \dimen@=2in \fi \setbox\bysamebox@AmS=\hbox{\hbox to\dimen@{\leaders\hrule\hfill.}}% \else \if T\isbysame@AmS \unhcopy\bysamebox@AmS\unskip \def\prepunct@AmS{\hskip7\p@ plus5\p@\relax}% \fi \fi \fi \if T\ispaper@AmS \ppunbox@AmS\paperbox@AmS\def\prepunct@AmS{. }% \fi \if T\ispaperinfo@AmS \ppunbox@AmS\paperinfobox@AmS\def\prepunct@AmS{. }% \fi \if T\isjour@AmS \ppunbox@AmS\jourbox@AmS\setpunct@AmS \editor@ref \if T\isjourinfo@AmS \ppunbox@AmS\jourinfobox@AmS\setpunct@AmS \fi \if T\isvol@AmS \ \unhbox\volbox@AmS\unskip \fi \if T\isissue@AmS \ppunbox@AmS\issuebox@AmS\setpunct@AmS \fi \date@JACM \if T\istoappear@AmS \ (to appear)\setpunct@AmS \fi \if T\ispages@AmS \ppunbox@AmS\pagesbox@AmS\setpunct@AmS \fi \if T\ispage@AmS \prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS \fi \fi \endref@finishup\date@JACM } % This version produces IEEE format references. \def\endref@IEEE{% \endref@startup \if T\refi@AmS \hbox to \key@size{\cite@font [\unhbox\keybox@AmS\unskip]\hfil}% \hangindent=\key@size \if T\isby@AmS \unhcopy\bybox@AmS\unskip\setpunct@AmS \setbox\z@=\hbox{\unhbox\bybox@AmS\unskip}% \dimen@=\wd\z@ % We want \dimen0=max(\wd0, 2in) \ifdim\dimen@>2in \dimen@=2in \fi \setbox\bysamebox@AmS=\hbox{\hbox to\dimen@{\leaders\hrule\hfill}}% \else \if T\isbysame@AmS \unhcopy\bysamebox@AmS\unskip\setpunct@AmS \fi \fi \fi \if T\ispaper@AmS \prepunct@AmS``\unhbox\paperbox@AmS\unskip,'' \let\prepunct@AmS=\empty \fi \if T\ispaperinfo@AmS \ppunbox@AmS\paperinfobox@AmS\def\prepunct@AmS{, }% \fi \if T\isjour@AmS \ppunbox@AmS\jourbox@AmS\setpunct@AmS \editor@ref \if T\isjourinfo@AmS \ppunbox@AmS\jourinfobox@AmS\setpunct@AmS \fi \if T\isvol@AmS \prepunct@AmS vol.~\unhbox\volbox@AmS\unskip\setpunct@AmS \fi \if T\isissue@AmS \prepunct@AmS no.~\unhbox\issuebox@AmS\unskip\setpunct@AmS \fi \if T\istoappear@AmS \ (to appear)\setpunct@AmS \fi \if T\ispages@AmS \prepunct@AmS pp.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS \fi \if T\ispage@AmS \prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS \fi \if T\ispubladdr@AmS \ppunbox@AmS\publaddrbox@AmS \if T\ispubl@AmS \def\prepunct@AmS{: }\else\setpunct@AmS\fi \fi \if T\ispubl@AmS \ppunbox@AmS\publbox@AmS\setpunct@AmS \fi \let\ispubl@AmS=F\let\ispubladdr@AmS=F% For finishup routine \date@IEEE \fi \endref@finishup\date@IEEE } % By default, we use JACM format references \let\endref@AmS=\endref@JACM % But it's possible to get the other format \def\IEEE{% \gdef\using@IEEE{T}% Now we're using IEEE format. \let\editors=\ieee@editors \let\endref@AmS=\endref@IEEE \refdef@AmS\vol{}% Vol not printed in slanted any more. \global\let\appearing@in=\empty % Don't say that in IEEE format. \let\volume=\vol \let\book@font=\twelveit % Book and journal titles in this font. \oktell{IEEE Bibliography Style}% } % References Dump \newwrite\dump@file \catcode`\{=12 \catcode`\}=12 \catcode`\%=12 \catcode`\[=1 \catcode`\]=2 \def\ref@open[{] \def\ref@close[}] \def\ref@comment[%] \catcode`\{=1 \catcode`\}=2 \catcode`\%=14 \catcode`\[=12 \catcode`\]=12 \def\refdump{% \vfill\supereject \begingroup \content\reftitle \tell{Dumping \reftitle\space to refdump.tex}% \immediate\openout\dump@file=refdump \immediate\write\dump@file{% \noexpand\catcode`\noexpand\@=11 ^^J% \noexpand\let\noexpand\content=\noexpand\eat@AmS^^J% \noexpand\pageno=\the\pageno^^J% \noexpand\def\noexpand\ref@set\ref@open\ref@comment }% \def\\##1{\immediate\write\dump@file{ \noexpand\\{##1}\ref@comment}}% \ref@set \immediate\write\dump@file{% \ref@close^^J% }% \immediate\closeout\dump@file \endgroup } %%%%%%%%%%%%%%%%%%%% % OUTPUT CONTROL % %%%%%%%%%%%%%%%%%%%% % Control for informational messages. Default is \verbose mode. \newif\iftell@all \let\verbose=\tell@alltrue \let\quiet=\tell@allfalse \verbose \def\oktell#1{\iftell@all\tell{#1}\fi} \def\okmessage#1{\iftell@all\message{#1}\fi} % Chapter macro parameters \newcount\chapterno \chapterno=\z@ % Number of current chapter \newif\ifnumber@chapters \number@chapterstrue % By default, number the chapters \def\nochapternumbers{% \number@chaptersfalse \oktell{No Chapter Numbers mode}% } % Same thing for sections, subsections, etc \newcount\sectno \sectno=\@ne \newcount\subsectno \subsectno=\@ne \newcount\subsubsectno \subsubsectno=\@ne \newif\ifnumber@sections \def\numbersections{% \number@sectionstrue \oktell{Section Numbers mode}% } %%%%%%%%%%%%%%%%%%%%%%%%%%% % OUTPUT CONTROL MACROS % %%%%%%%%%%%%%%%%%%%%%%%%%%% % Center, left justify, right justify -- avoid exceeding margins \def\centerline#1{\line{\hfill#1\hfill}} \def\leftline#1{\line{#1\hfill}} \def\rightline#1{\line{\hfill#1}} \def\threepart#1#2#3{\line{\hskip\leftskip\rlap{#1}\hfill#2\hfill \llap{#3}\hskip\rightskip}} % End of the main body of the document \let\enddiss=\bye % Summary Information \outer\def\showsummary{% \begingroup \def\note##1##2##3##4{% \count@=##1 \advance\count@ by##3 \ifcase\count@ \message{No ##2s##4}\or \message{1 ##2##4}\else \message{\the\count@\space ##2s##4}\fi }% \note\fignumber{figure}{-1}{,}% \note\tablenumber{table}{-1}{,}% \note\note@count{footnote}{-1}{,}% \cardinality\ref@set\to\count@ \note\count@{citation}{0}{.}% \endgroup } % Real version of ragged right margins \def\raggedright{% \rightskip=\z@ plus 2em \oktell{Raggedright mode}% } % Disallow hyphenation -- a very dangerous thing \def\nohyphens{% \hyphenpenalty=\@M\tolerance=500\pretolerance=\@M \oktell{Nohyphens mode}% } % Allow capitalized words to be hyphenated \def\hyphenall{% \uchyph=\@ne \oktell{Hyphenating all words}% } % Handle a long quotation in a standard way \def\bigquote#1\endbigquote{% \par \vskip \baselineskip \vskip -\parskip { \advance\rightskip by30\p@ \advance\leftskip by30\p@ \smallertype \singlespace \let\\=\newline \noindent\llap{``}\ignorespaces#1\unskip''\par }% End of singlespacing and special indentation \vskip \baselineskip \vskip -\parskip } %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % CHAPTERS, SECTIONS, FIGURES, TABLES % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % What to do at the beginning of a chapter \def\chapter#1\endchapter{ \chapter@base #1\endchapter \oktell{Chapter \number\chapterno: #1} \content{Chapter \number\chapterno: #1} } % This boolean controls whether chapters are made to start only on % odd pages. \newif\ifoddpages \oddpagesfalse \def\twosided{% This is the ``official'' command \oddpagestrue \oktell{Twosided mode}% } % The guts of the \chapter command. \chapter==\chapter@base when % in \articlestyle. \def\chapter@base#1\endchapter{ \par \clearpage % Clean up from prev chapter \ifoddpages % Make sure start on even page. \ifodd\pageno \relax \else \null\vfill\eject \fi \fi \pageno@foot % Page #ing special for chap pages \advance\chapterno by\@ne \ifnumber@chapters \centerline{\chap@font CHAPTER \number\chapterno}% Do heading \fi \sectno=\z@ \subsectno=\z@ \subsubsectno=\z@ {\let\\=\cr \tabskip=\z@ \chap@font % Center the chapter title \halign to\hsize{\centerline{\ignorespaces##\unskip}\cr#1\cr} } \nobreak % Shouldn't happen anyway \vskip 1.0in minus 0.15in } % What to do at the beginning of a section \outer\def\section{\dosection} \def\dosection#1{% \skip@=\lastskip % \par resets \lastskip, apparently \par % This junk trys to provide consistent spacing \dimen@=\baselineskip \ifdim\skip@<\dimen@ \ifdim\skip@=\z@ \penalty-200 \fi \vskip \dimen@ plus .5\baselineskip \fi \ifnumber@sections \advance\sectno by\@ne \subsectno=\z@ \subsubsectno=\z@ \leftline{\sec@font\number\sectno. #1} \else \leftline{\sec@font#1} \fi \subcontent{#1} \sanetell{ Section: #1} \nobreak \vskip \z@ plus .15\baselineskip \vskip -\parskip } % And for sub-sections \outer\def\subsection{\dosubsection} \def\dosubsection#1{% \skip@=\lastskip \par \dimen@=.6\baselineskip \ifdim\skip@<\dimen@ \ifdim\skip@=\z@ \penalty-100 \fi \vskip \dimen@ plus .3\baselineskip \fi \ifnumber@sections \advance\subsectno by\@ne \subsubsectno=\z@ \leftline{\subsec@font\number\sectno.\number\subsectno. #1} \else \leftline{\subsec@font#1} \fi \subsubcontent{#1} \sanetell{ \\Subsection: #1} \nobreak \vskip \z@ plus .1\baselineskip \vskip -\parskip } % And for sub-sub-sections \outer\def\subsubsection{\dosubsubsection} \def\dosubsubsection#1{% \skip@=\lastskip \par \dimen@=.5\baselineskip \ifdim\skip@<\dimen@ \ifdim\skip@=\z@ \penalty-50 \fi \vskip \dimen@ plus .3\baselineskip \fi \ifnumber@sections \advance\subsubsectno by\@ne \leftline{\subsubsec@font\number\sectno.\number\subsectno .\number\subsubsectno. #1} \else \leftline{\subsubsec@font#1} \fi \subsubsubcontent{#1} \sanetell{ \\\\Subsubsection: #1} \nobreak \vskip -\parskip } % This is an alternate definition for plain TeX's \@ins, % omitting the \par. It is for use during \figure etc. Reason: % If you use \figure right after \section, it would otherwise % become a legal place for a page break. \def\@ins@uci{\begingroup\setbox\z@\vbox\bgroup} % This is \endinsert from plain.tex, but \midinsert's are not converted % to \topinsert's, since that can lead to figures getting out of order. % This can lead to excessive blank space at the bottom of the page, but % that's life. Makes use of \keep...\endkeep type stuff. \def\endinsert{\egroup % finish the \vbox \if@mid \dimen@\ht\z@ \advance\dimen@\dp\z@ \advance\dimen@12\p@ \vskip\z@ plus\dimen@ \penalty\z@ \vskip\z@ plus-\dimen@ \bigskip\box\z@\bigbreak \else\insert\topins{\penalty100 % floating insertion \splittopskip\z@skip \splitmaxdepth\maxdimen \floatingpenalty\z@ \ifp@ge \dimen@\dp\z@ \vbox to\vsize{\unvbox\z@\kern-\dimen@}% depth is zero \else \box\z@\nobreak\bigskip\fi}\fi\endgroup} % This macro provides rudamentary support for figures. The % argument to \figure is the name of the file containing the tpic (or whatever) % output. The second argument is the caption for the picture. % As usual, TeX's delayed paging and midinserting causes expansion-timing % problems which have to be kludged around. \newif\iftopfigs \topfigstrue \def\domidfigs{% \topfigsfalse \oktell{Midfigs mode}% } % Counters for figures/diagrams/examples and tables \newcount\fignumber \fignumber=\@ne \newcount\tablenumber \tablenumber=\@ne % Helper for \figure, \example, and \diagram. Define \lastfigure and % \this@insert, increment the figure number for next time, and make sure % the figures list file is open for writing. % #1=the caption, to be written to the figures list file \def\advance@figno#1{% \xdef\lastfigure{\the\fignumber}% Remember the current figure number \begingroup\no@cites \let\\=\space \xdef\this@insert{\write\noexpand\fig@file{\noexpand\noexpand \noexpand\listfig{\lastfigure}{#1}% {\noexpand\number\noexpand\pageno}% }% }% \endgroup \global\advance\fignumber by\@ne \iffig@closed % Open figures file if not already \immediate\openout\fig@file=\figtitle \global\fig@closedfalse \fi } % Bump the table number after defining \lasttable. Prepare \this@insert. % Define \table@caption. \def\advance@tablenumber#1{% \xdef\lasttable{\the\tablenumber}% Remember the current figure number \begingroup \no@cites \let\\=\space \xdef\this@insert{\write\noexpand\tab@file{\noexpand\noexpand \noexpand\listfig{\lasttable}{#1}% {\noexpand\number\noexpand\pageno}% }% }% \endgroup \global\advance\tablenumber by\@ne \gdef\table@caption{#1}% } \newif\ifpage@figs \page@figsfalse % Special mode to put figures/diagrams/examples on separate pages \def\pagefigs{% \oktell{Page Figures mode}% \page@figstrue } % Usage: \figure{filename}{caption with \\'s} \def\figure#1#2{% \begingroup % Hide anything that crazy user does! \advance@figno{#2}% % Now do mid or top insert as appropriate \let\@ins=\@ins@uci \ifpage@figs \shipout\vbox to\vsize\bgroup {\smallertype\rm\input #1\relax\centerline{\box\graph}}% \vfill \centerline{Figure \lastfigure}\this@insert \egroup \else \iftopfigs \topinsert \else \midinsert \fi \hrule \vskip .5\baselineskip {\smallertype\rm\input #1\relax\centerline{\box\graph}}% \vskip .5\baselineskip plus .5\baselineskip \centerline{\twelvebf Figure \lastfigure}% \this@insert \let\\=\cr \tabskip=\z@ \halign to\hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}% \vskip2\p@ \hrule \endinsert \fi \endgroup } % Allow user to specify arbitrary diagrams. The arguments are: % #1=name of the file containing the commands to form the diagram, % #2=caption for the figure, possibly containing \\'s. \def\diagram#1#2{% \begingroup \advance@figno{#2}% % Do mid or top insert as appropriate \let\@ins=\@ins@uci \ifpage@figs \shipout\vbox to\vsize\bgroup {\smallertype\rm\input #1\relax}% \vfill \centerline{\twelverm Figure \lastfigure}\this@insert \egroup \else \iftopfigs \topinsert \else \midinsert \fi \hrule \vskip .5\baselineskip {\smallertype\rm\input #1\relax}% \vskip .5\baselineskip plus .5\baselineskip \centerline{\twelvebf Figure \lastfigure}% \this@insert \let\\=\cr \tabskip=\z@ \halign to \hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}% \vskip2\p@ \hrule \endinsert \fi \endgroup } % Allow user to include verbatim examples from files. The arguments are: % #1=name of the file containing the text of the example, % #2=caption for the figure, possibly containing \\'s. \def\example#1#2{% \begingroup \advance@figno{#2}% % Do mid or top insert as appropriate \let\@ins=\@ins@uci \ifpage@figs \shipout\vbox to\vsize\bgroup \vbox{\smallertype\singlespace\verbfile{#1}}% \vfill \centerline{\twelverm Figure \lastfigure}\this@insert \egroup \else \iftopfigs \topinsert \else \midinsert \fi \hrule \vskip .5\baselineskip \vbox{\smallertype\singlespace\verbfile{#1}}% \vskip .5\baselineskip plus .5\baselineskip \centerline{\twelvebf Figure \lastfigure}% \this@insert \let\\=\cr \tabskip=\z@ \halign to \hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}% \vskip2\p@ \hrule \endinsert \fi \endgroup } % Similar thing for tables % usage: \table{caption} ...text... \endtable \def\table#1{% \begingroup % Hide user zingers \advance@tablenumber{#1}% \setbox\z@=\vbox\bgroup } % End of the table body specification. \def\endtable{% \egroup % End the definition of \box0. % Now do top or mid insert \let\@ins=\@ins@uci \iftab@closed % Open output file if necessary \immediate\openout\tab@file=\tabtitle \global\tab@closedfalse \fi \ifpage@figs \shipout\vbox to\vsize\bgroup \box\z@ \vfill \centerline{\twelverm Table \lasttable}\this@insert \egroup \else \iftopfigs \topinsert \else \midinsert \fi \hrule \vskip .5\baselineskip \box\z@ % Insert the material here. \vskip .5\baselineskip plus .5\baselineskip \centerline{\twelvebf Table \lasttable}% \this@insert \let\\=\cr \tabskip=\z@ \halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\table@caption \cr}% \vskip2\p@ \hrule \endinsert \fi \endgroup } % End of the table body specification for a full-page table. \def\endtablepage{% \egroup % End the definition of \box0. % Now do top or mid insert \let\@ins=\@ins@uci \iftab@closed % Open output file if necessary \immediate\openout\tab@file=\tabtitle \global\tab@closedfalse \fi \ifpage@figs \shipout\vbox to\vsize\bgroup \box\z@ \vfill \centerline{\twelverm Table \lasttable}\this@insert \egroup \else \pageinsert \hrule \vskip .5\baselineskip \box\z@ % Insert the material here. \vskip .5\baselineskip plus .5\baselineskip \centerline{\twelvebf Table \lasttable}% \this@insert \let\\=\cr \tabskip=\z@ \halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\table@caption \cr}% \vskip2\p@ \hrule \endinsert \fi \endgroup } % Environment for report generation -- use only at the beginning! % Since sections are the biggest division, the table of contents % stuff is redefined, and chapter numbering is turned off so that % \chapter can be used for the first-page title. The title page % gets no page number (page # 0). The user can get to the % normal chapter font as \titlefont, and the section font as % \authorfont. \def\articlestyle{% \nochapternumbers \let\subsubsubcontent=\subsubcontent \let\subsubcontent=\subcontent \let\subcontent=\content \let\chapter=\chapter@base \pageno=\z@ \let\titlefont=\chap@font \let\authorfont=\sec@font \oktell{Articlestyle mode}% } %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % PAGE NUMBERING and OUTPUT ROUTINES % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % This macro produces a blank, numbered page of output \def\blankpage{\pageinsert \null\vfill \endinsert} % This defintion of \folio differs from Plain's in that (a) page % numbers are printed in 12pt, and (b) roman numeral ones are % printed in italics. It makes use of a trick, that % \romannumeral0 produces no output, which we need for title % pages and things, so we make their page numbers be 0. \def\folio{\ifnum\pageno>\z@ {\twelverm\number\pageno}\else {\twelveit\romannumeral-\pageno}\fi } % Permanent definitions of macros which get switched in and out % with \let's. Do not change any of these !!! \def\uci@headpage{\hfill\folio} \def\uci@footpage{\hfill\folio\hfill} \headline={\uci@headline} \footline={\uci@footline} % If this is used as the footline, it causes a page number to be % printed, but with the side-effect of making the headline blank % and the footline a page number again. This is used on pages % like the first of a chapter. \def\no@foot{% \uci@footpage \global\let\uci@footline=\hfil \global\let\uci@headline=\uci@headpage } % This macro causes the page number to be at the bottom of the current % page, and after it has been used there once, it moves to the % top right of each page. It also sets \dimen\topins=0pt so that % any material \topinsert'd on these pages will get carried over % to subsequent pages. \def\pageno@foot{% \dimen\topins=\z@ \let\uci@headline=\hfil \let\uci@footline=\no@foot } % Executing this causes page numbers to be at the bottom only, as % with the plain TeX format. \def\plain@page@numbers{% \let\uci@headline=\hfil % Initial values similar to plain's \let\uci@footline=\uci@footpage } % Change plain's \makeheadline and \makefootline to position page % numbers as required. \def\makeheadline{% \vbox to\z@{\vskip-22.65\p@ \line{\vbox to8.5\p@{}\the\headline}\vss}\nointerlineskip } \def\makefootline{\baselineskip=1.6cm\line{\the\footline}} % Define an output routine which will restore \dimen\topins % after \chapter, \references, etc, title pages, which have % \dimen\topins=0pt \def\dissoutput{\shipout\vbox{\makeheadline\pagebody\makefootline}% \advancepageno \global\dimen\topins=\vsize \ifnum\outputpenalty>-\@MM \else\dosupereject\fi } \let\output@AmS=\dissoutput \dimen\topins=\vsize % Don't insert more than will fit on one page % Output Routines: We adjust the \raggedbottom command of plain % TeX so that the extra space is no more than 1in, and so that % the space is put above footnotes instead of below. NOTE: Since % we put a \vfil below the page contents, the topskip glue will % never actually be stretched. Its stretchability is just to % let TeX know about the raggedness in computing when to make a % page break. Since it's 1in, the \vfil will never be stretched to % more than that amount. \def\raggedbottom{\topskip=\normal@topskip plus1in \r@ggedbottomtrue \oktell{Ragged bottom mode}} \def\normalbottom{\topskip=\normal@topskip\r@ggedbottomfalse \oktell{Normal bottom mode}} \def\pagecontents{% \ifvoid\topins\else\unvbox\topins\fi \dimen@=\dp\@cclv \unvbox\@cclv % open up \box255 \ifr@ggedbottom \kern-\dimen@ \vfil\fi \ifvoid\footins \else % footnote info is present \vskip\skip\footins \footnoterule \unvbox\footins \fi } %%%%%%%%%%%%%%%%%%%% % INITIALIZATION % %%%%%%%%%%%%%%%%%%%% \font@no=0 % Default font=\rm, \twelvepoint % point size, \doublespace % and spacing \plain@page@numbers % Page nos like plain's % Note that normally in AmSTeX, the @ character may not be used. % But in the dissertation style, @ may be used as a normal character, % As it can in plain TeX. \catcode`\@=12 % Eat any further \documentstyle commands \def\documentstyle#1{} % This prints out our welcome message, and it computes the time % and date string once per run, which saves time if they're used % more than once. Since \catcode`@=12 at the time this is % executed, it can't contain any @-type macros. \everyjob={% \begingroup \xdef\today{% \ifcase\month \the\month\or January\or February\or March\or April\or May\or June\or July\or August\or September\or October\or November\or December\else \the\month \fi\space\the\day, \the\year }% \count0=\time \count1=\count0 \divide\count0by60 \count2=\count0 \multiply\count0by60 \advance\count1by-\count0 \ifnum\count2>11 \ifnum\count2>12 \advance\count2by-12\fi \def\ampm{PM}% \else \ifnum\count2=0 \advance\count2by12\fi \def\ampm{AM}% \fi \xdef\daytime{% \ifnum\count2<10 0\fi \the\count2:% \ifnum\count1<10 0\fi \the\count1 \ampm }% \endgroup \tell{AmSTeX Dissertation Style, version \version}% } \edef\temp@uci{\the\everyjob} \temp@uci