-
Notifications
You must be signed in to change notification settings - Fork 15
/
example-programming.tex
966 lines (841 loc) · 37.3 KB
/
example-programming.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
% -*- coding: utf-8; -*-
% vim: set fileencoding=utf-8 :
\documentclass[english,submission]{programming}
%% First parameter: the language is 'english'.
%% Second parameter: use 'submission' for initial submission, remove it for camera-ready (see 5.1)
\usepackage[backend=biber]{biblatex}
\addbibresource{example.bib}
%
% Packages and Commands specific to article (see 3)
%
% These ones are used in the guide, replace with your own.
%
\usepackage{multicol}
\usepackage{ccicons}
\lstdefinelanguage[programming]{TeX}[AlLaTeX]{TeX}{%
deletetexcs={title,author,bibliography},%
deletekeywords={tabular},
morekeywords={abstract},%
moretexcs={chapter},%
moretexcs=[2]{title,author,subtitle,keywords,maketitle,titlerunning,authorinfo,affiliation,authorrunning,paperdetails,acks,email},
moretexcs=[3]{addbibresource,printbibliography,bibliography},%
}%
\lstset{%
language={[programming]TeX},%
keywordstyle=\firamedium,
stringstyle=\color{RosyBrown},%
texcsstyle=*{\color{Purple}\mdseries},%
texcsstyle=*[2]{\color{Blue1}},%
texcsstyle=*[3]{\color{ForestGreen}},%
commentstyle={\color{FireBrick}},%
escapechar=`,}
\newcommand*{\CTAN}[1]{\href{http://ctan.org/tex-archive/#1}{\nolinkurl{CTAN:#1}}}
%%
%%%%%%%%%%%%%%%%%%
%% These data MUST be filled for your submission. (see 5.3)
\paperdetails{
%% perspective options are: art, sciencetheoretical, scienceempirical, engineering.
%% Choose exactly the one that best describes this work. (see 2.1)
perspective=art,
%% State one or more areas, separated by a comma. (see 2.2)
%% Please see list of areas in http://programming-journal.org/cfp/
%% The list is open-ended, so use other areas if yours is/are not listed.
area={Social Coding, General-purpose programming},
%% You may choose the license for your paper (see 3.)
%% License options include: cc-by (default), cc-by-nc
% license=cc-by,
}
%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%
%% These data are provided by the editors. May be left out on submission.
%\paperdetails{
% submitted=2016-08-10,
% published=2016-10-11,
% year=2016,
% volume=1,
% issue=1,
% articlenumber=1,
%}
%%%%%%%%%%%%%%%%%%
\begin{document}
\title{The Art, Science, and Engineering of Programming}
\subtitle{Preparing Articles for Programming}% optional
\titlerunning{Preparing Articles for Programming} %optional, in case that the title is too long; the running title should fit into the top page column
\author[a]{Tobias Pape}[0000-0003-0110-6918]
\authorinfo{is the author of this {LaTeX} class. Contact him at
\email{[email protected]}.}
\affiliation[a]{Hasso Plattner Institute, University of Potsdam, Germany}
\author{Cristina V. Lopes}[orcid.org/0000-0003-0551-3908]
\authorinfo{is associate editor for the first two issues of The Art, Science,
and Engineering of Programming. Contact her at \email{[email protected]}.}
\affiliation{University of California, Irvine, USA}
\author[a]{Robert Hirschfeld}[https://orcid.org/0000-0002-4249-6003]
\authorinfo{is chair of the AOSA steering committee. The Art, Science,
and Engineering of Programming is published by AOSA. Contact Robert at \email{[email protected]}.}
% \authorrunning{T. Pape, C. Lopes, R. Hirschfeld} % Optional, for long author lists
\keywords{programming journal, paper formatting, submission preparation} % please provide 1--5 keywords
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Please go to https://dl.acm.org/ccs/ccs.cfm and generate your Classification
% System [view CCS TeX Code] stanz and copy _all of it_ to this place.
%% From HERE
\begin{CCSXML}
<ccs2012>
<concept>
<concept_id>10002944.10011122.10003459</concept_id>
<concept_desc>General and reference~Computing standards, RFCs and guidelines</concept_desc>
<concept_significance>300</concept_significance>
</concept>
<concept>
<concept_id>10010405.10010476.10010477</concept_id>
<concept_desc>Applied computing~Publishing</concept_desc>
<concept_significance>300</concept_significance>
</concept>
</ccs2012>
\end{CCSXML}
\ccsdesc[300]{General and reference~Computing standards, RFCs and guidelines}
\ccsdesc[500]{Applied computing~Publishing}
% To HERE
%%%%%%%%%%%%%%%%%%%%%%%
\maketitle
% Please always include the abstract.
% The abstract MUST be written according to the directives stated in
% http://programming-journal.org/submission/
% Failure to adhere to the abstract directives may result in the paper
% being returned to the authors.
\begin{abstract}
Many academic journals and conferences exist that publish
research related to programming, starting with programming languages,
software engineering, and expanding to the whole Computer Science field. Yet,
many of us feel that, as the field of Computer Science expanded, programming,
in itself, has been neglected to a secondary role not worthy of scholarly
attention.
We posit that a scholarly journal focusing primarily on programming
will help close this gap, and foster a more meaningful bridge
between research and the practice of software development.
The Art, Science, and Engineering of Programming accepts papers
under several perspectives: the art itself (programming styles,
pearls, models, languages), the emerging science of understanding what works
and what doesn’t work in general and in specific contexts, as well as more
established engineering and mathematical perspectives.
This journal aims at placing the wonderful art of programming in the
map of scholarly works.
We present this short paper as an example of, and a guide to,
writing articles for The Art, Science, and Engineering of
Programming journal. The complete template is provided: the class
file (\texttt{programming.cls}), an example paper (\texttt{example-programming.tex}, this file), and an example
bibliography file (\texttt{example.bib}).
Much of the progress in Computer Science lies on the basis of
computer programs, the people who write them, and the concepts and
tools available to them to express computational tasks. The
existence of a journal focusing on programming is of utmost
importance for strengthening our understanding of these activities.
\end{abstract}
\section{A Guided Tour}
\label{sec:guided-tour}
The content of a paper is its most important ingredient. That being said,
papers for The Art, Science, and Engineering of Programming should adhere to a
common style, which is achieved with the \lstinline|programming| {LaTeX}
class. You are to use this class as outlined here when submitting articles to
the journal. This document acts as an example of what this can look like and a
short references for all its parts.
\subsection{Document Parts}
\label{sec:document-parts}
\begin{lstlisting}[float,label=lst:tour,caption={A very minimal article.}]
\documentclass[english,submission]{programming}`\label{l:doc}`
\usepackage[backend=biber]{biblatex} % Use Biblatex `\label{l:bib}`
\addbibresource{example.bib}
\paperdetails{`\label{l:details}`
perspective=engineering,
area={General-purpose programming}
}
\begin{document}
\title{The importance of why and how to do work}`\label{l:meta}`
\author{Anna Author}
\affiliation{The Unseen University, Ankh-Morpork}
\author{Bert Betatester}
\affiliation{Carolingian Minuschool Academy, Bodoni, San Serriffe}
\keywords{paper, showcase, lorem ipsum}`\label{l:keywords}`
\begin{CCSXML}`\label{l:ccs:start}`
<ccs2012>
<concept>
<concept_id>10002944.10011122.10003459</concept_id>
<concept_desc>General and reference~Computing standards, RFCs and guidelines</concept_desc>
<concept_significance>300</concept_significance>
</concept>
</ccs2012>
\end{CCSXML}
\ccsdesc[300]{General and reference~Computing standards, RFCs and guidelines}`\label{l:ccs:end}`
\maketitle
\begin{abstract}
This paper shows...
\end{abstract}
\section{Introduction}
The art of computer programming~\cite{DBLP:journals/cacm/Knuth74}...
\section{...}
...
\acks`\label{l:acks}`
I want to thank ....
\printbibliography
\end{document}
\end{lstlisting}
{\lstset{language=}%
We have included a most minimal article in \autoref{lst:tour} that you can
adapt to the concrete work to be submitted. First, you
have to select the \lstinline|programming| class as in \autoref{l:doc}. The
parameter \lstinline|english| is for language selection (optional, but
recommended). The other parameter, \lstinline|submission|, is crucial for the
reviewing process and must be included for submission. More information on
document parameters can be found in \autoref{sec:class-options}. After that,
we recommend that you load the \lstinline|biblatex| package. While it is %
perfectly fine to use plain {BibTeX}, we recommend
\lstinline|biblatex|, as it has native Unicode support and can handle
\textsc{url}s and \textsc{doi}s better. In both cases, we have preloaded a
bibliography style.
At that point, you can load necessary {LaTeX} packages. We already load some
important packages with the \lstinline|programming| class and that there are
certain packages that are not recommended or incompatible with this class.
Refer to \autoref{sec:pack-cons} for which packages are recommended. Then you
start the document with \lstinline|\begin{document}|.
You have to provide details to your submission that will be used during the
review process. For that, use the \lstinline|paperdetails| command and
specify \emph{perspective} and \emph{area} of your submission. For
perspective, choose from one of the \emph{Art}, \emph{theoretical} or
\emph{empirical} \emph{Science}, or \emph{Engineering} and provide it as
argument to the \lstinline|perspective| keyword; they can be found in
\autoref{sec:perspective}. For area, specify an argument to the
\lstinline|area| keyword (in braces). Find a list of suggested areas in
\autoref{sec:area-submission}.
We need you to provide certain metadata which you can do with the following
commands, as form \autoref{l:meta}. You can specify the title and maybe the subtitle with
\lstinline|\title| (and \lstinline|\subtitle|, respectively). Then please
list all authors. For that, use one \lstinline|\author| command per author
and give an affiliation for each with \lstinline|\affiliation|. When several
consecutive authors share the same affiliation, you should only use one
\lstinline|\affiliation| command after the last of them. More information can
be found in \autoref{sec:document-metadata}.
Please include one to five keywords, separated by commas, that are important to
your work with the \lstinline|\keywords| command as in \autoref{l:keywords}. We
kindly ask you to classify your work using the \emph{ACM Computing
Classification System}\footnote{\url{https://dl.acm.org/ccs/ccs.cfm}.}.
Please visit the ACM's website and generate the {TeX} code that matches
your classification. The code should consist of a \lstinline|CCSXML|
environment and several \lstinline|\ccsdesc| commands, as in lines
\ref{l:ccs:start} to \ref{l:ccs:end}.
With \lstinline|\maketitle| and the \lstinline|abstract| environment, you can
produce the article's title page. Then you can start with your content. If
applicable, you can put acknowledgements at the end after an \lstinline|\acks|
command, as in \autoref{l:acks}.}
\subsection{Running {LaTeX}}
\label{sec:running}
This class has been tested with the popular {LaTeX} programs available.
It should work with {pdfLaTeX}, {LuaLaTeX}, and {XeLaTeX}.
We suggest that you use {LuaLaTeX}, which is included in all major
{TeX} system installations, has a good Unicode support, and is well portable.
Please do not use the LaTeX/dvips combination to produce output files.
To get all metadata right, several LaTeX runs will be necessary. Hence, a
typical run looks like this:
\begin{lstlisting}[language=]
lualatex myarticle
biber myarticle
lualatex myarticle
lualatex myarticle
\end{lstlisting}
You should replace \lstinline|lualatex| with the LaTeX program of your choice,
and \lstinline|biber| with \lstinline|bibtex| if you do not want to use
Biblatex (or use Biblatex's BibTeX backend).
Your \textsc{pdf} file for your article should then be ready for submission.
\section{Submission Classification}
Almost anything about programming is in scope for The Art, Science, and
Engineering of Programming. However, you should classify your article according
to the following aspects.
\subsection{Perspective}
\label{sec:perspective}
We accept descriptions of work under different perspectives:
\emph{The Art.} This perspective is about knowledge and technical skills acquired through
practice and personal experiences. Examples include libraries, frameworks,
languages, APIs, programming models and styles, programming pearls, and essays
about programming.
\emph{Science (theoretical).} This perspective is about knowledge and technical skills acquired
through mathematical formalisms. Examples include formal programming models and
proofs.
\emph{Science (empirical).} This perspective is about knowledge and technical skills acquired
through experiments and systematic observations. Examples include user studies
and programming-related data mining.
\emph{Engineering.} This perspective is about knowledge and technical skills acquired through
designing and building large systems and through calculated application of
principles in building those systems. Examples include measurements of
artifacts’ properties, development processes and tools, and quality assurance
methods.
\bigskip
To classify your work as any of the above perspectives, please set the
\lstinline|perspective| keyword of the \lstinline|\paperdetails| command to
one of the following values:
\begin{description}
\item[art] for submissions concerning \emph{The Art } (\textsf{theart} is a
proper alias);
\item[sciencetheoretical] For submissions concerning \emph{Science
(theoretical)}, with the aliases \textsf{sciencetheoretical},
\textsf{theoreticalscience}, \textsf{theoretical},
\textsf{science-theoretical}, and finally \textsf{theoretical-science};
\item[scienceempirical] for submissions concerning \emph{Science (empirical)},
the valid aliases are \textsf{scienceempirical}, \textsf{empiricalscience},
\textsf{empirical}, \textsf{science-empirical}, and
\textsf{empirical-science}; and
\item[engineering] for submissions concerning \emph{Engineering}.
\end{description}
\subsection{Area of Submission}
\label{sec:area-submission}
Independent of the type of work, the journal accepts submissions covering
several expertise areas. Expertise areas include, but are not limited to:
\begin{itemize}
\item General-purpose programming
\item Distributed systems programming
\item Parallel and multi-core programming
\item Graphics and GPU programming
\item Security programming
\item User interface programming
\item Database programming
\item Visual and live programming
\item Data mining and machine learning programming, and for programming
\item Interpreters, virtual machines and compilers
\item Modeling and modularity
\item Testing and debugging
\item Program verification
\item Programming education
\item Programming environments
\item Social coding
\end{itemize}
To specify the area of expertise for your work, please set the
\lstinline|area| keyword of the \lstinline|\paperdetails| command to
one of the preceding suggested areas, or provide your own. Please use curly
braces \lstinline|{}| around the value.
\section{Choice of License (optional)}
All work published by The Art, Science, and Engineering of Programming will be
available as open-access. Therefore, authors submitting a paper to The Art,
Science, and Engineering of Programming should grant a Creative Commons
license. We support two licenses (description adapted from
Wikipedia\footnote{\url{https://en.wikipedia.org/w/index.php?title=Creative_Commons_license&oldid=754498632}}):
\begin{description}
\item[\ccby] \href{https://creativecommons.org/licenses/by/4.0}{Attribution 4.0
\textsmaller{\textsc{cc by 4.0}}}\\
{\small
Licensees may copy, distribute, display and perform the work and make
derivative works and remixes based on it only if they give the author or
licensor the credits (attribution) in the manner specified by these.}
\item[\ccbync]
\href{https://creativecommons.org/licenses/by-nc-sa/4.0}{Attribution-NonCommercial
4.0 \textsmaller{\textsc{cc by-nc 4.0}}}\\
{\small
Licensees may copy, distribute, display and perform the work and make
derivative works and remixes based on it only if they give the author or
licensor the credits (attribution) in the manner specified by these and only
for non-commercial purposes.}
\end{description}
%
To choose a license for your work, set the
\lstinline|license| keyword of the \lstinline|\paperdetails| command to
either \lstinline|cc-by| or \lstinline|cc-by-nc|. Please be aware that, in absence of a choice, we assume \textsc{cc by}.
\section{Typographical and Technical Aspects}
We have carefully chosen the presentation for articles published in The Art, Science, and
Engineering of Programming to fit on-screen reading and occasional printouts.
It is important to maintain a uniform look of all articles appearing in the
journal. We kindly ask you therefore to \emph{not} change the presentation. Most
importantly,
%
\begin{itemize}
\item please do not change the font or the font size for that matter. The text
font remains fixed as \emph{Charter} (in the XCharter variant) and emphasis
font is \emph{Fira Sans}. The only exception is the typewriter font, where
you can choose from two variants (please refer to
\autoref{sec:typewriter-fonts}). Moreover;
\item please do not change the margins or the line spacing;
\item please refrain from using the \lstinline|\sloppy| command, especially for
the whole document;
\item please avoid the use of the \lstinline|[H]| or \lstinline|[h!]| modifiers
for figures, tables, and similar elements;
\item please use a consistent formatting (for example, use the
\lstinline|siunitx| package~\cite{siunitx}).
\end{itemize}
%
This class has been tested on several LaTeX systems. We suggest that you use an
up-to-date system, for example
TeX\,Live\footnote{\url{https://www.tug.org/texlive/}.}, which is available for
Linux, Windows, and Apple systems, among others. We tested with the 2015 and
2016 systems and will make sure that it will work with upcoming systems, too.
Please first upgrade your system if problems with this class should occur.
Regarding the LaTeX system, please keep in mind to
%
\begin{itemize}
\item use LaTeX packages only if required, as fewer packages lower the
chance of conflicts (refer to \autoref{sec:pack-cons} for details);
\item keep the use of custom macros low to not interfere with provided
packages and use LaTeX commands to do so (for example, \lstinline|\newcommand| and
similar instead of TeX's \lstinline|\def|);
\item watch out for unsuitable line- and pagebreaks;
\item when using pixel graphics, provide at least 300\,dpi imagery,
\textsc{pdf} files preferred;
\item minimize the use of LaTeX comments, especially via block constructs;
\item consult the \emph{l2tabu} documentation~\cite{l2tabu} about outdated packages;
\item provide \textsc{doi}s for all your references, unless inaccessible.
\end{itemize}
%
We suggest the use of a spellchecker to avoid typos.
Please note that all article source must be \textsc{utf-8} encoded, no
exceptions.
\section{Detailed Reference}
Several aspects of this class as outlined above provide for some fine tuning.
\subsection{Class Options}
\label{sec:class-options}
As explained in~\autoref{sec:guided-tour}, submissions to the journal must use
the \lstinline|submission| package option. For the accepted final, to-be-published
version, this option should be omitted or replaced by \lstinline|crc| for
“Camera-ready Copy”. Actually, both are shortcuts for the
\lstinline|phase| keyword, which could be used, instead.
Hence, the following statements in either column are equivalent:\par\noindent
{\lstset{texcsstyle=*{\color{Purple}\mdseries\smaller}}
\begin{minipage}[t]{.45\linewidth}
\emph{Final phase}
\begin{lstlisting}
\documentclass[phase=final]{programming}
\documentclass[crc]{programming}
\documentclass{programming}
\end{lstlisting}
\end{minipage}%
\hfill%
\begin{minipage}[t]{.5\linewidth}
\emph{Submission phase}
\begin{lstlisting}[numbers= none]
\documentclass[phase=submission]{programming}
\documentclass[submission]{programming}
``
\end{lstlisting}
\end{minipage}}
\paragraph{Code Fonts}
\label{sec:typewriter-fonts}
The standard font for code, as selected with \lstinline|\texttt|,
\lstinline|\ttfamily|, or a listing, is set to be the same as the sans serif
font, \emph{Fira Sans}. This matches the rest of the document style very well.
However, it may be strictly necessary to have a non-proportional (or
monospaced) font for the typewriter style. We therefore provide a class option \lstinline|code|
to change the typewriter font.
It takes one the following values:
\begin{description}
\item[code=sf] Sets the code font to the sans serif font (Fira Sans). This is the
default. Aliases for this option are \lstinline|code=sans| and
\lstinline|code=sansserif|.
\item[code=tt] Sets the code font to Fira Sans' monospaced equivalent, Fira Mono. Aliases for this option are \lstinline|code=mono| and
\lstinline|code=monospace|. This is the preferred choice if monospaced
typewriter font is necessary. Note that this font does not have italics.
\end{description}
\paragraph{Other Options}
All other options give in the \lstinline|\documentclass| command are not
processed directly by the class but rather passed on to other packages as
``global options''. For example, the \lstinline|english| option from the
example above does not influence the \lstinline|programming| class directly,
but rather will be picked up by Babel~\cite{babel} to set up language options.
\subsection{Document Metadata}
\label{sec:document-metadata}
The presentation of the document metadata can be fine tuned, as well.
Besides the \lstinline|\title| and \lstinline|\subtitle| commands, there is the
\lstinline|\titlerunning| command to specify a shorter title when the normal
title does not fit into the page header. Similarly, the
\lstinline|\authorrunning| command can be used to specify the presentation of
the authors in the header.
Sometimes listing the affiliations of the authors can be tricky when they are
shared. An optional argument to the \lstinline|\author| and
\lstinline|\affiliation| command can be used to associate authors and
affiliations explicitly. Four variants for affiliations are outlined in the
beginning of \autoref{lst:affiliation}.
For the final publication, we ask you to provide a short information of each
author, typically a very short biography, and a photo. You can use the
\lstinline|\authorinfo| command right after an \lstinline|\author| command to
associate that author information with an author. See \autoref{l:authorinfo} in
\autoref{lst:affiliation} for example. The photo is given as optional argument
as file name in brackets (without file extension). Omitting the photo will
produce a blank space next to the author information. The actual information
follows as an argument. Note that the author's \emph{name} is prepended to the
information automatically and is not to be repeated.
An author's email address can be given in either the affiliation or author
information block. Please use the \lstinline|\email| command for that purpose.
\begin{lstlisting}[float,label=lst:affiliation,caption={Four
ways to specify affiliations\,/\,Author information example\,/\,Sample publication paper details}]
% Independent affiliations
\author{Anna Author}
\affiliation{The Unseen University, Ankh-Morpork}
\author{Bert Betatester}
\affiliation{Carolingian Minuschool Academy, Bodoni, San Serriffe}
% Shared affiliations
\author{Anna Author}
\author{Bert Betatester}
\affiliation{Carolingian Minuschool Academy, Bodoni, San Serriffe}
% Explicit affiliations
\author[a]{Anna Author}
\author[b]{Bert Betatester}
\author[a]{Claire Cadence}
\affiliation[a]{The Unseen University, Ankh-Morpork}
\affiliation[b]{Carolingian Minuschool Academy, Bodoni, San Serriffe}
% Mixed affiliations
\author[a]{Anna Author}
\author[a,b]{Bert Betatester}
\affiliation[a]{The Unseen University, Ankh-Morpork}
\affiliation[b]{Carolingian Minuschool Academy, Bodoni, San Serriffe}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Author information`\label{l:authorinfo}`
\author{Anna Author}
\authorinfo[anna]{is a researcher at the Unseen University in Ankh-Morpork and
a Ph\,D student to Rincewind. Contact her at
\email{[email protected]}}
\affiliation[a]{The Unseen University, Ankh-Morpork}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Sample publication paper details
\paperdetails{
submitted=2017-02-18,
published=2017-08-01,
year=2017,
volume=2,
issue=1,
articlenumber=4,
}
\end{lstlisting}
\subsection{Paper Details}
Besides specifying the perspective and area of the submission, the
\lstinline|\paperdetails| command is also used to provide publication
information for the final, camera-ready-copy phase (class option
\lstinline|phase=final|). In this case, perspective and area are removed from
the title page and the Digital Object Identifier (\textsc{doi}), as well as the
dates of submission and publications are presented instead. The information
necessary for this is provided \emph{by the publisher} after acceptance. It
includes the following information:
%
\begin{description}
\item[year] The year of the articles publication.
\item[volume] The volume the article appears in.
\item[issue] The issue the article appears in.
\item[articlenumber] The number of the article within the volume.
\item[submitted] The date the article was submitted to (and received by) the
publisher. Please use an \textsc{iso} date (\textsc{yyyy-mm-dd}).
\item[published] The date the article was published and made public by the
publisher. Please use an \textsc{iso} date (\textsc{yyyy-mm-dd}).
\end{description}
%
See the end of \autoref{lst:affiliation} for an example.
\subsection{Figures, Tables, Listings}
Sometimes it is necessary to pay special attention to the \emph{floating
elements} of your document, that is figures, tables, listings, and similar.
While it is tempting to force those elements to the specific position where
they are written down, this is not always the best choice, especially since it
can interrupt the reading flow. Therefore please refrain form using the
\lstinline|[h!]| and \lstinline|[H]| specifiers for such elements. If you
\emph{must} have the element at the current position, it maybe is not a
\emph{floating element}, in the first place. It is perfectly fine to use
graphics \emph{without} a \lstinline|\begin{figure}...\end{figure}| environment
or use a \lstinline|\begin{tabular}...\end{tabular}| \emph{without} an
enclosing \lstinline|\begin{table}...\end{table}|.
\begin{table}
\centering
\caption{Differences between things projected and things achieved}
\label{tbl:things}
\begin{threeparttable}
\footnotesize
\begin{tabular}{>{}p{.33\linewidth}@{}cSs}
\toprule
Part & done & {Value} & Unit \\
\midrule
Title & yes & 2.3456 & \dB \\
Abstract & yes & e3 & \kilo\hertz \\
\midrule
\multicolumn{4}{c}{Rest is not entirely true} \\
\midrule
Context & yes & 90.473 & \percent \\
Problem & no\tnote{a} & & \\
Solution & yes & 5642.5 & \mega\byte \\
Implementation & yes & 1.2e-3 & \metre\squared\per\second \\
Evaluation & no & & \\
Related Work & no & & \\
Conclusion & yes & 4955.3 & \per\kilogram \\
\bottomrule
\end{tabular}
\begin{tablenotes}
\item [a] Just a few things missing
\end{tablenotes}
\end{threeparttable}
\end{table}
\begin{figure}[b]
\centering
\setlength{\unitlength}{.01in}%{.025in}
\begin{picture}(200,75)
\put(0,25){\vector(1,0){200}}
\put(25,0){\vector(0,1){75}}
\put(75,22){\line(0,1){6}}
\put(125,22){\line(0,1){6}}
\put(22,50){\line(1,0){6}}
\thicklines
\put(25,25){\line(1,0){50}}
\put(75,50){\line(1,0){50}}
\put(125,25){\line(1,0){72}}
\put(17,50){\makebox(0,0){$1$}}
\put(75,13){\makebox(0,0)[b]{$\pi$}}
\put(125,13){\makebox(0,0)[b]{$2\pi$}}
\put(195,13){\makebox(0,0)[b]{$t$}}
\put(175,60){\makebox(0,0){$g(t)$}}
\end{picture}
\caption{A test figure}
\label{fig:test}
\end{figure}
The caption position of a floating element should match its content. For
tables, listings, algorithms, or similar list-like content, please use captions
\emph{above} its contents, as those elements are typically read from top to
bottom. Find examples in the listings already presented and
\autoref{tbl:things}. For figures, graphs, graphics, or similar, please us
captions \emph{below} the imagery, as in \autoref{fig:test}.
For tabular content, we suggest to avoid vertical lines altogether and keep
horizontal lines to a minimum. Refer to the \lstinline|booktabs| package
documentation for more information~\cite{booktabs}. Also, the
\lstinline|threeparttable| package is valuable if you need footnotes in your
table~\cite{threeparttable}.
\subsection{Bibliography}
As outlined, the \lstinline|programming| class supports both plain BibTeX as
well as the newer Biblatex bibliography package to present your references.
Please note that you may not change the bibliography style, it is pre-selected
by the class. It is a simple, numbered style with all references sorted
alphabetically. In text, it should look like
this:~\cite{DBLP:journals/cacm/Knuth74}. Note that the reference has the
\textsc{doi} included. We would like to encourage you to always provide the
\textsc{doi}s of the works you cite, if possible. However, please make sure in
your bibliography file, that the \lstinline|doi| entry is a plain entry without
a ``resolver'' (for example, \textsf{http://dx.doi.org/}) prepended. A typical
example for an entry format should look like in \autoref{lst:bib}. Please
shorten neither names nor journal articles, if possible.
The bibliography commands for your article should look like this (for Biblatex
and plain BibTeX, respectively):\\*
\begin{minipage}[t]{.45\linewidth}
\emph{Biblatex}
\begin{lstlisting}
\documentclass{programming}
\usepackage[backend=biber]{biblatex}
\addbibresource{example.bib}
\begin{document}
...
\printbibliography
\end{document}
\end{lstlisting}
\end{minipage}%
\hfill%
\begin{minipage}[t]{.45\linewidth}
\emph{Plain BibTeX}
\begin{lstlisting}[numbers= none]
\documentclass{programming}
\begin{document}
...
\bibliography{example}
\end{document}
\end{lstlisting}
\end{minipage}
\begin{lstlisting}[float,label=lst:bib,language=,caption={A typical BibTeX entry for \cite{DBLP:journals/cacm/Knuth74}}]
@article{DBLP:journals/cacm/Knuth74,
Author = {Donald E. Knuth},
Doi = {10.1145/361604.361612},
Journal = {Communications of the {ACM}},
Number = {12},
Pages = {667--673},
Title = {{Computer Programming as an Art}},
Volume = {17},
Year = {1974}}
\end{lstlisting}
\subsection{{LaTeX} Packages Considerations }
\label{sec:pack-cons}
The following packages are automatically loaded by the \lstinline|programming|
class and need not to be loaded manually.
\begin{multicols}{4}
{\color{DarkGreen}
\begin{itemize}
\item \path{accsupp}
\item \path{amsmath}
\item \path{amstext}
\item \path{array}
\item \path{atbegshi}
\item \path{babel}
\item \path{booktabs}
\item \path{calc}
\item \path{caption}
\item \path{colortbl}
\item \path{comment}
\item \path{csquotes}
\item \path{doclicense}
\item \path{expl3}
\item \path{FiraSans}
\item \path{fnpct}
\item \path{fontspec}
\item \path{fontenc}
\item \path{gettitlestring}
\item \path{graphics}
\item \path{graphicx}
\item \path{grfext}
\item \path{hypcap}
\item \path{hyperref}
\item \path{hyperxmp}
\item \path{listings}
\item \path{mathdesign}
\item \path{microtype}
\item \path{morewrites}
\item \path{multirow}
\item \path{pict2e}
\item \path{relsize}
\item \path{rotating}
\item \path{siunitx}
\item \path{subcaption}
\item \path{tabularx}
\item \path{textcase}
\item \path{textcomp}
\item \path{threeparttable}
\item \path{typearea}
\item \path{url}
\item \path{verbatim}
\item \path{xcolor}
\item \path{xparse}
\item \path{xspace}
\item \path{xunicode}
\end{itemize}}
\end{multicols}
\par\noindent The following packages \emph{must not} be loaded.
\begin{multicols}{4}
{\color{DarkRed}
\begin{itemize}
\item \path{SIstyle}
\item \path{SIunits}
\item \path{a4wide}
\item \path{a4}
\item \path{aecompl}
\item \path{ae}
\item \path{caption2}
\item \path{courier}
\item \path{doublespace}
\item \path{epsfig}
\item \path{epsf}
\item \path{euler}
\item \path{fancyhdr}
\item \path{fancyheadings}
\item \path{fourier}
\item \path{geometry}
\item \path{glossary}
\item \path{helvet}
\item \path{isolatin}
\item \path{mathpple}
\item \path{mathptmx}
\item \path{mathptm}
\item \path{newtxmath}
\item \path{newtxtext}
\item \path{palatino}
\item \path{psfig}
\item \path{pslatex}
\item \path{scrpage}
\item \path{subfigure}
\item \path{subfig}
\item \path{t1enc}
\item \path{times}
\item \path{umlaut}
\item \path{utopia}
\item \path{zefonts}
\end{itemize}}
\end{multicols}
%
\noindent
Additionally, any package that changes the font must not be loaded.
\acks
We want to thank you for using this class to prepare articles for The Art, Science, and Engineering of Programming.
\appendix
\section{A Famous Filler Text}
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu
fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in
culpa qui officia deserunt mollit anim id est laborum.
\section{Submission Checklist}
\begingroup
\smaller
\begin{itemize}
\renewcommand*\labelitemi{\ensuremath{\square}}
\item All authors are listed, with affiliation
\item The abstract is not longer than 500 words.
\item The abstract states, in this order, \emph{Context},
\emph{Inquiry}, \emph{Approach}, \emph{Knowledge}, \emph{Grounding}, and
\emph{Importance} of the submission.
\item The ACM CCS 2012 classification is included.
\item A list of relevant keywords is provided.
\item One \emph{perspective} has been chosen.
\item One or more \emph{area(s) of submission} have been chosen.
\item The license has been acknowledged or changed to fit.
\item The title page does not spill onto the second page.
\item The running title on even pages' heads is not wider than the text block.
\item The running list of author on odd pages' heads is not wider than the text
block.
\item The only text encoding used is \textsc{utf-8}.
\item The fonts, margins, and spacings are unchanged.
\item All \textsc{url}s are marked using the \lstinline|\url| command.
\item All units are separated from their values with a half space, consistently
(see ~\cite{siunitx}).
\item Bold font is not used (or only in exceptional circumstances).
\item Underlining is not used (no exceptions).
\item Bold or bright colors are only ever used sparingly.
\item The captions of (a) tables, (b) listings, and (c) algorithms are
\emph{above} the content, flush left.
\item The captions of (a) figures, (b) charts, (c) combined content, and
similar are \emph{below} the content, flush left.
\item %
\begin{minipage}[t]{.4\linewidth}
Tables adhere to best practice layout~\cite{booktabs}. They do not contain
vertical lines and only few horizontal lines.
\end{minipage}
{\renewcommand{\arraystretch}{.6}
\hspace{2em} \textcolor{DarkGreen}{Yes} \hspace{1em}
\begin{tabular}[t]{ll}\noalign{\vspace*{-2.2ex}}
\toprule
\emph{a} & \emph{b}\\
\midrule
x & abc \\
y & def \\
\bottomrule
\end{tabular}
\hspace{2em} \textcolor{DarkRed}{No} \hspace{1em}
\begin{tabular}[t]{|l|l|}\noalign{\vspace*{-1.6ex}}
\hline
\emph{a} & \emph{b}\\
\hline\hline
x & abc \\\hline
y & def \\\hline
\end{tabular}}
\item All fonts are embedded. This includes the fonts for any included
(\textsc{pdf}-)graphics.
\item All graphics are either vector graphics or have at least 300\,dpi.
\item Acknowledgements, including statement of funding bodies or projects, is
placed before the references, using the \lstinline|\acks| command.
\item Citations in the text are preceded by a non-breaking space.
(\(\rightarrow\) Citations do not appear at the beginning of a line)
\item The bibliography lists all cited works, all authors are given (no
\emph{et. al.}), the full names of the authors are used.
\item All bibliography entries have a \textsc{doi} (unless not applicable, such as for
slides or unpublished work).
\item All bibliography entries show an \textsc{isbn}, if they have one assigned.
\item All bibliography entries that represent web sites have a \textsc{url} and
an \emph{access date}.
\item No bibliography entries have duplicate information in \textsc{url} and
\textsc{doi}.
\end{itemize}
%
For the final phase (or camera-ready copy), additionally:
\begin{itemize}
\renewcommand*\labelitemi{\ensuremath{\square}}
\renewcommand*\labelitemii{\ensuremath{\square}}
\item The \lstinline|\paperdetails| are included as provided by the journal.
\item The \textsc{doi}, and submission and publication date appear on the title
page.
\item Neither the \emph{perspective} nor the \emph{area of submission} appear
on the title.
\end{itemize}
\endgroup
\printbibliography
\end{document}
% Local Variables:
% TeX-engine: luatex
% End: