Cleaning up the software folder.
[pingpong.git] / papers / SIGCOMM2018_IoT-SP / ACM-Reference-Format.bst
diff --git a/papers/SIGCOMM2018_IoT-SP/ACM-Reference-Format.bst b/papers/SIGCOMM2018_IoT-SP/ACM-Reference-Format.bst
deleted file mode 100755 (executable)
index f79017e..0000000
+++ /dev/null
@@ -1,2893 +0,0 @@
-%%% -*-BibTeX-*-
-%%% ====================================================================
-%%%  @BibTeX-style-file{
-%%%     author          = "Nelson H. F. Beebe, Boris Veytsman and Gerald Murray",
-%%%     version         = "2.1",
-%%%     date            = "14 June 2017",
-%%%     filename        = "ACM-Reference-Format.bst",
-%%%     email           = "borisv@lk.net, boris@varphi.com",
-%%%     codetable       = "ISO/ASCII",
-%%%     keywords        = "ACM Transactions bibliography style; BibTeX",
-%%%     license         = "public domain",
-%%%     supported       = "yes",
-%%%     abstract        = "",
-%%%  }
-%%% ====================================================================
-
-%%% Revision history:  see source in git
-
-ENTRY
-  { address
-    advisor
-    archiveprefix
-    author
-    booktitle
-    chapter
-    city
-    date
-    edition
-    editor
-    eprint
-    eprinttype
-    eprintclass
-    howpublished
-    institution
-    journal
-    key
-    month
-    note
-    number
-    organization
-    pages
-    primaryclass
-    publisher
-    school
-    series
-    title
-    type
-    volume
-    year
-        % New keys recognized
-        issue         % UTAH: used in, e.g., ACM SIGSAM Bulletin and ACM Communications in Computer Algebra
-        articleno
-        eid
-        day           % UTAH: needed for newspapers, weeklies, bi-weeklies
-        doi           % UTAH
-        url           % UTAH
-        bookpages     % UTAH
-        numpages
-        lastaccessed  % UTAH: used only for @Misc{...}
-        coden         % UTAH
-        isbn          % UTAH
-        isbn-13       % UTAH
-        issn          % UTAH
-        lccn          % UTAH
-  }
-  {}
-  { label.year extra.label sort.year sort.label basic.label.year}
-
-INTEGERS { output.state before.all mid.sentence after.sentence after.block }
-
-INTEGERS { show-isbn-10-and-13 }  % initialized below in begin.bib
-
-INTEGERS { nameptr namesleft numnames }
-
-INTEGERS { multiresult }
-
-INTEGERS { len }
-
-INTEGERS { last.extra.num }
-
-STRINGS { s t t.org u }
-
-STRINGS { last.label next.extra }
-
-STRINGS { p1 p2 p3 page.count }
-
-
-FUNCTION { not }
-{
-    { #0 }
-    { #1 }
-  if$
-}
-
-FUNCTION { and }
-{
-    'skip$
-    { pop$ #0 }
-  if$
-}
-
-FUNCTION { or }
-{
-   { pop$ #1 }
-    'skip$
-  if$
-}
-
-
-FUNCTION { dump.stack.1 }
-{
-    duplicate$ "STACK[top] = [" swap$ * "]" * warning$
-}
-
-FUNCTION { dump.stack.2 }
-{
-    duplicate$ "STACK[top  ] = [" swap$ * "]" * warning$
-    swap$
-    duplicate$ "STACK[top-1] = [" swap$ * "]" * warning$
-    swap$
-}
-
-FUNCTION { empty.or.unknown }
-{
-  %% Examine the top stack entry, and push 1 if it is empty, or
-  %% consists only of whitespace, or is a string beginning with two
-  %% queries (??), and otherwise, push 0.
-  %%
-  %% This function provides a replacement for empty$, with the
-  %% convenient feature that unknown values marked by two leading
-  %% queries are treated the same as missing values, and thus, do not
-  %% appear in the output .bbl file, and yet, their presence in .bib
-  %% file(s) serves to mark values which are temporarily missing, but
-  %% are expected to be filled in eventually once more data is
-  %% obtained.  The TeX User Group and BibNet bibliography archives
-  %% make extensive use of this practice.
-  %%
-  %% An empty string cannot serve the same purpose, because just as in
-  %% statistics data processing, an unknown value is not the same as an
-  %% empty value.
-  %%
-  %% At entry: stack = ... top:[string]
-  %% At exit:  stack = ... top:[0 or 1]
-
-  duplicate$ empty$
-    { pop$ #1 }
-    { #1 #2 substring$ "??" = }
-  if$
-}
-
-FUNCTION { writeln }
-{
-  %% In BibTeX style files, the sequences
-  %%
-  %%     ... "one" "two" output
-  %%     ... "one" "two" output.xxx
-  %%
-  %% ship "one" to the output file, possibly following by punctuation,
-  %% leaving the stack with
-  %%
-  %%     ... "two"
-  %%
-  %% There is thus a one-string lag in output processing that must be
-  %% carefully handled to avoid duplicating a string in the output
-  %% file.  Unless otherwise noted, all output.xxx functions leave
-  %% just one new string on the stack, and that model should be born
-  %% in mind when reading or writing function code.
-  %%
-  %% BibTeX's asynchronous buffering of output from strings from the
-  %% stack is confusing because newline$ bypasses the buffer.  It
-  %% would have been so much easier for newline to be a character
-  %% rather than a state of the output-in-progress.
-  %%
-  %% The documentation in btxhak.dvi is WRONG:  it says
-  %%
-  %%    newline$ Writes onto the bbl file what's accumulated in the
-  %%             output buffer. It writes a blank line if and only
-  %%             if the output buffer is empty. Since write$ does
-  %%             reasonable line breaking, you should use this
-  %%             function only when you want a blank line or an
-  %%             explicit line break.
-  %%
-  %%    write$   Pops the top (string) literal and writes it on the
-  %%             output buffer (which will result in stuff being
-  %%             written onto the bbl file when the buffer fills
-  %%             up).
-  %%
-  %% Examination of the BibTeX source code shows that write$ does
-  %% indeed behave as claimed, but newline$ sends a newline character
-  %% directly to the output file, leaving the stack unchanged.  The
-  %% first line "Writes onto ... buffer." is therefore wrong.
-  %%
-  %% The original BibTeX style files almost always use "write$ newline$"
-  %% in that order, so it makes sense to hide that pair in a private
-  %% function like this one, named after a statement in Pascal,
-  %% the programming language embedded in the BibTeX Web program.
-
-  write$                % output top-of-stack string
-  newline$              % immediate write of newline (not via stack)
-}
-
-FUNCTION { init.state.consts }
-{
-  #0 'before.all :=
-  #1 'mid.sentence :=
-  #2 'after.sentence :=
-  #3 'after.block :=
-}
-
-FUNCTION { output.nonnull }
-{ % Stack in: ... R S T  Stack out: ... R T   File out: S<comma><space>
-  's :=
-  output.state mid.sentence =
-    {
-      ", " * write$
-    }
-    {
-      output.state after.block =
-        {
-          add.period$ writeln
-          "\newblock " write$
-        }
-        {
-          output.state before.all =
-            {
-              write$
-            }
-            {
-              add.period$ " " * write$
-            }
-          if$
-        }
-      if$
-      mid.sentence 'output.state :=
-    }
-  if$
-  s
-}
-
-FUNCTION { output.nonnull.dot.space }
-{ % Stack in: ... R S T  Stack out: ... R T   File out: S<dot><space>
-  's :=
-  output.state mid.sentence =           % { "<DEBUG output.nonnull.dot.space>. " * write$ }
-    {
-      ". " * write$
-    }
-    {
-      output.state after.block =
-        {
-          add.period$ writeln "\newblock " write$
-        }
-        {
-          output.state before.all =
-            {
-              write$
-            }
-            {
-              add.period$ " " * write$
-            }
-          if$
-        }
-      if$
-      mid.sentence 'output.state :=
-    }
-  if$
-  s
-}
-
-FUNCTION { output.nonnull.remove }
-{ % Stack in: ... R S T  Stack out: ... R T   File out: S<space>
-  's :=
-  output.state mid.sentence =
-    {
-      " " * write$
-    }
-    {
-      output.state after.block =
-        {
-          add.period$ writeln "\newblock " write$
-        }
-        {
-          output.state before.all =
-            {
-              write$
-            }
-            {
-              add.period$ " " * write$
-            }
-          if$
-        }
-      if$
-      mid.sentence 'output.state :=
-    }
-  if$
-  s
-}
-
-FUNCTION { output.nonnull.removenospace }
-{ % Stack in: ... R S T  Stack out: ... R T   File out: S
-  's :=
-  output.state mid.sentence =
-    {
-      "" * write$
-    }
-    {
-      output.state after.block =
-        {
-          add.period$ writeln "\newblock " write$
-        }
-        {
-          output.state before.all =
-            {
-              write$
-            }
-            {
-              add.period$ " " * write$
-            }
-          if$
-        }
-      if$
-      mid.sentence 'output.state :=
-    }
-  if$
-  s
-}
-
-FUNCTION { output }
-{ % discard top token if empty, else like output.nonnull
-  duplicate$ empty.or.unknown
-    'pop$
-    'output.nonnull
-  if$
-}
-
-FUNCTION { output.dot.space }
-{ % discard top token if empty, else like output.nonnull.dot.space
-  duplicate$ empty.or.unknown
-    'pop$
-    'output.nonnull.dot.space
-  if$
-}
-
-FUNCTION { output.removenospace }
-{ % discard top token if empty, else like output.nonnull.removenospace
-  duplicate$ empty.or.unknown
-    'pop$
-    'output.nonnull.removenospace
-  if$
-}
-
-FUNCTION { output.check }
-{ % like output, but warn if key name on top-of-stack is not set
-  't :=
-  duplicate$ empty.or.unknown
-    { pop$ "empty " t * " in " * cite$ * warning$ }
-    'output.nonnull
-  if$
-}
-
-FUNCTION { bibinfo.output.check }
-{ % like output.check, adding bibinfo field
-  't :=
-  duplicate$ empty.or.unknown
-    { pop$ "empty " t * " in " * cite$ * warning$ }
-    { "\bibinfo{" t "}{" * * swap$ * "}" *
-      output.nonnull }
-  if$
-}
-
-FUNCTION { output.check.dot.space }
-{ % like output.dot.space, but warn if key name on top-of-stack is not set
-  't :=
-  duplicate$ empty.or.unknown
-    { pop$ "empty " t * " in " * cite$ * warning$ }
-    'output.nonnull.dot.space
-  if$
-}
-
-FUNCTION { fin.block }
-{ % functionally, but not logically, identical to fin.entry
-   add.period$
-   writeln
-}
-
-FUNCTION { fin.entry }
-{
-   add.period$
-   writeln
-}
-
-FUNCTION { new.sentence }
-{ % update sentence state, with neither output nor stack change
-  output.state after.block =
-    'skip$
-    {
-      output.state before.all =
-        'skip$
-        { after.sentence 'output.state := }
-      if$
-    }
-  if$
-}
-
-FUNCTION { fin.sentence }
-{
-   add.period$
-   write$
-   new.sentence
-   ""
-}
-
-FUNCTION { new.block }
-{
-  output.state before.all =
-    'skip$
-    { after.block 'output.state := }
-  if$
-}
-
-FUNCTION { output.coden }       % UTAH
-{ % output non-empty CODEN as one-line sentence (stack untouched)
-  coden empty.or.unknown
-    { }
-    { "\showCODEN{" coden * "}" * writeln }
-  if$
-}
-
-FUNCTION { format.articleno }
-{
-  articleno empty.or.unknown not eid empty.or.unknown not and
-     { "Both articleno and eid are defined for " cite$ * warning$ }
-     'skip$
-  if$
-  articleno empty.or.unknown eid empty.or.unknown and
-     { "" }
-     {
-        numpages empty.or.unknown
-          { "articleno or eid field, but no numpages field, in "
-            cite$ * warning$ }
-          { }
-        if$
-        eid empty.or.unknown
-          { "Article \bibinfo{articleno}{" articleno * "}" * }
-          { "Article \bibinfo{articleno}{" eid * "}" * }
-        if$
-     }
-  if$
-}
-
-FUNCTION { format.year }
-{ % push year string or "[n. d.]" onto output stack
-  %% Because year is a mandatory field, we always force SOMETHING
-  %% to be output
-  "\bibinfo{year}{"
-  year empty.or.unknown
-    { "[n. d.]" }
-    { year }
-  if$
-  *  "}" *
-}
-
-FUNCTION { format.day.month }
-{ % push "day month " or "month " or "" onto output stack
-  day empty.or.unknown
-    {
-      month empty.or.unknown
-        { "" }
-        { "\bibinfo{date}{" month * "} " *}
-      if$
-    }
-    {
-      month empty.or.unknown
-        { "" }
-        { "\bibinfo{date}{" day * " " * month * "} " *}
-      if$
-    }
-  if$
-}
-
-FUNCTION { format.day.month.year }     % UTAH
-{ % if month is empty, push "" else push "(MON.)" or "(DD MON.)"
-  % Needed for frequent periodicals: 2008. ... New York Times C-1, C-2, C-17 (23 Oct.)
-  % acm-*.bst addition: prefix parenthesized date string with
-  % ", Article nnn "
-  articleno empty.or.unknown eid empty.or.unknown and
-    { "" }
-    { output.state after.block =
-       {", " format.articleno * }
-       { format.articleno  }
-      if$
-    }
-  if$
-  " (" * format.day.month * format.year * ")" *
-}
-
-FUNCTION { output.day.month.year }     % UTAH
-{ % if month is empty value, do nothing; else output stack top and
-  % leave with new top string "(MON.)" or "(DD MON.)"
-  % Needed for frequent periodicals: 2008. ... New York Times C-1, C-2, C-17 (23 Oct.)
-  format.day.month.year
-  output.nonnull.remove
-}
-
-FUNCTION { strip.doi } % UTAH
-{ % Strip any Web address prefix to recover the bare DOI, leaving the
-  % result on the output stack, as recommended by CrossRef DOI
-  % documentation.
-  % For example, reduce "http://doi.acm.org/10.1145/1534530.1534545" to
-  % "10.1145/1534530.1534545".  That is later typeset and displayed as
-  % doi:10.1145/1534530.1534545 as the LAST item in the reference list
-  % entry.  Publisher Web sites wrap this with a suitable link to a real
-  % URL to resolve the DOI, and the master https://doi.org/ address is
-  % preferred, since publisher-specific URLs can disappear in response
-  % to economic events.  All journals are encouraged by the DOI
-  % authorities to use that typeset format and link procedures for
-  % uniformity across all publications that include DOIs in reference
-  % lists.
-  % The numeric prefix is guaranteed to start with "10.", so we use
-  % that as a test.
-  % 2017-02-04 Added stripping of https:// (Boris)
-  doi #1 #3 substring$ "10." =
-    { doi }
-    {
-      doi 't :=  % get modifiable copy of DOI
-
-      % Change https:// to http:// to strip both prefixes (BV)
-
-      t #1 #8 substring$ "https://" =
-        { "http://"  t #9 t text.length$ #8 - substring$ * 't := }
-        { }
-      if$
-
-      t #1 #7 substring$ "http://" =
-        {
-            t #8 t text.length$ #7 - substring$ 't :=
-
-            "INTERNAL STYLE-FILE ERROR" 's :=
-
-            % search for next "/" and assign its suffix to s
-
-            { t text.length$ }
-            {
-              t #1 #1 substring$ "/" =
-                {
-                  % save rest of string as true DOI (should be 10.xxxx/yyyy)
-                  t #2 t text.length$ #1 - substring$ 's :=
-                  "" 't :=    % empty string t terminates the loop
-                }
-                {
-                  % discard first character and continue loop: t <= substring(t,2,last)
-                  t #2 t text.length$ #1 - substring$ 't :=
-                }
-              if$
-            }
-            while$
-
-            % check for valid DOI (should be 10.xxxx/yyyy)
-            s #1 #3 substring$ "10." =
-              { }
-              { "unrecognized DOI substring " s * " in DOI value [" * doi * "]" * warning$ }
-            if$
-
-            s   % push the stripped DOI on the output stack
-
-        }
-        {
-          "unrecognized DOI value [" doi * "]" * warning$
-          doi   % push the unrecognized original DOI on the output stack
-        }
-      if$
-    }
-  if$
-}
-
-%
-% Change by BV: added standard prefix to URL
-%
-FUNCTION { output.doi } % UTAH
-{ % output non-empty DOI as one-line sentence (stack untouched)
-  doi empty.or.unknown
-    { }
-    {
-      %% Use \urldef here for the same reason it is used in output.url,
-      %% see output.url for further discussion.
-      "\urldef\tempurl%" writeln
-      "\url{https://doi.org/" strip.doi * "}" * writeln
-      "\showDOI{\tempurl}" writeln
-    }
-  if$
-}
-
-FUNCTION { output.isbn }                % UTAH
-{ % output non-empty ISBN-10 and/or ISBN-13 as one-line sentences (stack untouched)
-  show-isbn-10-and-13
-    {
-      %% show both 10- and 13-digit ISBNs
-      isbn empty.or.unknown
-        { }
-        {
-          "\showISBNx{" isbn * "}" * writeln
-        }
-      if$
-      isbn-13 empty.or.unknown
-        { }
-        {
-          "\showISBNxiii{" isbn-13 * "}" * writeln
-        }
-      if$
-    }
-    {
-      %% show 10-digit ISBNs only if 13-digit ISBNs not available
-      isbn-13 empty.or.unknown
-        {
-          isbn empty.or.unknown
-            { }
-            {
-              "\showISBNx{" isbn * "}" * writeln
-            }
-          if$
-        }
-        {
-          "\showISBNxiii{" isbn-13 * "}" * writeln
-        }
-      if$
-    }
-  if$
-}
-
-FUNCTION { output.issn } % UTAH
-{ % output non-empty ISSN as one-line sentence (stack untouched)
-  issn empty.or.unknown
-    { }
-    { "\showISSN{" issn * "}" * writeln }
-  if$
-}
-
-FUNCTION { output.issue }
-{ % output non-empty issue number as a one-line sentence (stack untouched)
-  issue empty.or.unknown
-    { }
-    { "Issue " issue * "." * writeln }
-  if$
-}
-
-FUNCTION { output.lccn } % UTAH
-{ % return with stack untouched
-  lccn empty.or.unknown
-    { }
-    { "\showLCCN{" lccn * "}" * writeln }
-  if$
-}
-
-FUNCTION { output.note } % UTAH
-{ % return with stack empty
-  note empty.or.unknown
-    { }
-    { "\shownote{" note add.period$ * "}" * writeln }
-  if$
-}
-
-FUNCTION { output.note.check } % UTAH
-{ % return with stack empty
-  note empty.or.unknown
-    { "empty note in " cite$ * warning$ }
-    { "\shownote{" note add.period$ * "}" * writeln }
-  if$
-}
-
-FUNCTION { output.eprint } %
-{ % return with stack empty
-  eprint empty.or.unknown
-    { }
-    { "\showeprint"
-         archiveprefix empty.or.unknown
-           { eprinttype empty.or.unknown
-               { }
-               { "[" eprinttype "]" * * * }
-             if$
-           }
-           { "[" archiveprefix "l" change.case$ "]" * * * }
-         if$
-         "{" *
-         primaryclass empty.or.unknown
-           { eprintclass empty.or.unknown
-             { }
-             { eprintclass "/" * * }
-             if$
-           }
-           { primaryclass "/" * * }
-         if$
-         eprint "}" * *
-         writeln
-    }
-  if$
-}
-
-
-%
-% Changes by BV 2011/04/15.  Do not output
-% url if doi is defined
-%
-FUNCTION { output.url } % UTAH
-{ % return with stack untouched
-  % output URL and associated lastaccessed fields
-  doi empty.or.unknown
-  {
-    url empty.or.unknown
-      { }
-      {
-          %% Use \urldef, outside \showURL, so that %nn, #, etc in URLs work
-          %% correctly.  Put the actual URL on its own line to reduce the
-          %% likelihood of BibTeX's nasty line wrapping after column 79.
-          %% \url{} can undo this, but if that doesn't work for some reason
-          %% the .bbl file would have to be repaired manually.
-          "\urldef\tempurl%" writeln
-          "\url{" url * "}" * writeln
-
-          "\showURL{%" writeln
-          lastaccessed empty.or.unknown
-            { "" }
-            { "Retrieved " lastaccessed * " from " * }
-          if$
-          "\tempurl}" * writeln
-      }
-      if$
-  }
-  { }
-  if$
-}
-
-FUNCTION { output.year.check }
-{ % warn if year empty, output top string and leave " YEAR<label>" on stack in mid-sentence
-  year empty.or.unknown
-     { "empty year in " cite$ * warning$
-       write$
-       " \bibinfo{year}{[n. d.]}"
-       "\natexlab{" extra.label * "}" * *
-       mid.sentence 'output.state :=
-     }
-     { write$
-       " \bibinfo{year}{" year * "}"  *
-       "\natexlab{" extra.label * "}" * *
-       mid.sentence 'output.state :=
-     }
-  if$
-}
-
-
-FUNCTION { le }
-{
-  %% test whether first number is less than or equal to second number
-  %% stack in:  n1 n2
-  %% stack out: if n1 <= n2 then 1 else 0
-
-  %% "DEBUG: le " cite$ * warning$
-  > { #0 } { #1 } if$
-}
-
-FUNCTION { ge }
-{
-  %% test whether first number is greater than or equal to second number
-  %% stack in:  n1 n2
-  %% stack out: if n1 >= n2 then 1 else 0
-
-  %% "DEBUG: ge " cite$ * warning$
-  < { #0 } { #1 } if$
-}
-
-FUNCTION { is.leading.digit }
-{
-  %% test whether first character of string is a digit
-  %% stack in:  string
-  %% stack out: if first-char-is-digit then 1 else 0
-
-  #1 #1 substring$                      % replace string by string[1:1]
-  duplicate$                            % string[1:1] string[1:1]
-  chr.to.int$
-  "0" chr.to.int$ swap$ le              % "0" <= string[1:1] --> 0-or-1
-  swap$                                 % 0-or-1 string[1:1]
-  chr.to.int$
-  "9" chr.to.int$ le                    % string[1:1} <= "9" --> 0-or-1
-  and
-}
-
-FUNCTION { skip.digits }
-{
-  %% skip over leading digits in string
-  %% stack in:  string
-  %% stack out: rest-of-string leading-digits
-
-  %% "DEBUG: enter skip.digits " cite$ * warning$
-
-  %% dump.stack.1
-
-  duplicate$
-  't :=
-  't.org :=
-  "" 'u :=
-
-  { t text.length$ }
-  {
-    %% "=================DEBUG: skip.digits   t = [" t * "]" * warning$
-    t is.leading.digit
-      { t #2 t text.length$ #1 - substring$ }
-      {
-        t 'u :=
-        ""
-      }
-    if$
-    't :=
-  }
-  while$
-
-  u                                                             % rest of string
-  t.org #1 t.org text.length$ u text.length$ - substring$       % leading digits
-
-  %% "DEBUG: t.org = [" t.org * "]" * warning$
-  %% "DEBUG: u     = [" u * "]" * warning$
-
-  %% dump.stack.2
-
-  %% "DEBUG: leave skip.digits " cite$ * warning$
-}
-
-FUNCTION { skip.nondigits }
-{
-  %% skip over leading nondigits in string
-  %% stack in:  string
-  %% stack out: rest-of-string
-
-  %% "DEBUG: enter skip.nondigits " cite$ * warning$
-
-  't :=
-  "" 'u :=
-
-  { t text.length$ }
-  {
-    %% "=================DEBUG: skip.nondigits   t = [" t * "]" * warning$
-    t is.leading.digit
-      {
-        t 'u :=
-        ""
-      }
-      { t #2 t text.length$ #1 - substring$ }
-    if$
-    't :=
-  }
-  while$
-
-  u                     % rest of string
-
-  %% dump.stack.1
-  %% "DEBUG: leave skip.nondigits " cite$ * warning$
-}
-
-FUNCTION { parse.next.number }
-{
-  %% stack in:  string
-  %% stack out: rest-of-string next-numeric-part-of-string
-  %% Example:
-  %% stack in:  "123:1--123:59"
-  %% stack out: ":1--123:59" "123"
-
-  's :=
-  s skip.nondigits 's :=
-  s skip.digits
-}
-
-FUNCTION { reduce.pages.to.page.count }
-{
-  %% Stack in:  arbitrary-and-unused
-  %% Stack out: unchanged
-  %%
-  %% For the new-style pagination with article number and numpages or
-  %% pages, we expect to have BibTeX entries containing something like
-  %%     articleno = "17",
-  %%     pages     = "1--23",
-  %% with output "Article 17, 23 pages",
-  %% or
-  %%     articleno = "17",
-  %%     numpages  = "23",
-  %% with output "Article 17, 23 pages",
-  %% or
-  %%     articleno = "17",
-  %%     pages     = "17:1--17:23",
-  %% with output "Article 17, 23 pages",
-  %%
-  %% If articleno is missing or empty, then we should output "1--23",
-  %% "23" (with a warning of a missing articleno), or "17:1--17:23",
-  %% respectively.
-
-  %% "DEBUG: enter reduce.pages.to.page.count " cite$ * warning$
-
-  %% "DEBUG: pages = [" pages * "]" * warning$
-
-  pages
-  parse.next.number 'p1 :=
-  parse.next.number 'p2 :=
-  parse.next.number 'p3 :=
-  parse.next.number 'page.count :=
-
-  duplicate$
-  empty.or.unknown
-    {  }
-    {
-      duplicate$ "unexpected trailing garbage [" swap$ *
-      "] after n:p1--n:p2 in pages = [" *
-      pages *
-      "] in " *
-      cite$ *
-      warning$
-    }
-  if$
-
-  pop$
-
-  %% "DEBUG: reduce.pages.to.page.count: "
-  %% " p1 = " p1 * *
-  %% " p2 = " p2 * *
-  %% " p3 = " p3 * *
-  %% " p4 = " page.count * *
-  %% " in " cite$ * * warning$
-
-  p1 p3 =   p2 "1" =   and   numpages empty.or.unknown   and
-    { "INFO: reduced pages = [" pages * "] to numpages = [" * page.count * "]" * warning$ }
-    {
-      numpages empty.or.unknown
-        { pages }
-        { numpages }
-      if$
-      'page.count :=
-    }
-  if$
-
-  p1 "1" =   p3 empty.or.unknown   and   numpages empty.or.unknown   and
-    {
-      p2 'page.count :=
-      "INFO: reduced pages = [" pages * "] to numpages = [" * page.count * "]" * warning$
-    }
-    {
-      numpages empty.or.unknown
-        { pages }
-        { numpages }
-      if$
-      'page.count :=
-    }
-  if$
-
-  %% "DEBUG: leave reduce.pages.to.page.count " cite$ * warning$
-}
-
-FUNCTION { new.block.checkb }
-{ % issue a new.block only if at least one of top two stack strings is not empty
-  empty.or.unknown
-  swap$ empty.or.unknown
-  and
-    'skip$
-    'new.block
-  if$
-}
-
-FUNCTION { field.or.null }
-{ % convert empty value to null string, else return value
-  duplicate$ empty.or.unknown
-    { pop$ "" }
-    'skip$
-  if$
-}
-
-
-
-FUNCTION { emphasize }
-{ % emphasize a non-empty top string on the stack
-  duplicate$ empty.or.unknown
-    { pop$ "" }
-    { "\emph{" swap$ * "}" * }
-  if$
-}
-
-FUNCTION { comma }
-{ % convert empty string to null string, or brace string and add trailing comma
-  duplicate$ empty.or.unknown
-    { pop$ "" }
-    { "{" swap$ * "}," * }
-  if$
-}
-
-FUNCTION { format.names }
-{
-  % Format bibliographical entries with the first author last name first,
-  % and subsequent authors with initials followed by last name.
-  % All names are formatted in this routine.
-
-  's :=
-  #1 'nameptr :=               % nameptr = 1;
-  s num.names$ 'numnames :=    % numnames = num.name$(s);
-  numnames 'namesleft :=
-    { namesleft #0 > }
-    { nameptr #1 =
-        %NO: BAD ORDER: {"{" s nameptr "{ff~}{ll}{, jj}{, vv}" format.name$ * "}" * 't := }
-        %NO: BAD ORDER: {"{" s nameptr "{ff~}{ll}{, jj}{, vv}" format.name$ * "}" * 't := }
-        {"\bibinfo{person}{" s nameptr "{ff }{vv }{ll}{, jj}" format.name$ * "}" * 't := }
-        {"\bibinfo{person}{" s nameptr "{ff }{vv }{ll}{, jj}" format.name$ * "}" * 't := }
-      if$
-      nameptr #1 >
-        {
-          namesleft #1 >
-            { ", " * t * }
-            {
-              numnames #2 >
-                { "," * }
-                'skip$
-              if$
-              t "\bibinfo{person}{others}" =
-                { " {et~al\mbox{.}}" * } % jrh: avoid spacing problems
-                { " {and} " * t * } % from Chicago Manual of Style
-              if$
-            }
-          if$
-        }
-        't
-      if$
-      nameptr #1 + 'nameptr :=          % nameptr += 1;
-      namesleft #1 - 'namesleft :=      % namesleft =- 1;
-    }
-  while$
-}
-
-FUNCTION { my.full.label }
-{
-  's :=
-  #1 'nameptr :=               % nameptr = 1;
-  s num.names$ 'numnames :=    % numnames = num.name$(s);
-  numnames 'namesleft :=
-    { namesleft #0 > }
-
-    { s nameptr "{vv~}{ll}" format.name$ 't :=  % get the next name
-      nameptr #1 >
-        {
-          namesleft #1 >
-            { ", " * t * }
-            {
-              numnames #2 >
-                { "," * }
-                'skip$
-              if$
-              t "others" =
-                { " et~al\mbox{.}" * } % jrh: avoid spacing problems
-                { " and " * t * } % from Chicago Manual of Style
-              if$
-            }
-          if$
-        }
-        't
-      if$
-      nameptr #1 + 'nameptr :=          % nameptr += 1;
-      namesleft #1 - 'namesleft :=      % namesleft =- 1;
-    }
-  while$
-
-}
-
-FUNCTION { format.names.fml }
-{
-  % Format names in "familiar" format, with first initial followed by
-  % last name. Like format.names, ALL names are formatted.
-  % jtb: The names are NOT put in small caps
-
-  's :=
-  #1 'nameptr :=               % nameptr = 1;
-  s num.names$ 'numnames :=    % numnames = num.name$(s);
-  numnames 'namesleft :=
-    { namesleft #0 > }
-
-    {
-      "\bibinfo{person}{" s nameptr "{ff~}{vv~}{ll}{, jj}" format.name$ * "}" * 't :=
-
-      nameptr #1 >
-        {
-          namesleft #1 >
-            { ", " * t * }
-            {
-              numnames #2 >
-                { "," * }
-                'skip$
-              if$
-              t "\bibinfo{person}{others}" =
-                { " {et~al\mbox{.}}" * }
-                { " {and} " * t * }
-              if$
-            }
-          if$
-        }
-        't
-      if$
-      nameptr #1 + 'nameptr :=          % nameptr += 1;
-      namesleft #1 - 'namesleft :=      % namesleft =- 1;
-    }
-  while$
-}
-
-FUNCTION { format.authors }
-{
-  author empty.or.unknown
-    { "" }
-    {
-      "\bibfield{author}{"
-      author format.names add.period$ * "}" *} % jtb: add period if none before
-  if$
-}
-
-FUNCTION { format.key }
-{
-  empty.or.unknown
-    { key field.or.null }
-    { "" }
-  if$
-}
-
-FUNCTION { format.no.key }
-{
-  empty.or.unknown
-    { "" }
-    { "" }
-  if$
-}
-
-FUNCTION { format.editors.fml }
-{
-  % Format editor names for use in the "in" types: inbook, incollection,
-  % inproceedings: first initial, then last names. When editors are the
-  % LABEL for an entry, then format.editor is used which lists editors
-  % by last name first.
-
-  editor empty.or.unknown
-    { "" }
-    {
-      "\bibfield{editor}{"
-      editor format.names.fml
-      *  "}" *
-      editor num.names$ #1 >
-        { " (Eds.)" * }
-        { " (Ed.)" * }
-      if$
-    }
-  if$
-}
-
-FUNCTION { format.editors }
-{ % format editor names for use in labels, last names first.
-  editor empty.or.unknown
-    { "" }
-    {
-      "\bibfield{editor}{"
-      editor format.names
-      *  "}" *
-      editor num.names$ #1 >
-        { " (Eds.)." * }
-        { " (Ed.)." * }
-      if$
-    }
-  if$
-}
-
-FUNCTION { format.articletitle }
-{
-  title empty.or.unknown
-    { "" }
-    % Use this to preserve lettercase in titles:
-    { "\showarticletitle{" title * "}" * }
-    % Use this for downcase title style:
-    % { \showarticletitle{" title "t" change.case$ * "}" * }
-  if$
-}
-
-FUNCTION { format.title }
-{
-  title empty.or.unknown
-    { "" }
-    % Use this to preserve lettercase in titles:
-    { "\bibinfo{title}{" title * "}" * }
-    % Use this for downcase title style:
-    % { title "t" change.case$ }
-  if$
-}
-
-FUNCTION { n.dashify }
-{
-  't :=
-  ""
-    { t empty.or.unknown not }
-    {
-      t #1 #1 substring$ "-" =
-        {
-          t #1 #2 substring$ "--" = not
-            { "--" *
-              t #2 global.max$ substring$ 't :=
-            }
-            {
-              { t #1 #1 substring$ "-" = }
-              {
-                "-" *
-                t #2 global.max$ substring$ 't :=
-              }
-              while$
-            }
-          if$
-        }
-        {
-          t #1 #1 substring$ *
-          t #2 global.max$ substring$ 't :=
-        }
-      if$
-    }
-  while$
-}
-
-FUNCTION { format.a.title.with.edition }
-{
-  "\bibinfo{booktitle}{"
-  swap$ emphasize *
-  edition empty.or.unknown
-    'skip$
-    { " (\bibinfo{edition}{" * edition "l" change.case$ *
-      "} ed.)" * } % jtb: no parens for ed.
-  if$
-  "}" *
-}
-
-FUNCTION { format.btitle }
-{ title format.a.title.with.edition }
-
-FUNCTION { format.emphasize.booktitle }
-{ booktitle format.a.title.with.edition }
-
-FUNCTION { format.city }
-{
-  % jtb: if the preceding string (the title of the conference) is non-empty,
-  % jtb: append the location, otherwise leave empty (so as to trigger the
-  % jtb: error message in output.check
-
-  duplicate$ empty.or.unknown
-    { }
-    {
-      city empty.or.unknown
-        {
-          date empty.or.unknown
-            { }
-            { " (" * date * ")" * }
-          if$
-        }
-        {
-          date empty.or.unknown
-            { " (" * city * ")" * }
-            { " (" * city * ", " * date * ")" * }
-          if$
-        }
-      if$
-    }
-  if$
-}
-
-FUNCTION { tie.or.space.connect }
-{
-  duplicate$ text.length$ #3 <
-    { "~" }
-    { " " }
-  if$
-  swap$ * *
-}
-
-FUNCTION { either.or.check }
-{
-  empty.or.unknown
-    'pop$
-    { "can't use both " swap$ * " fields in " * cite$ * warning$ }
-  if$
-}
-
-FUNCTION { format.bvolume }
-{
-  % jtb: If there is a series, this is added and the volume trails after it.
-  % jtb: Otherwise, "Vol" is Capitalized.
-
-  volume empty.or.unknown
-    { "" }
-    {
-      series empty.or.unknown
-        { "Vol.~\bibinfo{volume}{" volume "}" * *}
-        { "\bibinfo{series}{" series "}, " * *
-          "Vol.~\bibinfo{volume}{" volume "}" * * *}
-      if$
-      "volume and number" number either.or.check
-    }
-  if$
-}
-
-FUNCTION { format.bvolume.noseries }
-{
-  volume empty.or.unknown
-    { "" }
-    { "Vol.~\bibinfo{volume}{" volume "}" * *
-      "volume and number" number either.or.check
-    }
-  if$
-}
-
-FUNCTION { format.series }
-{
-  series empty.or.unknown
-    {""}
-    {" \emph{(\bibinfo{series}{" * series "})}" *}
-  if$
-}
-
-FUNCTION { format.number.series }
-{
-  volume empty.or.unknown
-    {
-      number empty.or.unknown
-        {
-          volume empty.or.unknown
-          { "" }
-          {
-            series empty.or.unknown
-              { "" }
-              { " (\bibinfo{series}{" series * "})" * }
-            if$
-          }
-          if$
-        }                                       %    { series field.or.null }
-        {
-          output.state mid.sentence =
-            { "Number" }                        % gnp - changed to mixed case always
-            { "Number" }
-          if$
-          number tie.or.space.connect series empty.or.unknown
-            { "there's a number but no series in " cite$ * warning$ }
-            { " in \bibinfo{series}{" * series * "}" * }
-          if$
-        }
-      if$
-    }
-    {
-      ""
-    }
-  if$
-}
-
-FUNCTION { multi.page.check }
-{
-  't :=
-  #0 'multiresult :=
-    { multiresult not
-      t empty.or.unknown not
-      and
-    }
-    { t #1 #1 substring$
-      duplicate$ "-" =
-      swap$ duplicate$ "," =
-      swap$ "+" =
-      or or
-    { #1 'multiresult := }
-    { t #2 global.max$ substring$ 't := }
-      if$
-    }
-  while$
-  multiresult
-}
-
-FUNCTION { format.pages }
-{
-  pages empty.or.unknown
-    { "" }
-    { "\bibinfo{pages}{"
-      pages multi.page.check
-        { pages n.dashify } % gnp - removed () % jtb: removed pp.
-        { pages }
-      if$
-      * "}" *
-    }
-  if$
-}
-
-FUNCTION { format.pages.check.without.articleno }
-{ %% format pages field only if articleno is absent
-  %% Stack out: pages-specification
-  numpages missing$ pages missing$ and
-    { "page numbers missing in both pages and numpages fields in " cite$ * warning$ }
-    { }
-  if$
-
-  articleno empty.or.unknown eid empty.or.unknown and
-    {
-      pages missing$
-        { numpages }
-        { format.pages }
-      if$
-    }
-    { "" }
-  if$
-}
-
-FUNCTION { format.pages.check }
-{
-  pages empty.or.unknown
-    { "page numbers missing in " cite$ * warning$ "" }
-    { pages n.dashify }
-  if$
-}
-
-FUNCTION { format.bookpages }
-{
-  bookpages empty.or.unknown
-    { "" }
-    { bookpages "book pages" tie.or.space.connect }
-  if$
-}
-
-FUNCTION { format.named.pages }
-{
-  pages empty.or.unknown
-    { "" }
-    { format.pages "pages" tie.or.space.connect }
-  if$
-}
-
-%
-% Changed by Boris Veytsman, 2011-03-13
-% Now the word "pages" is printed even if
-% there field pages is not empty.
-%
-
-FUNCTION { format.page.count }
-{
-  page.count empty.or.unknown
-    { "" }
-    { "\bibinfo{numpages}{" page.count * "}~pages" * }
-  if$
-}
-
-FUNCTION { format.articleno.numpages }
-{
-  %% There are seven possible outputs, depending on which fields are set.
-  %%
-  %% These four are handled here:
-  %%
-  %%     articleno, numpages, pages     -> "Article articleno-value, numpages-value pages"
-  %%     articleno, numpages            -> "Article articleno-value, numpages-value pages"
-  %%     articleno, pages               -> "Article articleno-value, reduced-pages-value pages"
-  %%     articleno                      -> "Article articleno-value" and warn about missing numpages
-  %%
-  %% The remaining three have already been handled by
-  %% format.pages.check.without.articleno:
-  %%
-  %%     numpages, pages                -> "pages-value"
-  %%     numpages                       -> "numpages-value"
-  %%     pages                          -> "pages-value"
-
-  articleno empty.or.unknown eid empty.or.unknown and
-    {
-      numpages empty.or.unknown
-        { }
-        { "numpages field, but no articleno or eid field, in "
-          cite$ * warning$ }
-      if$
-      ""
-    }
-    {
-      numpages empty.or.unknown
-        {
-          pages empty.or.unknown
-            {
-              "articleno or eid, but no pages or numpages field in "
-                 cite$ * warning$
-              "" 'page.count :=
-            }
-            { reduce.pages.to.page.count }
-          if$
-        }
-        { numpages 'page.count := }
-      if$
-
-      %% The Article number is now handled in format.day.month.year because
-      %% ACM prefers the style "Digital Libraries 12, 3, Article 5 (July 2008)"
-      %% over "Digital Libraries 12, 3 (July 2008), Article 5"
-      %% format.articleno output
-      format.page.count
-    }
-  if$
-}
-
-FUNCTION {calc.format.page.count}
-{
-  numpages empty.or.unknown
-   {
-     pages empty.or.unknown
-        {
-        "" 'page.count :=
-        }
-        { reduce.pages.to.page.count }
-     if$
-   }
-   { numpages 'page.count := }
-  if$
-  format.page.count
-}
-
-
-FUNCTION { journal.canon.abbrev }
-{
-  % Returns a canonical abbreviation for 'journal', or else 'journal'
-  % unchanged.
-  journal "ACM Computing Surveys"                                                                       = { "Comput. Surveys"                                 } {
-  journal "{ACM} Computing Surveys"                                                                     = { "Comput. Surveys"                                 } {
-  journal "ACM Transactions on Mathematical Software"                                                   = { "ACM Trans. Math. Software"                       } {
-  journal "{ACM} Transactions on Mathematical Software"                                                 = { "ACM Trans. Math. Software"                       } {
-  journal "ACM SIGNUM Newsletter"                                                                       = { "ACM SIGNUM Newslett."                            } {
-  journal "ACM {SIGNUM} Newsletter"                                                                     = { "ACM SIGNUM Newslett."                            } {
-  journal "{ACM} SIGNUM Newsletter"                                                                     = { "ACM SIGNUM Newslett."                            } {
-  journal "{ACM} {SIGNUM} Newsletter"                                                                   = { "ACM SIGNUM Newslett."                            } {
-  journal "American Journal of Sociology"                                                               = { "Amer. J. Sociology"                              } {
-  journal "American Mathematical Monthly"                                                               = { "Amer. Math. Monthly"                             } {
-  journal "American Mathematical Society Translations"                                                  = { "Amer. Math. Soc. Transl."                        } {
-  journal "Applied Mathematics and Computation"                                                         = { "Appl. Math. Comput."                             } {
-  journal "British Journal of Mathematical and Statistical Psychology"                                  = { "Brit. J. Math. Statist. Psych."                  } {
-  journal "Bulletin of the American Mathematical Society"                                               = { "Bull. Amer. Math. Soc."                          } {
-  journal "Canadian Mathematical Bulletin"                                                              = { "Canad. Math. Bull."                              } {
-  journal "Communications of the ACM"                                                                   = { "Commun. ACM"                                     } {
-  journal "Communications of the {ACM}"                                                                 = { "Commun. ACM"                                     } {
-  journal "Computers and Structures"                                                                    = { "Comput. \& Structures"                           } {
-  journal "Contemporary Mathematics"                                                                    = { "Contemp. Math."                                  } {
-  journal "Crelle's Journal"                                                                            = { "Crelle's J."                                     } {
-  journal "Giornale di Mathematiche"                                                                    = { "Giorn. Mat."                                     } {
-  journal "IEEE Transactions on Aerospace and Electronic Systems"                                       = { "IEEE Trans. Aerospace Electron. Systems"         } {
-  journal "{IEEE} Transactions on Aerospace and Electronic Systems"                                     = { "IEEE Trans. Aerospace Electron. Systems"         } {
-  journal "IEEE Transactions on Automatic Control"                                                      = { "IEEE Trans. Automat. Control"                    } {
-  journal "{IEEE} Transactions on Automatic Control"                                                    = { "IEEE Trans. Automat. Control"                    } {
-  journal "IEEE Transactions on Computers"                                                              = { "IEEE Trans. Comput."                             } {
-  journal "{IEEE} Transactions on Computers"                                                            = { "IEEE Trans. Comput."                             } {
-  journal "IMA Journal of Numerical Analysis"                                                           = { "IMA J. Numer. Anal."                             } {
-  journal "{IMA} Journal of Numerical Analysis"                                                         = { "IMA J. Numer. Anal."                             } {
-  journal "Information Processing Letters"                                                              = { "Inform. Process. Lett."                          } {
-  journal "International Journal for Numerical Methods in Engineering"                                  = { "Internat. J. Numer. Methods Engrg."              } {
-  journal "International Journal of Control"                                                            = { "Internat. J. Control"                            } {
-  journal "International Journal of Supercomputing Applications"                                        = { "Internat. J. Supercomputing Applic."             } {
-  journal "Journal of Computational Physics"                                                            = { "J. Comput. Phys."                                } {
-  journal "Journal of Computational and Applied Mathematics"                                            = { "J. Comput. Appl. Math."                          } {
-  journal "Journal of Computer and System Sciences"                                                     = { "J. Comput. System Sci."                          } {
-  journal "Journal of Mathematical Analysis and Applications"                                           = { "J. Math. Anal. Appl."                            } {
-  journal "Journal of Mathematical Physics"                                                             = { "J. Math. Phys."                                  } {
-  journal "Journal of Parallel and Distributed Computing"                                               = { "J. Parallel and Distrib. Comput."                } {
-  journal "Journal of Research of the National Bureau of Standards"                                     = { "J. Res. Nat. Bur. Standards"                     } {
-  journal "Journal of VLSI and Computer Systems"                                                        = { "J. VLSI Comput. Syst."                           } {
-  journal "Journal of {VLSI} and Computer Systems"                                                      = { "J. VLSI Comput. Syst."                           } {
-  journal "Journal of the ACM"                                                                          = { "J. ACM"                                          } {
-  journal "Journal of the American Statistical Association"                                             = { "J. Amer. Statist. Assoc."                        } {
-  journal "Journal of the Institute of Mathematics and its Applications"                                = { "J. Inst. Math. Appl."                            } {
-  journal "Journal of the Society for Industrial and Applied Mathematics"                               = { "J. Soc. Indust. Appl. Math."                     } {
-  journal "Journal of the Society for Industrial and Applied Mathematics, Series B, Numerical Analysis" = { "J. Soc. Indust. Appl. Math. Ser. B Numer. Anal." } {
-  journal "Linear Algebra and its Applications"                                                         = { "Linear Algebra Appl."                            } {
-  journal "Mathematica Scandinavica"                                                                    = { "Math. Scand."                                    } {
-  journal "Mathematical Tables and Other Aids to Computation"                                           = { "Math. Tables Aids Comput."                       } {
-  journal "Mathematics of Computation"                                                                  = { "Math. Comp."                                     } {
-  journal "Mathematische Annalen"                                                                       = { "Math. Ann."                                      } {
-  journal "Numerische Mathematik"                                                                       = { "Numer. Math."                                    } {
-  journal "Pacific Journal of Mathematics"                                                              = { "Pacific J. Math."                                } {
-  journal "Parallel Computing"                                                                          = { "Parallel Comput."                                } {
-  journal "Philosophical Magazine"                                                                      = { "Philos. Mag."                                    } {
-  journal "Proceedings of the American Mathematical Society"                                            = { "Proc. Amer. Math. Soc."                          } {
-  journal "Proceedings of the IEEE"                                                                     = { "Proc. IEEE"                                      } {
-  journal "Proceedings of the {IEEE}"                                                                   = { "Proc. IEEE"                                      } {
-  journal "Proceedings of the National Academy of Sciences of the USA"                                  = { "Proc. Nat. Acad. Sci. U. S. A."                  } {
-  journal "Quarterly Journal of Mathematics, Oxford, Series (2)"                                        = { "Quart. J. Math. Oxford Ser. (2)"                 } {
-  journal "Quarterly of Applied Mathematics"                                                            = { "Quart. Appl. Math."                              } {
-  journal "Review of the International Statisical Institute"                                            = { "Rev. Inst. Internat. Statist."                   } {
-  journal "SIAM Journal on Algebraic and Discrete Methods"                                              = { "SIAM J. Algebraic Discrete Methods"              } {
-  journal "{SIAM} Journal on Algebraic and Discrete Methods"                                            = { "SIAM J. Algebraic Discrete Methods"              } {
-  journal "SIAM Journal on Applied Mathematics"                                                         = { "SIAM J. Appl. Math."                             } {
-  journal "{SIAM} Journal on Applied Mathematics"                                                       = { "SIAM J. Appl. Math."                             } {
-  journal "SIAM Journal on Computing"                                                                   = { "SIAM J. Comput."                                 } {
-  journal "{SIAM} Journal on Computing"                                                                 = { "SIAM J. Comput."                                 } {
-  journal "SIAM Journal on Matrix Analysis and Applications"                                            = { "SIAM J. Matrix Anal. Appl."                      } {
-  journal "{SIAM} Journal on Matrix Analysis and Applications"                                          = { "SIAM J. Matrix Anal. Appl."                      } {
-  journal "SIAM Journal on Numerical Analysis"                                                          = { "SIAM J. Numer. Anal."                            } {
-  journal "{SIAM} Journal on Numerical Analysis"                                                        = { "SIAM J. Numer. Anal."                            } {
-  journal "SIAM Journal on Scientific and Statistical Computing"                                        = { "SIAM J. Sci. Statist. Comput."                   } {
-  journal "{SIAM} Journal on Scientific and Statistical Computing"                                      = { "SIAM J. Sci. Statist. Comput."                   } {
-  journal "SIAM Review"                                                                                 = { "SIAM Rev."                                       } {
-  journal "{SIAM} Review"                                                                               = { "SIAM Rev."                                       } {
-  journal "Software Practice and Experience"                                                            = { "Software Prac. Experience"                       } {
-  journal "Statistical Science"                                                                         = { "Statist. Sci."                                   } {
-  journal "The Computer Journal"                                                                        = { "Comput. J."                                      } {
-  journal "Transactions of the American Mathematical Society"                                           = { "Trans. Amer. Math. Soc."                         } {
-  journal "USSR Computational Mathematics and Mathematical Physics"                                     = { "U. S. S. R. Comput. Math. and Math. Phys."       } {
-  journal "{USSR} Computational Mathematics and Mathematical Physics"                                   = { "U. S. S. R. Comput. Math. and Math. Phys."       } {
-  journal "Zeitschrift fur Angewandte Mathematik und Mechanik"                                          = { "Z. Angew. Math. Mech."                           } {
-  journal "Zeitschrift fur Angewandte Mathematik und Physik"                                            = { "Z. Angew. Math. Phys."                           } {
-  journal
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-  } if$ } if$ } if$ } if$ } if$ } if$ } if$ } if$
-}
-
-FUNCTION { format.journal.volume.number.day.month.year }
-{
-  % By Young (and Spencer)
-  % GNP - fixed bugs with missing volume, number, and/or pages
-  %
-  % Format journal, volume, number, pages for article types.
-  %
-  journal empty.or.unknown
-    { "no journal in " cite$ * warning$ "" }
-    { "\bibinfo{journal}{"
-      journal.canon.abbrev emphasize *
-      "}" * }
-  if$
-
-  number empty.or.unknown
-    {
-      volume empty.or.unknown
-        { "no number and no volume in " cite$ * warning$ "" * }
-        { " " * " \bibinfo{volume}{" * volume * "}" * }
-      if$
-    }
-    {
-      volume empty.or.unknown
-        {
-          "unusual to have number, but no volume, for " cite$ * warning$
-          " \bibinfo{number}{" * number * "}" *
-        }
-        { " \bibinfo{volume}{" * volume  * "}, \bibinfo{number}{" *
-          number * "}" *}
-      if$
-    }
-  if$
-  after.block 'output.state :=
-
-  % Sometimes proceedings are published in journals
-  % In this case we do not want to put year, day and month here
-
-  type$ "inproceedings" =
-    { }
-    {format.day.month.year * }
-  if$
-}
-
-FUNCTION { format.chapter.pages }
-{
-  chapter empty.or.unknown
-    'format.pages
-    { type empty.or.unknown
-        { "Chapter" } % gnp - changed to mixed case
-        { type "t" change.case$ }
-      if$
-      chapter tie.or.space.connect
-      pages empty.or.unknown
-        {"page numbers missing in " cite$ * warning$} % gnp - added check
-        { ", " * format.pages * }
-      if$
-    }
-  if$
-}
-
-FUNCTION { format.in.emphasize.booktitle }
-{ % jtb: format for collections or proceedings not appearing in a journal
-  booktitle empty.or.unknown
-  { "" }
-  { "In " format.emphasize.booktitle * }
-  if$
-}
-
-FUNCTION { format.in.booktitle }
-{ % jtb: format for proceedings appearing in a journal
-  booktitle empty.or.unknown
-  { "" }
-  { "In \bibinfo{booktitle}{" booktitle * "}" * }
-  if$
-}
-
-FUNCTION { format.in.ed.booktitle }
-{
-  booktitle empty.or.unknown
-  { "" }
-  { editor empty.or.unknown
-    { "In " format.emphasize.booktitle * }
-                % jtb: swapped editor location
-    { "In " format.emphasize.booktitle * ", " * format.editors.fml * }
-    if$
-  }
-  if$
-}
-
-FUNCTION { format.thesis.type }
-{ % call with default type on stack top
-  type empty.or.unknown
-    'skip$    % use default type
-    {
-      pop$    % discard default type
-      % NO: it is silly to have to brace protect every degree type!:  type "t" change.case$
-      type
-    }
-  if$
-}
-
-FUNCTION { format.tr.number }
-{
-  "\bibinfo{type}{"
-  type empty.or.unknown
-    { "{T}echnical {R}eport" }
-    'type
-  if$
-  "}" * *
-  number empty.or.unknown
-    { "t" change.case$ }
-    %% LOOKS BAD: { "." * number tie.or.space.connect }
-    %% Prefer "Research report RJ687." to "Research report. RJ687."
-    { number tie.or.space.connect }
-  if$
-}
-
-FUNCTION { format.advisor }
-{
-  advisor empty.or.unknown
-    { "" }
-    { "Advisor(s) " advisor * }
-  if$
-}
-
-FUNCTION { format.article.crossref }
-{ "See"
-  "\citeN{" * crossref * "}" *
-}
-
-FUNCTION { format.crossref.editor }
-{
-  editor #1 "{vv~}{ll}" format.name$
-  editor num.names$ duplicate$
-  #2 >
-    { pop$ " et~al\mbox{.}" * }         % jrh: avoid spacing problems
-    { #2 <
-    'skip$
-    { editor #2 "{ff }{vv }{ll}{ jj}" format.name$ "others" =
-        { " et~al\mbox{.}" * }          % jrh: avoid spacing problems
-        { " and " * editor #2 "{vv~}{ll}" format.name$ * }
-      if$
-    }
-      if$
-    }
-  if$
-}
-
-FUNCTION { format.book.crossref }
-{
-  volume empty.or.unknown
-    { "empty volume in " cite$ * "'s crossref of " * crossref * warning$
-      "In "
-    }
-    { "Volume" volume tie.or.space.connect % gnp - changed to mixed case
-      " of " *
-    }
-  if$
-  editor empty.or.unknown
-  editor field.or.null author field.or.null =
-  or
-    { key empty.or.unknown
-    { series empty.or.unknown
-        { "need editor, key, or series for " cite$ * " to crossref " *
-          crossref * warning$
-          "" *
-        }
-        { series emphasize * }
-      if$
-    }
-    { key * }
-      if$
-    }
-    { format.crossref.editor * }
-  if$
-  " \citeN{" * crossref * "}" *
-}
-
-FUNCTION { format.incoll.inproc.crossref }
-{ "See"
-  " \citeN{" * crossref * "}" *
-}
-
-FUNCTION { format.lab.names }
-{
-  % format.lab.names:
-  %
-  % determines "short" names for the abbreviated author information.
-  % "Long" labels are created in calc.label, using the routine my.full.label
-  % to format author and editor fields.
-  %
-  % There are 4 cases for labels.   (n=3 in the example)
-  % a) one author             Foo
-  % b) one to n               Foo, Bar and Baz
-  % c) use of "and others"    Foo, Bar et al.
-  % d) more than n            Foo et al.
-
-  's :=
-  s num.names$ 'numnames :=
-  numnames #2 >    % change number to number of others allowed before
-                   % forcing "et al".
-    { s #1 "{vv~}{ll}" format.name$ " et~al\mbox{.}" * } % jrh: \mbox{} added
-    {
-      numnames #1 - 'namesleft :=
-      #2 'nameptr :=
-      s #1 "{vv~}{ll}" format.name$
-        { namesleft #0 > }
-        { nameptr numnames =
-            { s nameptr "{ff }{vv }{ll}{ jj}" format.name$ "others" =
-                { " et~al\mbox{.}" * }          % jrh: avoid spacing problems
-                { " and " * s nameptr "{vv~}{ll}" format.name$ * }
-              if$
-            }
-            { ", " * s nameptr "{vv~}{ll}" format.name$ * }
-          if$
-          nameptr #1 + 'nameptr :=
-          namesleft #1 - 'namesleft :=
-        }
-      while$
-    }
-  if$
-}
-
-FUNCTION { author.key.label }
-{
-  author empty.or.unknown
-    { key empty.or.unknown
-          { "no key, author in " cite$ * warning$
-            cite$ #1 #3 substring$ }
-         'key
-      if$
-    }
-    { author format.lab.names }
-  if$
-}
-
-FUNCTION { editor.key.organization.label }
-{ % added - gnp. Provide label formatting by organization if editor is null.
-  editor empty.or.unknown
-    { organization empty.or.unknown
-        { key empty.or.unknown
-            { "no key, editor or organization in " cite$ * warning$
-              cite$ #1 #3 substring$ }
-            'key
-          if$
-        }
-        { organization }
-      if$
-    }
-    { editor format.lab.names }
-  if$
-}
-
-FUNCTION { author.editor.key.label }
-{
-  author empty.or.unknown
-    { editor empty.or.unknown
-          { key empty.or.unknown
-               { "no key, author, or editor in " cite$ * warning$
-                 cite$ #1 #3 substring$ }
-             'key
-           if$
-         }
-          { editor format.lab.names }
-      if$
-    }
-    { author format.lab.names }
-  if$
-}
-
-FUNCTION { author.editor.key.organization.label }
-{ % added - gnp. Provide label formatting by organization if author is null.
-  author empty.or.unknown
-    { editor empty.or.unknown
-        { organization empty.or.unknown
-            { key empty.or.unknown
-               { "no key, author, editor or organization in " cite$ * warning$
-                 cite$ #1 #3 substring$ }
-               'key
-              if$
-            }
-            { organization }
-          if$
-        }
-        { editor format.lab.names }
-      if$
-    }
-    { author format.lab.names }
-  if$
-}
-
-% Calculate label and leave it on stack
-FUNCTION { calc.basic.label }
-{
-  type$ "book" =
-  type$ "inbook" =
-  or
-  type$ "article" =
-  or
-    'author.editor.key.label
-    { type$ "proceedings" =
-      type$ "periodical" =
-      or
-        'editor.key.organization.label
-        { type$ "manual" =
-            'author.editor.key.organization.label
-            'author.key.label
-          if$
-        }
-      if$
-    }
-  if$
-  duplicate$
-  year empty.or.unknown
-    { "[n. d.]" }
-    { year field.or.null purify$ #-1 #4 substring$}
-  if$
-  *
-  'basic.label.year :=
-}
-
-FUNCTION { calc.label }
-{
-  % Changed - GNP. See also author.editor.organization.sort, editor.organization.sort
-  % Form label for BibTeX entry. The classification of which fields are used
-  % for which type of entry (book, inbook, etc.) are taken from alpha.bst.
-  % The change here from newapa is to also include organization as a
-  % citation label if author or editor is missing.
-
-  calc.basic.label
-
-  author empty.or.unknown  % generate the full label citation information.
-    {
-      editor empty.or.unknown
-        {
-          organization empty.or.unknown
-            {
-              key empty.or.unknown
-                {
-                  "no author, editor, organization, or key in " cite$ * warning$
-                  "??"
-                }
-                { key }
-              if$
-            }
-            { organization }
-          if$
-        }
-        { editor my.full.label }
-      if$
-    }
-    { author my.full.label }
-  if$
-
-  % leave label on the stack, to be popped when required.
-
-  "}{" * swap$ * "}{" *
-  %  year field.or.null purify$ #-1 #4 substring$ *
-  %
-  % save the year for sort processing afterwards (adding a, b, c, etc.)
-  %
-  year empty.or.unknown
-    { "[n. d.]" }
-    { year field.or.null purify$ #-1 #4 substring$}
-  if$
-  'label.year :=
-}
-
-
-FUNCTION { output.bibitem }
-{
-  newline$
-  "\bibitem[\protect\citeauthoryear{" write$
-  calc.label write$
-  sort.year write$
-  "}]%" writeln
-  "        {" write$
-  cite$ write$
-  "}" writeln
-  ""
-  before.all 'output.state :=
-}
-
-
-FUNCTION { output.issue.doi.coden.isxn.lccn.url.eprint }
-{ % enter and return with stack empty
-  %% We switch now from buffered output to output of complete lines, so
-  %% that the Issue .. URL data have their own lines, and are less likely
-  %% to be line-wrapped by BibTeX's short-sighted algorithm, which wraps
-  %% lines longer than 79 characters, backtracking to what it thinks is
-  %% a break point in the string.  Any such wrapping MUST be undone to
-  %% prevent percent-newline from appearing in DOIs and URLs.  The
-  %% output data are intentionally wrapped in \showxxx{} macros at
-  %% beginning of line, and that supply their own punctuation (if they
-  %% are not defined to suppress output entirely), to make it easier for
-  %% other software to recover them from .bbl files.
-  %%
-  %% It also makes it possible to later change the macro definitions
-  %% to suppress particular output values, or alter their appearance.
-  %%
-  %% Note that it is possible for theses, technical reports, and
-  %% manuals to have ISBNs, and anything that has an ISBN may also
-  %% have an ISSN.  When there are no values for these keys, there
-  %% is no output generated for them here.
-
-  "\newblock" writeln
-  after.block 'output.state :=
-
-  output.issue
-  output.isbn
-  output.coden  % CODEN is functionally like ISSN, so output them sequentially
-  output.issn
-  output.lccn
-  output.doi    % DOI is ALWAYS last according to CrossRef DOI documentation
-  output.eprint
-  output.url    % but ACM wants URL last
-}
-
-FUNCTION { output.issue.doi.coden.isxn.lccn.url.eprint.note }
-{ % enter with stack empty, return with empty string on stack
-  output.issue.doi.coden.isxn.lccn.url.eprint
-  note empty.or.unknown
-    { }
-    {
-      "\newblock" writeln
-      output.note
-    }
-  if$
-  ""
-}
-
-FUNCTION { output.issue.doi.coden.isxn.lccn.url.eprint.note.check }
-{ % enter with stack empty, return with empty string on stack
-  output.issue.doi.coden.isxn.lccn.url.eprint
-  note empty.or.unknown
-    { }
-    {
-      "\newblock" writeln
-      output.note.check
-    }
-  if$
-  ""
-}
-
-FUNCTION { article }
-{
-  output.bibitem
-
-  author empty.or.unknown
-    {
-      editor empty.or.unknown
-        { "neither author and editor supplied for " cite$ * warning$ }
-        { format.editors "editor" output.check }
-      if$
-    }
-    { format.authors "author" output.check }
-  if$
-
-  author format.no.key output       % added
-  output.year.check                 % added
-  new.block
-  format.articletitle "title" output.check
-  new.block
-  howpublished empty.or.unknown
-    { }
-    { "\bibinfo{howpublished}{" howpublished "}" * * output }
-  if$
-
-  crossref missing$
-    { format.journal.volume.number.day.month.year output}
-    {
-      "cross reference in @Article{...} is unusual" warning$
-      format.article.crossref output.nonnull
-    }
-  if$
-
-  format.pages.check.without.articleno output
-  format.articleno.numpages output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { book }
-{
-  output.bibitem
-  author empty.or.unknown
-    { format.editors "author and editor" output.check }
-    { format.authors output.nonnull
-      crossref missing$
-        { "author and editor" editor either.or.check }
-        'skip$
-      if$
-    }
-  if$
-  output.year.check       % added
-  new.block
-  format.btitle "title" output.check
-  crossref missing$
-    { new.sentence              % jtb: start a new sentence for series/volume
-      format.bvolume output
-      new.block
-      format.number.series output
-      new.sentence
-      publisher "publisher" bibinfo.output.check
-      address "address" bibinfo.output.check    % jtb: require address
-      fin.sentence
-      pages empty.or.unknown
-        { format.bookpages }    % use bookpages when pages empty
-        { format.pages.check "pages" tie.or.space.connect }
-      if$
-      output
-    }
-    { new.block
-      format.book.crossref output.nonnull
-    }
-  if$
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { booklet }
-{
-  output.bibitem
-  format.authors output
-  author format.key output          % added
-  output.year.check                 % added
-  new.block
-  format.title "title" output.check
-  new.block
-    howpublished empty.or.unknown
-    { }
-    { "\bibinfo{howpublished}{" howpublished "}" * * output }
-  if$
-  address output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { inbook }
-{
-  output.bibitem
-  author empty.or.unknown
-    { format.editors
-      "author and editor" output.check
-    }
-    { format.authors output.nonnull
-      crossref missing$
-    { "author and editor" editor either.or.check }
-    'skip$
-      if$
-    }
-  if$
-  output.year.check                 % added
-  new.block
-  format.btitle "title" output.check
-  crossref missing$
-    { new.sentence              % jtb: start a new sentence for series/volume
-      format.bvolume output
-      new.block
-      format.number.series output
-      new.sentence
-      publisher "publisher" bibinfo.output.check
-      address "address" bibinfo.output.check    % jtb: require address
-      format.bookpages output
-      format.chapter.pages
-      "chapter and pages" output.check  % jtb: moved from before publisher
-    }
-    {
-      format.bookpages output
-      format.chapter.pages "chapter and pages" output.check
-      new.block
-      format.book.crossref output.nonnull
-    }
-  if$
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { incollection }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output       % added
-  output.year.check              % added
-  new.block
-  format.articletitle "title" output.check
-  new.block
-  crossref missing$
-    { format.in.ed.booktitle "booktitle" output.check
-      new.sentence                % jtb: start a new sentence for series/volume
-      format.bvolume output
-      format.number.series output
-      new.sentence
-      publisher "publisher" bibinfo.output.check
-      address "address" bibinfo.output.check      % jtb: require address
-      format.bookpages output
-      format.chapter.pages output % gnp - was special.output.nonnull
-                                  % left out comma before page numbers
-                                  % jtb: moved from before publisher
-    }
-    {
-      format.incoll.inproc.crossref output.nonnull
-      format.chapter.pages output
-    }
-  if$
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { inproceedings }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output            % added
-  output.year.check                   % added
-  new.block
-  format.articletitle "title" output.check
-  howpublished empty.or.unknown
-    { }
-    { "\bibinfo{howpublished}{" howpublished "}" * * output.dot.space }
-  if$
-  crossref missing$
-    {
-      journal missing$          % jtb: proceedings appearing in journals
-        { format.in.emphasize.booktitle format.city "booktitle"  output.check.dot.space
-          format.series output.removenospace
-          format.editors.fml output % BV 2011/09/27 Moved dot to comma
-          format.bvolume.noseries output
-          new.sentence
-          organization output
-          publisher "publisher" bibinfo.output.check % jtb: require publisher (?)
-          address "address" bibinfo.output.check  % jtb: require address
-          format.bookpages output
-        }
-        {
-           format.in.booktitle format.city "booktitle" output.check
-           format.editors.fml output
-           new.sentence
-           format.journal.volume.number.day.month.year output
-        }
-      if$
-      format.articleno output
-      format.pages.check.without.articleno output
-    }
-    {
-      format.incoll.inproc.crossref output.nonnull
-      format.articleno output
-      format.pages.check.without.articleno output
-    }
-  if$
-  format.articleno.numpages output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { conference } { inproceedings }
-
-FUNCTION { manual }
-{
-  output.bibitem
-  author empty.or.unknown
-    { editor empty.or.unknown
-      { organization "organization" output.check
-        organization format.key output }  % if all else fails, use key
-      { format.editors "author and editor" output.check }
-      if$
-    }
-    { format.authors output.nonnull }
-    if$
-  output.year.check                 % added
-  new.block
-  format.btitle "title" output.check
-  organization address new.block.checkb
-  % jtb: back to normal style: organization, address
-  organization "organization" output.check
-  address output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { mastersthesis }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output          % added
-  output.year.check                 % added
-  new.block
-  format.title emphasize "title" output.check  % NB: ACM style requires emphasized thesis title
-  new.block
-  "\bibinfo{thesistype}{Master's\ thesis}" format.thesis.type output
-  new.sentence
-  school "school" bibinfo.output.check
-  address empty.or.unknown
-     { }
-     { "\bibinfo{address}{" address * "}" * output }
-  if$
-  new.block
-  format.advisor output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { misc }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output            % added
-  output.year.check                   % added
-  title howpublished new.block.checkb
-  format.title output
-  new.block
-  howpublished empty.or.unknown
-    { }
-    { "\bibinfo{howpublished}{" howpublished "}" * * output }
-  if$
-  "" output.nonnull.dot.space
-  output.day.month.year
-  calc.format.page.count output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { online } { misc }
-
-FUNCTION { game } { misc }
-
-
-FUNCTION { phdthesis }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output          % added
-  output.year.check                 % added
-  new.block
-  format.title emphasize "title" output.check  % NB: ACM style requires emphasized thesis title
-  new.block
-  "\bibinfo{thesistype}{Ph.D. Dissertation}" format.thesis.type output
-  new.sentence
-  school "school" bibinfo.output.check
-  address empty.or.unknown
-     { }
-     { "\bibinfo{address}{" address * "}" * output }
-  if$
-  new.block
-  format.advisor output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION {format.date}
-{ year empty.or.unknown
-    { month empty.or.unknown
-        {
-          ""                    % output empty date if year/month both empty
-          day empty.or.unknown
-            {  }
-            { "there's a day but no month or year in " cite$ * warning$ }
-          if$
-        }
-        { "there's a month but no year in " cite$ * warning$
-          month
-          day empty.or.unknown
-            { }
-            { " " * day * }
-          if$
-        }
-      if$
-    }
-    { month empty.or.unknown
-        {
-          year                  % output only year if month empty
-          day empty.or.unknown
-            {  }
-            { "there's a day and year but no month in " cite$ * warning$ }
-          if$
-        }
-        {
-          month " " *
-          day empty.or.unknown
-            { }
-            { day * ", " * }
-          if$
-          year *
-        }
-      if$
-    }
-  if$
-}
-
-FUNCTION {new.block.checka}
-{
-  empty.or.unknown
-    'skip$
-    'new.block
-  if$
-}
-
-FUNCTION { periodical }
-{
-  output.bibitem
-  editor empty.or.unknown
-    { organization output }
-    { format.editors output.nonnull }
-  if$
-  new.block
-  output.year.check
-  new.sentence
-  format.articletitle "title" output.check
-  format.journal.volume.number.day.month.year output
-  calc.format.page.count output
-  fin.entry
-}
-
-FUNCTION { proceedings }
-{
-  output.bibitem
-  editor empty.or.unknown
-    { organization output
-      organization format.key output }  % gnp - changed from author format.key
-    { format.editors output.nonnull }
-  if$
-  % author format.key output             % gnp - removed (should be either
-  %                                        editor or organization
-  output.year.check                    % added (newapa)
-  new.block
-  format.btitle format.city "title" output.check        % jtb: added city
-  new.sentence
-  format.bvolume output
-  format.number.series output
-  new.sentence
-  organization output
-  % jtb: normal order: publisher, address
-  publisher empty.or.unknown
-     { }
-     { "\bibinfo{publisher}{" publisher * "}" * output }
-  if$
-  address empty.or.unknown
-     { }
-     { "\bibinfo{address}{" address * "}" * output }
-  if$
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { collection } { proceedings }
-
-FUNCTION { techreport }
-{
-  output.bibitem
-  format.authors "author" output.check
-  author format.key output             % added
-  output.year.check                    % added
-  new.block
-  format.btitle "title" output.check
-  new.block
-%   format.tr.number output               % jtb: moved month ...
-  format.tr.number output new.sentence    % Gerry  - need dot 2011/09/28
-  institution "institution" bibinfo.output.check
-  address empty.or.unknown
-    { }
-    { "\bibinfo{address}{" address "}" * * output }
-  if$
-  new.sentence
-  format.named.pages output
-  % ACM omits year at end in transactions style
-  % format.day.month.year output.nonnull.dot.space  % jtb: ... to here (no parens)
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note
-  fin.entry
-}
-
-FUNCTION { unpublished }
-{
-  output.bibitem
-  format.authors
-  "author" output.check
-  author format.key output              % added
-  output.year.check                     % added
-  new.block
-  format.title "title" output.check
-  fin.sentence
-  output.day.month.year                 % UTAH
-  calc.format.page.count output
-  fin.block
-  output.issue.doi.coden.isxn.lccn.url.eprint.note.check
-  fin.entry
-}
-
-FUNCTION { default.type } { misc }
-
-%%% ACM journal-style month definitions: full name if 1--5 letters, else
-%%% abbreviation of 3 or 4 characters and a dot
-
-MACRO {jan}             {"Jan."}
-
-MACRO {feb}             {"Feb."}
-
-MACRO {mar}             {"March"}
-
-MACRO {apr}             {"April"}
-
-MACRO {may}             {"May"}
-
-MACRO {jun}             {"June"}
-
-MACRO {jul}             {"July"}
-
-MACRO {aug}             {"Aug."}
-
-MACRO {sep}             {"Sept."}
-
-MACRO {oct}             {"Oct."}
-
-MACRO {nov}             {"Nov."}
-
-MACRO {dec}             {"Dec."}
-
-
-
-READ
-
-FUNCTION { sortify }
-{
-  purify$
-  "l" change.case$
-}
-
-FUNCTION { chop.word }
-{
-  's :=
-  'len :=
-  s #1 len substring$ =
-    { s len #1 + global.max$ substring$ }
-    's
-  if$
-}
-
-FUNCTION { sort.format.names }
-{
-  's :=
-  #1 'nameptr :=
-  ""
-  s num.names$ 'numnames :=
-  numnames 'namesleft :=
-    { namesleft #0 > }
-    { nameptr #1 >
-          { "   " * }
-         'skip$
-      if$
-      s nameptr "{vv{ } }{ll{ }}{  f{ }}{  jj{ }}" format.name$ 't :=
-      nameptr numnames = t "others" = and
-          { " et~al" * }
-          { t sortify * }
-      if$
-      nameptr #1 + 'nameptr :=
-      namesleft #1 - 'namesleft :=
-    }
-  while$
-}
-
-FUNCTION { sort.format.title }
-{
-  't :=
-  "A " #2
-    "An " #3
-      "The " #4 t chop.word
-    chop.word
-  chop.word
-  sortify
-  #1 global.max$ substring$
-}
-
-FUNCTION { author.sort }
-{
-  author empty.or.unknown
-    { key empty.or.unknown
-         { "to sort, need author or key in " cite$ * warning$
-           "" }
-         { key sortify }
-      if$
-    }
-    { author sort.format.names }
-  if$
-}
-
-FUNCTION { author.editor.sort }
-{
-  author empty.or.unknown
-    {
-      editor empty.or.unknown
-         {
-           key empty.or.unknown
-             { "to sort, need author, editor, or key in " cite$ * warning$
-               ""
-             }
-             { key sortify }
-           if$
-         }
-         { editor sort.format.names }
-      if$
-    }
-    { author sort.format.names }
-  if$
-}
-
-FUNCTION { editor.organization.sort }
-{
-  % added - GNP. Stack editor or organization for sorting (from alpha.bst).
-  % Unlike alpha.bst, we need entire names, not abbreviations
-
-  editor empty.or.unknown
-    { organization empty.or.unknown
-        { key empty.or.unknown
-            { "to sort, need editor, organization, or key in " cite$ * warning$
-              ""
-            }
-            { key sortify }
-          if$
-        }
-        { organization sortify }
-      if$
-    }
-    { editor sort.format.names }
-  if$
-}
-
-FUNCTION { author.editor.organization.sort }
-{
-  % added - GNP. Stack author or organization for sorting (from alpha.bst).
-  % Unlike alpha.bst, we need entire names, not abbreviations
-
-  author empty.or.unknown
-    {
-      editor empty.or.unknown
-        { organization empty.or.unknown
-            { key empty.or.unknown
-                { "to sort, need author, editor, or key in " cite$ * warning$
-                ""
-                }
-                { key sortify }
-              if$
-            }
-            { organization sortify }
-          if$
-        }
-        { editor sort.format.names }
-      if$
-    }
-    { author sort.format.names }
-  if$
-}
-
-FUNCTION { presort }
-{
-  % Presort creates the bibentry's label via a call to calc.label, and then
-  % sorts the entries based on entry type. Chicago.bst adds support for
-  % including organizations as the sort key; the following is stolen from
-  % alpha.bst.
-
-  calc.label
-  basic.label.year
-  swap$
-  "    "
-  swap$
-  * *
-  "    "
-  *
-  sortify
-  year field.or.null purify$ #-1 #4 substring$ * % add year
-  "    "
-  *
-  type$ "book" =
-  type$ "inbook" =
-  or
-  type$ "article" =
-  or
-    'author.editor.sort
-    { type$ "proceedings" =
-      type$ "periodical" =
-      or
-        'editor.organization.sort
-        { type$ "manual" =
-            'author.editor.organization.sort
-            'author.sort
-          if$
-        }
-      if$
-    }
-  if$
-  #1 entry.max$ substring$        % added for newapa
-  'sort.label :=                  % added for newapa
-  sort.label                      % added for newapa
-  *
-  "    "
-  *
-  title field.or.null
-  sort.format.title
-  *
-  #1 entry.max$ substring$
-  'sort.key$ :=
-}
-
-
-
-ITERATE { presort }
-
-SORT             % by label, year, author/editor, title
-
-% From plainnat.bst
-STRINGS { longest.label }
-
-INTEGERS { longest.label.width number.label }
-
-FUNCTION {initialize.longest.label}
-{ "" 'longest.label :=
-  #0 int.to.chr$ 'last.label :=
-  "" 'next.extra :=
-  #0 'longest.label.width :=
-  #0 'last.extra.num :=
-  #0 'number.label :=
-}
-
-
-
-FUNCTION { initialize.extra.label.stuff }
-{ #0 int.to.chr$ 'last.label :=
-  "" 'next.extra :=
-  #0 'last.extra.num :=
-}
-
-FUNCTION { forward.pass }
-{
-  % Pass through all entries, comparing current entry to last one.
-  % Need to concatenate year to the stack (done by calc.label) to determine
-  % if two entries are the same (see presort)
-
-  last.label
-  calc.basic.label year field.or.null purify$ #-1 #4 substring$ * % add year
-  #1 entry.max$ substring$ =     % are they equal?
-     { last.extra.num #1 + 'last.extra.num :=
-       last.extra.num int.to.chr$ 'extra.label :=
-     }
-     { "a" chr.to.int$ 'last.extra.num :=
-       "" 'extra.label :=
-       calc.basic.label year field.or.null purify$ #-1 #4 substring$ * % add year
-       #1 entry.max$ substring$ 'last.label := % assign to last.label
-     }
-  if$
-  number.label #1 + 'number.label :=
-}
-
-FUNCTION { reverse.pass }
-{
-  next.extra "b" =
-    { "a" 'extra.label := }
-     'skip$
-  if$
-  label.year extra.label * 'sort.year :=
-  extra.label 'next.extra :=
-}
-
-EXECUTE {initialize.extra.label.stuff}
-EXECUTE {initialize.longest.label}
-
-
-ITERATE {forward.pass}
-
-REVERSE {reverse.pass}
-
-FUNCTION { bib.sort.order }
-{
-  sort.label
-  "    "
-  *
-  year field.or.null sortify
-  *
-  "    "
-  *
-  title field.or.null
-  sort.format.title
-  *
-  #1 entry.max$ substring$
-  'sort.key$ :=
-}
-
-ITERATE { bib.sort.order }
-
-SORT             % by sort.label, year, title --- giving final bib. order.
-
-FUNCTION { begin.bib }
-{
-  %% Set to #0 show 13-digit ISBN in preference to 10-digit ISBN.
-  %% Set to #1 to show both 10-digit and 13-digit ISBNs.
-  #1 'show-isbn-10-and-13 :=
-
-  "%%% -*-BibTeX-*-" writeln
-  "%%% Do NOT edit. File created by BibTeX with style" writeln
-  "%%% ACM-Reference-Format-Journals [18-Jan-2012]." writeln
-  "" writeln
-
-  preamble$ empty.or.unknown
-    'skip$
-    { preamble$ writeln }
-  if$
-  "\begin{thebibliography}{" number.label int.to.str$ * "}" * writeln
-  ""                                                                         writeln
-  "%%% ====================================================================" writeln
-  "%%% NOTE TO THE USER: you can override these defaults by providing"       writeln
-  "%%% customized versions of any of these macros before the \bibliography"  writeln
-  "%%% command.  Each of them MUST provide its own final punctuation,"       writeln
-  "%%% except for \shownote{}, \showDOI{}, and \showURL{}.  The latter two"  writeln
-  "%%% do not use final punctuation, in order to avoid confusing it with"    writeln
-  "%%% the Web address."                                                     writeln
-  "%%%"                                                                      writeln
-  "%%% To suppress output of a particular field, define its macro to expand" writeln
-  "%%% to an empty string, or better, \unskip, like this:"                   writeln
-  "%%%"                                                                      writeln
-  "%%% \newcommand{\showDOI}[1]{\unskip}   % LaTeX syntax"                   writeln
-  "%%%"                                                                      writeln
-  "%%% \def \showDOI #1{\unskip}           % plain TeX syntax"               writeln
-  "%%%"                                                                      writeln
-  "%%% ====================================================================" writeln
-  ""                                                                         writeln
-
-  %% ACM publications do not use CODEN, ISSN, and LCCN data, so their default
-  %% macro wrappers expand to \unskip, discarding their values and unwanted
-  %% space.
-  %%
-  %% For other publications, prior definitions like these may be useful:
-  %%
-  %%     Plain TeX:
-  %%         \def \showCODEN     #1{CODEN #1.}
-  %%         \def \showISSN      #1{ISSN #1.}
-  %%         \def \showLCCN      #1{LCCN #1.}
-  %%
-  %%     LaTeX:
-  %%         \newcommand{\showCODEN}[1]{CODEN #1.}
-  %%         \newcommand{\showISSN}[1]#1{ISSN #1.}
-  %%         \newcommand{\showLCCN}[1]{LCCN #1.}
-
-  "\ifx \showCODEN    \undefined \def \showCODEN     #1{\unskip}     \fi" writeln
-  "\ifx \showDOI      \undefined \def \showDOI       #1{#1}\fi" writeln
-  % ACM styles omit ISBNs, but they can be included by suitable definitions of
-  % \showISBNx and \showISBNxiii before the .bbl file is read
-  "\ifx \showISBNx    \undefined \def \showISBNx     #1{\unskip}     \fi" writeln
-  "\ifx \showISBNxiii \undefined \def \showISBNxiii  #1{\unskip}     \fi" writeln
-  "\ifx \showISSN     \undefined \def \showISSN      #1{\unskip}     \fi" writeln
-  "\ifx \showLCCN     \undefined \def \showLCCN      #1{\unskip}     \fi" writeln
-  "\ifx \shownote     \undefined \def \shownote      #1{#1}          \fi" writeln % NB: final period supplied by add.period$ above
-  "\ifx \showarticletitle \undefined \def \showarticletitle #1{#1}   \fi" writeln
-  "\ifx \showURL      \undefined \def \showURL       {\relax}        \fi" writeln
-  "% The following commands are used for tagged output and should be " writeln
-  "% invisible to TeX" writeln
-  "\providecommand\bibfield[2]{#2}" writeln
-  "\providecommand\bibinfo[2]{#2}" writeln
-  "\providecommand\natexlab[1]{#1}" writeln
-  "\providecommand\showeprint[2][]{arXiv:#2}" writeln
-}
-
-EXECUTE {begin.bib}
-
-EXECUTE {init.state.consts}
-
-ITERATE {call.type$}
-
-FUNCTION { end.bib }
-{
-  newline$
-  "\end{thebibliography}"
-  writeln
-}
-
-EXECUTE {end.bib}