| 
						 | 
						- %%
 - %% IEEEtran.bst
 - %% BibTeX Bibliography Style file for IEEE Journals and Conferences (unsorted)
 - %% Version 1.13 (2008/09/30)
 - %% 
 - %% Copyright (c) 2003-2008 Michael Shell
 - %% 
 - %% Original starting code base and algorithms obtained from the output of
 - %% Patrick W. Daly's makebst package as well as from prior versions of
 - %% IEEE BibTeX styles:
 - %% 
 - %% 1. Howard Trickey and Oren Patashnik's ieeetr.bst  (1985/1988)
 - %% 2. Silvano Balemi and Richard H. Roy's IEEEbib.bst (1993)
 - %% 
 - %% Support sites:
 - %% http://www.michaelshell.org/tex/ieeetran/
 - %% http://www.ctan.org/tex-archive/macros/latex/contrib/IEEEtran/
 - %% and/or
 - %% http://www.ieee.org/
 - %% 
 - %% For use with BibTeX version 0.99a or later
 - %%
 - %% This is a numerical citation style.
 - %% 
 - %%*************************************************************************
 - %% Legal Notice:
 - %% This code is offered as-is without any warranty either expressed or
 - %% implied; without even the implied warranty of MERCHANTABILITY or
 - %% FITNESS FOR A PARTICULAR PURPOSE! 
 - %% User assumes all risk.
 - %% In no event shall IEEE or any contributor to this code be liable for
 - %% any damages or losses, including, but not limited to, incidental,
 - %% consequential, or any other damages, resulting from the use or misuse
 - %% of any information contained here.
 - %%
 - %% All comments are the opinions of their respective authors and are not
 - %% necessarily endorsed by the IEEE.
 - %%
 - %% This work is distributed under the LaTeX Project Public License (LPPL)
 - %% ( http://www.latex-project.org/ ) version 1.3, and may be freely used,
 - %% distributed and modified. A copy of the LPPL, version 1.3, is included
 - %% in the base LaTeX documentation of all distributions of LaTeX released
 - %% 2003/12/01 or later.
 - %% Retain all contribution notices and credits.
 - %% ** Modified files should be clearly indicated as such, including  **
 - %% ** renaming them and changing author support contact information. **
 - %%
 - %% File list of work: IEEEabrv.bib, IEEEfull.bib, IEEEexample.bib,
 - %%                    IEEEtran.bst, IEEEtranS.bst, IEEEtranSA.bst,
 - %%                    IEEEtranN.bst, IEEEtranSN.bst, IEEEtran_bst_HOWTO.pdf
 - %%*************************************************************************
 - %
 - %
 - % Changelog:
 - %
 - % 1.00 (2002/08/13) Initial release
 - %
 - % 1.10 (2002/09/27)
 - %  1. Corrected minor bug for improperly formed warning message when a
 - %     book was not given a title. Thanks to Ming Kin Lai for reporting this.
 - %  2. Added support for CTLname_format_string and CTLname_latex_cmd fields
 - %     in the BST control entry type.
 - %
 - % 1.11 (2003/04/02)
 - %  1. Fixed bug with URLs containing underscores when using url.sty. Thanks
 - %     to Ming Kin Lai for reporting this.
 - %
 - % 1.12 (2007/01/11)
 - %  1. Fixed bug with unwanted comma before "et al." when an entry contained
 - %     more than two author names. Thanks to Pallav Gupta for reporting this.
 - %  2. Fixed bug with anomalous closing quote in tech reports that have a
 - %     type, but without a number or address. Thanks to Mehrdad Mirreza for
 - %     reporting this.
 - %  3. Use braces in \providecommand in begin.bib to better support
 - %     latex2html. TeX style length assignments OK with recent versions
 - %     of latex2html - 1.71 (2002/2/1) or later is strongly recommended.
 - %     Use of the language field still causes trouble with latex2html.
 - %     Thanks to Federico Beffa for reporting this.
 - %  4. Added IEEEtran.bst ID and version comment string to .bbl output.
 - %  5. Provide a \BIBdecl hook that allows the user to execute commands
 - %     just prior to the first entry.
 - %  6. Use default urlstyle (is using url.sty) of "same" rather than rm to
 - %     better work with a wider variety of bibliography styles.
 - %  7. Changed month abbreviations from Sept., July and June to Sep., Jul.,
 - %     and Jun., respectively, as IEEE now does. Thanks to Moritz Borgmann
 - %     for reporting this.
 - %  8. Control entry types should not be considered when calculating longest
 - %     label width.
 - %  9. Added alias www for electronic/online.
 - % 10. Added CTLname_url_prefix control entry type.
 - %
 - % 1.13 (2008/09/30)
 - %  1. Fixed bug with edition number to ordinal conversion. Thanks to
 - %     Michael Roland for reporting this and correcting the algorithm.
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - %% DEFAULTS FOR THE CONTROLS OF THE BST STYLE %%
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - % These are the defaults for the user adjustable controls. The values used
 - % here can be overridden by the user via IEEEtranBSTCTL entry type.
 - 
 - % NOTE: The recommended LaTeX command to invoke a control entry type is:
 - % 
 - %\makeatletter
 - %\def\bstctlcite{\@ifnextchar[{\@bstctlcite}{\@bstctlcite[@auxout]}}
 - %\def\@bstctlcite[#1]#2{\@bsphack
 - %  \@for\@citeb:=#2\do{%
 - %    \edef\@citeb{\expandafter\@firstofone\@citeb}%
 - %    \if@filesw\immediate\write\csname #1\endcsname{\string\citation{\@citeb}}\fi}%
 - %  \@esphack}
 - %\makeatother
 - %
 - % It is called at the start of the document, before the first \cite, like:
 - % \bstctlcite{IEEEexample:BSTcontrol}
 - %
 - % IEEEtran.cls V1.6 and later does provide this command.
 - 
 - 
 - 
 - % #0 turns off the display of the number for articles.
 - % #1 enables
 - FUNCTION {default.is.use.number.for.article} { #1 }
 - 
 - 
 - % #0 turns off the display of the paper and type fields in @inproceedings.
 - % #1 enables
 - FUNCTION {default.is.use.paper} { #1 }
 - 
 - 
 - % #0 turns off the forced use of "et al."
 - % #1 enables
 - FUNCTION {default.is.forced.et.al} { #0 }
 - 
 - % The maximum number of names that can be present beyond which an "et al."
 - % usage is forced. Be sure that num.names.shown.with.forced.et.al (below)
 - % is not greater than this value!
 - % Note: There are many instances of references in IEEE journals which have
 - % a very large number of authors as well as instances in which "et al." is
 - % used profusely.
 - FUNCTION {default.max.num.names.before.forced.et.al} { #10 }
 - 
 - % The number of names that will be shown with a forced "et al.".
 - % Must be less than or equal to max.num.names.before.forced.et.al
 - FUNCTION {default.num.names.shown.with.forced.et.al} { #1 }
 - 
 - 
 - % #0 turns off the alternate interword spacing for entries with URLs.
 - % #1 enables
 - FUNCTION {default.is.use.alt.interword.spacing} { #1 }
 - 
 - % If alternate interword spacing for entries with URLs is enabled, this is
 - % the interword spacing stretch factor that will be used. For example, the
 - % default "4" here means that the interword spacing in entries with URLs can
 - % stretch to four times normal. Does not have to be an integer. Note that
 - % the value specified here can be overridden by the user in their LaTeX
 - % code via a command such as: 
 - % "\providecommand\BIBentryALTinterwordstretchfactor{1.5}" in addition to
 - % that via the IEEEtranBSTCTL entry type.
 - FUNCTION {default.ALTinterwordstretchfactor} { "4" }
 - 
 - 
 - % #0 turns off the "dashification" of repeated (i.e., identical to those
 - % of the previous entry) names. IEEE normally does this.
 - % #1 enables
 - FUNCTION {default.is.dash.repeated.names} { #1 }
 - 
 - 
 - % The default name format control string.
 - FUNCTION {default.name.format.string}{ "{f.~}{vv~}{ll}{, jj}" }
 - 
 - 
 - % The default LaTeX font command for the names.
 - FUNCTION {default.name.latex.cmd}{ "" }
 - 
 - 
 - % The default URL prefix.
 - FUNCTION {default.name.url.prefix}{ "[Online]. Available:" }
 - 
 - 
 - % Other controls that cannot be accessed via IEEEtranBSTCTL entry type.
 - 
 - % #0 turns off the terminal startup banner/completed message so as to
 - % operate more quietly.
 - % #1 enables
 - FUNCTION {is.print.banners.to.terminal} { #1 }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - %% FILE VERSION AND BANNER %%
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - FUNCTION{bst.file.version} { "1.13" }
 - FUNCTION{bst.file.date} { "2008/09/30" }
 - FUNCTION{bst.file.website} { "http://www.michaelshell.org/tex/ieeetran/bibtex/" }
 - 
 - FUNCTION {banner.message}
 - { is.print.banners.to.terminal
 -      { "-- IEEEtran.bst version" " " * bst.file.version *
 -        " (" * bst.file.date * ") " * "by Michael Shell." *
 -        top$
 -        "-- " bst.file.website *
 -        top$
 -        "-- See the " quote$ * "IEEEtran_bst_HOWTO.pdf" * quote$ * " manual for usage information." *
 -        top$
 -      }
 -      { skip$ }
 -    if$
 - }
 - 
 - FUNCTION {completed.message}
 - { is.print.banners.to.terminal
 -      { ""
 -        top$
 -        "Done."
 -        top$
 -      }
 -      { skip$ }
 -    if$
 - }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%
 - %% STRING CONSTANTS %%
 - %%%%%%%%%%%%%%%%%%%%%%
 - 
 - FUNCTION {bbl.and}{ "and" }
 - FUNCTION {bbl.etal}{ "et~al." }
 - FUNCTION {bbl.editors}{ "eds." }
 - FUNCTION {bbl.editor}{ "ed." }
 - FUNCTION {bbl.edition}{ "ed." }
 - FUNCTION {bbl.volume}{ "vol." }
 - FUNCTION {bbl.of}{ "of" }
 - FUNCTION {bbl.number}{ "no." }
 - FUNCTION {bbl.in}{ "in" }
 - FUNCTION {bbl.pages}{ "pp." }
 - FUNCTION {bbl.page}{ "p." }
 - FUNCTION {bbl.chapter}{ "ch." }
 - FUNCTION {bbl.paper}{ "paper" }
 - FUNCTION {bbl.part}{ "pt." }
 - FUNCTION {bbl.patent}{ "Patent" }
 - FUNCTION {bbl.patentUS}{ "U.S." }
 - FUNCTION {bbl.revision}{ "Rev." }
 - FUNCTION {bbl.series}{ "ser." }
 - FUNCTION {bbl.standard}{ "Std." }
 - FUNCTION {bbl.techrep}{ "Tech. Rep." }
 - FUNCTION {bbl.mthesis}{ "Master's thesis" }
 - FUNCTION {bbl.phdthesis}{ "Ph.D. dissertation" }
 - FUNCTION {bbl.st}{ "st" }
 - FUNCTION {bbl.nd}{ "nd" }
 - FUNCTION {bbl.rd}{ "rd" }
 - FUNCTION {bbl.th}{ "th" }
 - 
 - 
 - % This is the LaTeX spacer that is used when a larger than normal space
 - % is called for (such as just before the address:publisher).
 - FUNCTION {large.space} { "\hskip 1em plus 0.5em minus 0.4em\relax " }
 - 
 - % The LaTeX code for dashes that are used to represent repeated names.
 - % Note: Some older IEEE journals used something like
 - % "\rule{0.275in}{0.5pt}\," which is fairly thick and runs right along
 - % the baseline. However, IEEE now uses a thinner, above baseline,
 - % six dash long sequence.
 - FUNCTION {repeated.name.dashes} { "------" }
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - %% PREDEFINED STRING MACROS %%
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - MACRO {jan} {"Jan."}
 - MACRO {feb} {"Feb."}
 - MACRO {mar} {"Mar."}
 - MACRO {apr} {"Apr."}
 - MACRO {may} {"May"}
 - MACRO {jun} {"Jun."}
 - MACRO {jul} {"Jul."}
 - MACRO {aug} {"Aug."}
 - MACRO {sep} {"Sep."}
 - MACRO {oct} {"Oct."}
 - MACRO {nov} {"Nov."}
 - MACRO {dec} {"Dec."}
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%
 - %% ENTRY FIELDS %%
 - %%%%%%%%%%%%%%%%%%
 - 
 - ENTRY
 -   { address
 -     assignee
 -     author
 -     booktitle
 -     chapter
 -     day
 -     dayfiled
 -     edition
 -     editor
 -     howpublished
 -     institution
 -     intype
 -     journal
 -     key
 -     language
 -     month
 -     monthfiled
 -     nationality
 -     note
 -     number
 -     organization
 -     pages
 -     paper
 -     publisher
 -     school
 -     series
 -     revision
 -     title
 -     type
 -     url
 -     volume
 -     year
 -     yearfiled
 -     CTLuse_article_number
 -     CTLuse_paper
 -     CTLuse_forced_etal
 -     CTLmax_names_forced_etal
 -     CTLnames_show_etal
 -     CTLuse_alt_spacing
 -     CTLalt_stretch_factor
 -     CTLdash_repeated_names
 -     CTLname_format_string
 -     CTLname_latex_cmd
 -     CTLname_url_prefix
 -   }
 -   {}
 -   { label }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%
 - %% INTEGER VARIABLES %%
 - %%%%%%%%%%%%%%%%%%%%%%%
 - 
 - INTEGERS { prev.status.punct this.status.punct punct.std
 -            punct.no punct.comma punct.period 
 -            prev.status.space this.status.space space.std
 -            space.no space.normal space.large
 -            prev.status.quote this.status.quote quote.std
 -            quote.no quote.close
 -            prev.status.nline this.status.nline nline.std
 -            nline.no nline.newblock 
 -            status.cap cap.std
 -            cap.no cap.yes}
 - 
 - INTEGERS { longest.label.width multiresult nameptr namesleft number.label numnames }
 - 
 - INTEGERS { is.use.number.for.article
 -            is.use.paper
 -            is.forced.et.al
 -            max.num.names.before.forced.et.al
 -            num.names.shown.with.forced.et.al
 -            is.use.alt.interword.spacing
 -            is.dash.repeated.names}
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%
 - %% STRING VARIABLES %%
 - %%%%%%%%%%%%%%%%%%%%%%
 - 
 - STRINGS { bibinfo
 -           longest.label
 -           oldname
 -           s
 -           t
 -           ALTinterwordstretchfactor
 -           name.format.string
 -           name.latex.cmd
 -           name.url.prefix}
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%%
 - %% LOW LEVEL FUNCTIONS %%
 - %%%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - FUNCTION {initialize.controls}
 - { default.is.use.number.for.article 'is.use.number.for.article :=
 -   default.is.use.paper 'is.use.paper :=
 -   default.is.forced.et.al 'is.forced.et.al :=
 -   default.max.num.names.before.forced.et.al 'max.num.names.before.forced.et.al :=
 -   default.num.names.shown.with.forced.et.al 'num.names.shown.with.forced.et.al :=
 -   default.is.use.alt.interword.spacing 'is.use.alt.interword.spacing :=
 -   default.is.dash.repeated.names 'is.dash.repeated.names :=
 -   default.ALTinterwordstretchfactor 'ALTinterwordstretchfactor :=
 -   default.name.format.string 'name.format.string :=
 -   default.name.latex.cmd 'name.latex.cmd :=
 -   default.name.url.prefix 'name.url.prefix :=
 - }
 - 
 - 
 - % This IEEEtran.bst features a very powerful and flexible mechanism for
 - % controlling the capitalization, punctuation, spacing, quotation, and
 - % newlines of the formatted entry fields. (Note: IEEEtran.bst does not need
 - % or use the newline/newblock feature, but it has been implemented for
 - % possible future use.) The output states of IEEEtran.bst consist of
 - % multiple independent attributes and, as such, can be thought of as being
 - % vectors, rather than the simple scalar values ("before.all", 
 - % "mid.sentence", etc.) used in most other .bst files.
 - % 
 - % The more flexible and complex design used here was motivated in part by
 - % IEEE's rather unusual bibliography style. For example, IEEE ends the
 - % previous field item with a period and large space prior to the publisher
 - % address; the @electronic entry types use periods as inter-item punctuation
 - % rather than the commas used by the other entry types; and URLs are never
 - % followed by periods even though they are the last item in the entry.
 - % Although it is possible to accommodate these features with the conventional
 - % output state system, the seemingly endless exceptions make for convoluted,
 - % unreliable and difficult to maintain code.
 - %
 - % IEEEtran.bst's output state system can be easily understood via a simple
 - % illustration of two most recently formatted entry fields (on the stack):
 - %
 - %               CURRENT_ITEM
 - %               "PREVIOUS_ITEM
 - %
 - % which, in this example, is to eventually appear in the bibliography as:
 - % 
 - %               "PREVIOUS_ITEM," CURRENT_ITEM
 - %
 - % It is the job of the output routine to take the previous item off of the
 - % stack (while leaving the current item at the top of the stack), apply its
 - % trailing punctuation (including closing quote marks) and spacing, and then
 - % to write the result to BibTeX's output buffer:
 - % 
 - %               "PREVIOUS_ITEM," 
 - % 
 - % Punctuation (and spacing) between items is often determined by both of the
 - % items rather than just the first one. The presence of quotation marks
 - % further complicates the situation because, in standard English, trailing
 - % punctuation marks are supposed to be contained within the quotes.
 - % 
 - % IEEEtran.bst maintains two output state (aka "status") vectors which
 - % correspond to the previous and current (aka "this") items. Each vector
 - % consists of several independent attributes which track punctuation,
 - % spacing, quotation, and newlines. Capitalization status is handled by a
 - % separate scalar because the format routines, not the output routine,
 - % handle capitalization and, therefore, there is no need to maintain the
 - % capitalization attribute for both the "previous" and "this" items.
 - % 
 - % When a format routine adds a new item, it copies the current output status
 - % vector to the previous output status vector and (usually) resets the
 - % current (this) output status vector to a "standard status" vector. Using a
 - % "standard status" vector in this way allows us to redefine what we mean by
 - % "standard status" at the start of each entry handler and reuse the same
 - % format routines under the various inter-item separation schemes. For
 - % example, the standard status vector for the @book entry type may use
 - % commas for item separators, while the @electronic type may use periods,
 - % yet both entry handlers exploit many of the exact same format routines.
 - % 
 - % Because format routines have write access to the output status vector of
 - % the previous item, they can override the punctuation choices of the
 - % previous format routine! Therefore, it becomes trivial to implement rules
 - % such as "Always use a period and a large space before the publisher." By
 - % pushing the generation of the closing quote mark to the output routine, we
 - % avoid all the problems caused by having to close a quote before having all
 - % the information required to determine what the punctuation should be.
 - %
 - % The IEEEtran.bst output state system can easily be expanded if needed.
 - % For instance, it is easy to add a "space.tie" attribute value if the
 - % bibliography rules mandate that two items have to be joined with an
 - % unbreakable space. 
 - 
 - FUNCTION {initialize.status.constants}
 - { #0 'punct.no :=
 -   #1 'punct.comma :=
 -   #2 'punct.period :=
 -   #0 'space.no := 
 -   #1 'space.normal :=
 -   #2 'space.large :=
 -   #0 'quote.no :=
 -   #1 'quote.close :=
 -   #0 'cap.no :=
 -   #1 'cap.yes :=
 -   #0 'nline.no :=
 -   #1 'nline.newblock :=
 - }
 - 
 - FUNCTION {std.status.using.comma}
 - { punct.comma 'punct.std :=
 -   space.normal 'space.std :=
 -   quote.no 'quote.std :=
 -   nline.no 'nline.std :=
 -   cap.no 'cap.std :=
 - }
 - 
 - FUNCTION {std.status.using.period}
 - { punct.period 'punct.std :=
 -   space.normal 'space.std :=
 -   quote.no 'quote.std :=
 -   nline.no 'nline.std :=
 -   cap.yes 'cap.std :=
 - }
 - 
 - FUNCTION {initialize.prev.this.status}
 - { punct.no 'prev.status.punct :=
 -   space.no 'prev.status.space :=
 -   quote.no 'prev.status.quote :=
 -   nline.no 'prev.status.nline :=
 -   punct.no 'this.status.punct :=
 -   space.no 'this.status.space :=
 -   quote.no 'this.status.quote :=
 -   nline.no 'this.status.nline :=
 -   cap.yes 'status.cap :=
 - }
 - 
 - FUNCTION {this.status.std}
 - { punct.std 'this.status.punct :=
 -   space.std 'this.status.space :=
 -   quote.std 'this.status.quote :=
 -   nline.std 'this.status.nline :=
 - }
 - 
 - FUNCTION {cap.status.std}{ cap.std 'status.cap := }
 - 
 - FUNCTION {this.to.prev.status}
 - { this.status.punct 'prev.status.punct :=
 -   this.status.space 'prev.status.space :=
 -   this.status.quote 'prev.status.quote :=
 -   this.status.nline 'prev.status.nline :=
 - }
 - 
 - 
 - FUNCTION {not}
 - {   { #0 }
 -     { #1 }
 -   if$
 - }
 - 
 - FUNCTION {and}
 - {   { skip$ }
 -     { pop$ #0 }
 -   if$
 - }
 - 
 - FUNCTION {or}
 - {   { pop$ #1 }
 -     { skip$ }
 -   if$
 - }
 - 
 - 
 - % convert the strings "yes" or "no" to #1 or #0 respectively
 - FUNCTION {yes.no.to.int}
 - { "l" change.case$ duplicate$
 -     "yes" =
 -     { pop$  #1 }
 -     { duplicate$ "no" =
 -         { pop$ #0 }
 -         { "unknown boolean " quote$ * swap$ * quote$ *
 -           " in " * cite$ * warning$
 -           #0
 -         }
 -       if$
 -     }
 -   if$
 - }
 - 
 - 
 - % pushes true if the single char string on the stack is in the
 - % range of "0" to "9"
 - FUNCTION {is.num}
 - { chr.to.int$
 -   duplicate$ "0" chr.to.int$ < not
 -   swap$ "9" chr.to.int$ > not and
 - }
 - 
 - % multiplies the integer on the stack by a factor of 10
 - FUNCTION {bump.int.mag}
 - { #0 'multiresult :=
 -     { duplicate$ #0 > }
 -     { #1 -
 -       multiresult #10 +
 -       'multiresult :=
 -     }
 -   while$
 - pop$
 - multiresult
 - }
 - 
 - % converts a single character string on the stack to an integer
 - FUNCTION {char.to.integer}
 - { duplicate$ 
 -   is.num
 -     { chr.to.int$ "0" chr.to.int$ - }
 -     {"noninteger character " quote$ * swap$ * quote$ *
 -           " in integer field of " * cite$ * warning$
 -     #0
 -     }
 -   if$
 - }
 - 
 - % converts a string on the stack to an integer
 - FUNCTION {string.to.integer}
 - { duplicate$ text.length$ 'namesleft :=
 -   #1 'nameptr :=
 -   #0 'numnames :=
 -     { nameptr namesleft > not }
 -     { duplicate$ nameptr #1 substring$
 -       char.to.integer numnames bump.int.mag +
 -       'numnames :=
 -       nameptr #1 +
 -       'nameptr :=
 -     }
 -   while$
 - pop$
 - numnames
 - }
 - 
 - 
 - 
 - 
 - % The output routines write out the *next* to the top (previous) item on the
 - % stack, adding punctuation and such as needed. Since IEEEtran.bst maintains
 - % the output status for the top two items on the stack, these output
 - % routines have to consider the previous output status (which corresponds to
 - % the item that is being output). Full independent control of punctuation,
 - % closing quote marks, spacing, and newblock is provided.
 - % 
 - % "output.nonnull" does not check for the presence of a previous empty
 - % item.
 - % 
 - % "output" does check for the presence of a previous empty item and will
 - % remove an empty item rather than outputing it.
 - % 
 - % "output.warn" is like "output", but will issue a warning if it detects
 - % an empty item.
 - 
 - FUNCTION {output.nonnull}
 - { swap$
 -   prev.status.punct punct.comma =
 -      { "," * }
 -      { skip$ }
 -    if$
 -   prev.status.punct punct.period =
 -      { add.period$ }
 -      { skip$ }
 -    if$ 
 -   prev.status.quote quote.close =
 -      { "''" * }
 -      { skip$ }
 -    if$
 -   prev.status.space space.normal =
 -      { " " * }
 -      { skip$ }
 -    if$
 -   prev.status.space space.large =
 -      { large.space * }
 -      { skip$ }
 -    if$
 -   write$
 -   prev.status.nline nline.newblock =
 -      { newline$ "\newblock " write$ }
 -      { skip$ }
 -    if$
 - }
 - 
 - FUNCTION {output}
 - { duplicate$ empty$
 -     'pop$
 -     'output.nonnull
 -   if$
 - }
 - 
 - FUNCTION {output.warn}
 - { 't :=
 -   duplicate$ empty$
 -     { pop$ "empty " t * " in " * cite$ * warning$ }
 -     'output.nonnull
 -   if$
 - }
 - 
 - % "fin.entry" is the output routine that handles the last item of the entry
 - % (which will be on the top of the stack when "fin.entry" is called).
 - 
 - FUNCTION {fin.entry}
 - { this.status.punct punct.no =
 -      { skip$ }
 -      { add.period$ }
 -    if$
 -    this.status.quote quote.close =
 -      { "''" * }
 -      { skip$ }
 -    if$
 - write$
 - newline$
 - }
 - 
 - 
 - FUNCTION {is.last.char.not.punct}
 - { duplicate$
 -    "}" * add.period$
 -    #-1 #1 substring$ "." =
 - }
 - 
 - FUNCTION {is.multiple.pages}
 - { 't :=
 -   #0 'multiresult :=
 -     { multiresult not
 -       t empty$ not
 -       and
 -     }
 -     { t #1 #1 substring$
 -       duplicate$ "-" =
 -       swap$ duplicate$ "," =
 -       swap$ "+" =
 -       or or
 -         { #1 'multiresult := }
 -         { t #2 global.max$ substring$ 't := }
 -       if$
 -     }
 -   while$
 -   multiresult
 - }
 - 
 - FUNCTION {capitalize}{ "u" change.case$ "t" change.case$ }
 - 
 - FUNCTION {emphasize}
 - { duplicate$ empty$
 -     { pop$ "" }
 -     { "\emph{" swap$ * "}" * }
 -   if$
 - }
 - 
 - FUNCTION {do.name.latex.cmd}
 - { name.latex.cmd
 -   empty$
 -     { skip$ }
 -     { name.latex.cmd "{" * swap$ * "}" * }
 -   if$
 - }
 - 
 - % IEEEtran.bst uses its own \BIBforeignlanguage command which directly
 - % invokes the TeX hyphenation patterns without the need of the Babel
 - % package. Babel does a lot more than switch hyphenation patterns and
 - % its loading can cause unintended effects in many class files (such as
 - % IEEEtran.cls).
 - FUNCTION {select.language}
 - { duplicate$ empty$ 'pop$
 -     { language empty$ 'skip$
 -         { "\BIBforeignlanguage{" language * "}{" * swap$ * "}" * }
 -       if$
 -     }
 -   if$
 - }
 - 
 - FUNCTION {tie.or.space.prefix}
 - { duplicate$ text.length$ #3 <
 -     { "~" }
 -     { " " }
 -   if$
 -   swap$
 - }
 - 
 - FUNCTION {get.bbl.editor}
 - { editor num.names$ #1 > 'bbl.editors 'bbl.editor if$ }
 - 
 - FUNCTION {space.word}{ " " swap$ * " " * }
 - 
 - 
 - % Field Conditioners, Converters, Checkers and External Interfaces
 - 
 - FUNCTION {empty.field.to.null.string}
 - { duplicate$ empty$
 -     { pop$ "" }
 -     { skip$ }
 -   if$
 - }
 - 
 - FUNCTION {either.or.check}
 - { empty$
 -     { pop$ }
 -     { "can't use both " swap$ * " fields in " * cite$ * warning$ }
 -   if$
 - }
 - 
 - FUNCTION {empty.entry.warn}
 - { author empty$ title empty$ howpublished empty$
 -   month empty$ year empty$ note empty$ url empty$
 -   and and and and and and
 -     { "all relevant fields are empty in " cite$ * warning$ }
 -     'skip$
 -   if$
 - }
 - 
 - 
 - % The bibinfo system provides a way for the electronic parsing/acquisition
 - % of a bibliography's contents as is done by ReVTeX. For example, a field
 - % could be entered into the bibliography as:
 - % \bibinfo{volume}{2}
 - % Only the "2" would show up in the document, but the LaTeX \bibinfo command
 - % could do additional things with the information. IEEEtran.bst does provide
 - % a \bibinfo command via "\providecommand{\bibinfo}[2]{#2}". However, it is
 - % currently not used as the bogus bibinfo functions defined here output the
 - % entry values directly without the \bibinfo wrapper. The bibinfo functions
 - % themselves (and the calls to them) are retained for possible future use.
 - % 
 - % bibinfo.check avoids acting on missing fields while bibinfo.warn will
 - % issue a warning message if a missing field is detected. Prior to calling
 - % the bibinfo functions, the user should push the field value and then its
 - % name string, in that order.
 - 
 - FUNCTION {bibinfo.check}
 - { swap$ duplicate$ missing$
 -     { pop$ pop$ "" }
 -     { duplicate$ empty$
 -         { swap$ pop$ }
 -         { swap$ pop$ }
 -       if$
 -     }
 -   if$
 - }
 - 
 - FUNCTION {bibinfo.warn}
 - { swap$ duplicate$ missing$
 -     { swap$ "missing " swap$ * " in " * cite$ * warning$ pop$ "" }
 -     { duplicate$ empty$
 -         { swap$ "empty " swap$ * " in " * cite$ * warning$ }
 -         { swap$ pop$ }
 -       if$
 -     }
 -   if$
 - }
 - 
 - 
 - % IEEE separates large numbers with more than 4 digits into groups of
 - % three. IEEE uses a small space to separate these number groups. 
 - % Typical applications include patent and page numbers.
 - 
 - % number of consecutive digits required to trigger the group separation.
 - FUNCTION {large.number.trigger}{ #5 }
 - 
 - % For numbers longer than the trigger, this is the blocksize of the groups.
 - % The blocksize must be less than the trigger threshold, and 2 * blocksize
 - % must be greater than the trigger threshold (can't do more than one
 - % separation on the initial trigger).
 - FUNCTION {large.number.blocksize}{ #3 }
 - 
 - % What is actually inserted between the number groups.
 - FUNCTION {large.number.separator}{ "\," }
 - 
 - % So as to save on integer variables by reusing existing ones, numnames
 - % holds the current number of consecutive digits read and nameptr holds
 - % the number that will trigger an inserted space.
 - FUNCTION {large.number.separate}
 - { 't :=
 -   ""
 -   #0 'numnames :=
 -   large.number.trigger 'nameptr :=
 -   { t empty$ not }
 -   { t #-1 #1 substring$ is.num
 -       { numnames #1 + 'numnames := }
 -       { #0 'numnames := 
 -         large.number.trigger 'nameptr :=
 -       }
 -     if$
 -     t #-1 #1 substring$ swap$ *
 -     t #-2 global.max$ substring$ 't :=
 -     numnames nameptr =
 -       { duplicate$ #1 nameptr large.number.blocksize - substring$ swap$
 -         nameptr large.number.blocksize - #1 + global.max$ substring$
 -         large.number.separator swap$ * *
 -         nameptr large.number.blocksize - 'numnames :=
 -         large.number.blocksize #1 + 'nameptr :=
 -       }
 -       { skip$ }
 -     if$
 -   }
 -   while$
 - }
 - 
 - % Converts all single dashes "-" to double dashes "--".
 - FUNCTION {n.dashify}
 - { large.number.separate
 -   't :=
 -   ""
 -     { t empty$ 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$
 - }
 - 
 - 
 - % This function detects entries with names that are identical to that of
 - % the previous entry and replaces the repeated names with dashes (if the
 - % "is.dash.repeated.names" user control is nonzero).
 - FUNCTION {name.or.dash}
 - { 's :=
 -    oldname empty$
 -      { s 'oldname := s }
 -      { s oldname =
 -          { is.dash.repeated.names
 -               { repeated.name.dashes }
 -               { s 'oldname := s }
 -             if$
 -          }
 -          { s 'oldname := s }
 -        if$
 -      }
 -    if$
 - }
 - 
 - % Converts the number string on the top of the stack to
 - % "numerical ordinal form" (e.g., "7" to "7th"). There is
 - % no artificial limit to the upper bound of the numbers as the
 - % two least significant digits determine the ordinal form.
 - FUNCTION {num.to.ordinal}
 - { duplicate$ #-2 #1 substring$ "1" =
 -       { bbl.th * }
 -       { duplicate$ #-1 #1 substring$ "1" =
 -           { bbl.st * }
 -           { duplicate$ #-1 #1 substring$ "2" =
 -               { bbl.nd * }
 -               { duplicate$ #-1 #1 substring$ "3" =
 -                   { bbl.rd * }
 -                   { bbl.th * }
 -                 if$
 -               }
 -             if$
 -           }
 -         if$
 -       }
 -     if$
 - }
 - 
 - % If the string on the top of the stack begins with a number,
 - % (e.g., 11th) then replace the string with the leading number
 - % it contains. Otherwise retain the string as-is. s holds the
 - % extracted number, t holds the part of the string that remains
 - % to be scanned.
 - FUNCTION {extract.num}
 - { duplicate$ 't :=
 -   "" 's :=
 -   { t empty$ not }
 -   { t #1 #1 substring$
 -     t #2 global.max$ substring$ 't :=
 -     duplicate$ is.num
 -       { s swap$ * 's := }
 -       { pop$ "" 't := }
 -     if$
 -   }
 -   while$
 -   s empty$
 -     'skip$
 -     { pop$ s }
 -   if$
 - }
 - 
 - % Converts the word number string on the top of the stack to
 - % Arabic string form. Will be successful up to "tenth".
 - FUNCTION {word.to.num}
 - { duplicate$ "l" change.case$ 's :=
 -   s "first" =
 -     { pop$ "1" }
 -     { skip$ }
 -   if$
 -   s "second" =
 -     { pop$ "2" }
 -     { skip$ }
 -   if$
 -   s "third" =
 -     { pop$ "3" }
 -     { skip$ }
 -   if$
 -   s "fourth" =
 -     { pop$ "4" }
 -     { skip$ }
 -   if$
 -   s "fifth" =
 -     { pop$ "5" }
 -     { skip$ }
 -   if$
 -   s "sixth" =
 -     { pop$ "6" }
 -     { skip$ }
 -   if$
 -   s "seventh" =
 -     { pop$ "7" }
 -     { skip$ }
 -   if$
 -   s "eighth" =
 -     { pop$ "8" }
 -     { skip$ }
 -   if$
 -   s "ninth" =
 -     { pop$ "9" }
 -     { skip$ }
 -   if$
 -   s "tenth" =
 -     { pop$ "10" }
 -     { skip$ }
 -   if$
 - }
 - 
 - 
 - % Converts the string on the top of the stack to numerical
 - % ordinal (e.g., "11th") form.
 - FUNCTION {convert.edition}
 - { duplicate$ empty$ 'skip$
 -     { duplicate$ #1 #1 substring$ is.num
 -         { extract.num
 -           num.to.ordinal
 -         }
 -         { word.to.num
 -           duplicate$ #1 #1 substring$ is.num
 -             { num.to.ordinal }
 -             { "edition ordinal word " quote$ * edition * quote$ *
 -               " may be too high (or improper) for conversion" * " in " * cite$ * warning$
 -             }
 -           if$
 -         }
 -       if$
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - %% LATEX BIBLIOGRAPHY CODE %%
 - %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - FUNCTION {start.entry}
 - { newline$
 -   "\bibitem{" write$
 -   cite$ write$
 -   "}" write$
 -   newline$
 -   ""
 -   initialize.prev.this.status
 - }
 - 
 - % Here we write out all the LaTeX code that we will need. The most involved
 - % code sequences are those that control the alternate interword spacing and
 - % foreign language hyphenation patterns. The heavy use of \providecommand
 - % gives users a way to override the defaults. Special thanks to Javier Bezos,
 - % Johannes Braams, Robin Fairbairns, Heiko Oberdiek, Donald Arseneau and all
 - % the other gurus on comp.text.tex for their help and advice on the topic of
 - % \selectlanguage, Babel and BibTeX.
 - FUNCTION {begin.bib}
 - { "% Generated by IEEEtran.bst, version: " bst.file.version * " (" * bst.file.date * ")" *
 -   write$ newline$
 -   preamble$ empty$ 'skip$
 -     { preamble$ write$ newline$ }
 -   if$
 -   "\begin{thebibliography}{"  longest.label  * "}" *
 -   write$ newline$
 -   "\providecommand{\url}[1]{#1}"
 -   write$ newline$
 -   "\csname url@samestyle\endcsname"
 -   write$ newline$
 -   "\providecommand{\newblock}{\relax}"
 -   write$ newline$
 -   "\providecommand{\bibinfo}[2]{#2}"
 -   write$ newline$
 -   "\providecommand{\BIBentrySTDinterwordspacing}{\spaceskip=0pt\relax}"
 -   write$ newline$
 -   "\providecommand{\BIBentryALTinterwordstretchfactor}{"
 -   ALTinterwordstretchfactor * "}" *
 -   write$ newline$
 -   "\providecommand{\BIBentryALTinterwordspacing}{\spaceskip=\fontdimen2\font plus "
 -   write$ newline$
 -   "\BIBentryALTinterwordstretchfactor\fontdimen3\font minus \fontdimen4\font\relax}"
 -   write$ newline$
 -   "\providecommand{\BIBforeignlanguage}[2]{{%"
 -   write$ newline$
 -   "\expandafter\ifx\csname l@#1\endcsname\relax"
 -   write$ newline$
 -   "\typeout{** WARNING: IEEEtran.bst: No hyphenation pattern has been}%"
 -   write$ newline$
 -   "\typeout{** loaded for the language `#1'. Using the pattern for}%"
 -   write$ newline$
 -   "\typeout{** the default language instead.}%"
 -   write$ newline$
 -   "\else"
 -   write$ newline$
 -   "\language=\csname l@#1\endcsname"
 -   write$ newline$
 -   "\fi"
 -   write$ newline$
 -   "#2}}"
 -   write$ newline$
 -   "\providecommand{\BIBdecl}{\relax}"
 -   write$ newline$
 -   "\BIBdecl"
 -   write$ newline$
 - }
 - 
 - FUNCTION {end.bib}
 - { newline$ "\end{thebibliography}" write$ newline$ }
 - 
 - FUNCTION {if.url.alt.interword.spacing}
 - { is.use.alt.interword.spacing 
 -      {url empty$ 'skip$ {"\BIBentryALTinterwordspacing" write$ newline$} if$}
 -      { skip$ }
 -    if$
 - }
 - 
 - FUNCTION {if.url.std.interword.spacing}
 - { is.use.alt.interword.spacing 
 -      {url empty$ 'skip$ {"\BIBentrySTDinterwordspacing" write$ newline$} if$}
 -      { skip$ }
 -    if$
 - }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%%%%
 - %% LONGEST LABEL PASS %%
 - %%%%%%%%%%%%%%%%%%%%%%%%
 - 
 - FUNCTION {initialize.longest.label}
 - { "" 'longest.label :=
 -   #1 'number.label :=
 -   #0 'longest.label.width :=
 - }
 - 
 - FUNCTION {longest.label.pass}
 - { type$ "ieeetranbstctl" =
 -     { skip$ }
 -     { number.label int.to.str$ 'label :=
 -       number.label #1 + 'number.label :=
 -       label width$ longest.label.width >
 -         { label 'longest.label :=
 -           label width$ 'longest.label.width :=
 -         }
 -         { skip$ }
 -       if$
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%%
 - %% FORMAT HANDLERS %%
 - %%%%%%%%%%%%%%%%%%%%%
 - 
 - %% Lower Level Formats (used by higher level formats)
 - 
 - FUNCTION {format.address.org.or.pub.date}
 - { 't :=
 -   ""
 -   year empty$
 -     { "empty year in " cite$ * warning$ }
 -     { skip$ }
 -   if$
 -   address empty$ t empty$ and
 -   year empty$ and month empty$ and
 -     { skip$ }
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -       address "address" bibinfo.check *
 -       t empty$
 -         { skip$ }
 -         { punct.period 'prev.status.punct :=
 -           space.large 'prev.status.space :=
 -           address empty$
 -             { skip$ }
 -             { ": " * }
 -           if$
 -           t *
 -         }
 -       if$
 -       year empty$ month empty$ and
 -         { skip$ }
 -         { t empty$ address empty$ and
 -             { skip$ }
 -             { ", " * }
 -           if$
 -           month empty$
 -             { year empty$
 -                 { skip$ }
 -                 { year "year" bibinfo.check * }
 -               if$
 -             }
 -             { month "month" bibinfo.check *
 -               year empty$
 -                  { skip$ }
 -                  { " " * year "year" bibinfo.check * }
 -               if$
 -             }
 -           if$
 -         }
 -       if$
 -     }
 -   if$
 - }
 - 
 - 
 - FUNCTION {format.names}
 - { 'bibinfo :=
 -   duplicate$ empty$ 'skip$ {
 -   this.to.prev.status
 -   this.status.std
 -   's :=
 -   "" 't :=
 -   #1 'nameptr :=
 -   s num.names$ 'numnames :=
 -   numnames 'namesleft :=
 -     { namesleft #0 > }
 -     { s nameptr
 -       name.format.string
 -       format.name$
 -       bibinfo bibinfo.check
 -       't :=
 -       nameptr #1 >
 -         { nameptr num.names.shown.with.forced.et.al #1 + =
 -           numnames max.num.names.before.forced.et.al >
 -           is.forced.et.al and and
 -             { "others" 't :=
 -               #1 'namesleft :=
 -             }
 -             { skip$ }
 -           if$
 -           namesleft #1 >
 -             { ", " * t do.name.latex.cmd * }
 -             { s nameptr "{ll}" format.name$ duplicate$ "others" =
 -                 { 't := }
 -                 { pop$ }
 -               if$
 -               t "others" =
 -                 { " " * bbl.etal emphasize * }
 -                 { numnames #2 >
 -                     { "," * }
 -                     { skip$ }
 -                   if$
 -                   bbl.and
 -                   space.word * t do.name.latex.cmd *
 -                 }
 -               if$
 -             }
 -           if$
 -         }
 -         { t do.name.latex.cmd }
 -       if$
 -       nameptr #1 + 'nameptr :=
 -       namesleft #1 - 'namesleft :=
 -     }
 -   while$
 -   cap.status.std
 -   } if$
 - }
 - 
 - 
 - 
 - 
 - %% Higher Level Formats
 - 
 - %% addresses/locations
 - 
 - FUNCTION {format.address}
 - { address duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% author/editor names
 - 
 - FUNCTION {format.authors}{ author "author" format.names }
 - 
 - FUNCTION {format.editors}
 - { editor "editor" format.names duplicate$ empty$ 'skip$
 -     { ", " *
 -       get.bbl.editor
 -       capitalize
 -       *
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% date
 - 
 - FUNCTION {format.date}
 - {
 -   month "month" bibinfo.check duplicate$ empty$
 -   year  "year" bibinfo.check duplicate$ empty$
 -     { swap$ 'skip$
 -         { this.to.prev.status
 -           this.status.std
 -           cap.status.std
 -          "there's a month but no year in " cite$ * warning$ }
 -       if$
 -       *
 -     }
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -       swap$ 'skip$
 -         {
 -           swap$
 -           " " * swap$
 -         }
 -       if$
 -       *
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.date.electronic}
 - { month "month" bibinfo.check duplicate$ empty$
 -   year  "year" bibinfo.check duplicate$ empty$
 -     { swap$ 
 -         { pop$ }
 -         { "there's a month but no year in " cite$ * warning$
 -         pop$ ")" * "(" swap$ *
 -         this.to.prev.status
 -         punct.no 'this.status.punct :=
 -         space.normal 'this.status.space :=
 -         quote.no 'this.status.quote :=
 -         cap.yes  'status.cap :=
 -         }
 -       if$
 -     }
 -     { swap$ 
 -         { swap$ pop$ ")" * "(" swap$ * }
 -         { "(" swap$ * ", " * swap$ * ")" * }
 -       if$
 -     this.to.prev.status
 -     punct.no 'this.status.punct :=
 -     space.normal 'this.status.space :=
 -     quote.no 'this.status.quote :=
 -     cap.yes  'status.cap :=
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% edition/title
 - 
 - % Note: IEEE considers the edition to be closely associated with
 - % the title of a book. So, in IEEEtran.bst the edition is normally handled 
 - % within the formatting of the title. The format.edition function is 
 - % retained here for possible future use.
 - FUNCTION {format.edition}
 - { edition duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       convert.edition
 -       status.cap
 -         { "t" }
 -         { "l" }
 -       if$ change.case$
 -       "edition" bibinfo.check
 -       "~" * bbl.edition *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - % This is used to format the booktitle of a conference proceedings.
 - % Here we use the "intype" field to provide the user a way to 
 - % override the word "in" (e.g., with things like "presented at")
 - % Use of intype stops the emphasis of the booktitle to indicate that
 - % we no longer mean the written conference proceedings, but the
 - % conference itself.
 - FUNCTION {format.in.booktitle}
 - { booktitle "booktitle" bibinfo.check duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       select.language
 -       intype missing$
 -         { emphasize
 -           bbl.in " " *
 -         }
 -         { intype " " * }
 -       if$
 -       swap$ *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - % This is used to format the booktitle of collection.
 - % Here the "intype" field is not supported, but "edition" is.
 - FUNCTION {format.in.booktitle.edition}
 - { booktitle "booktitle" bibinfo.check duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       select.language
 -       emphasize
 -       edition empty$ 'skip$
 -         { ", " *
 -           edition
 -           convert.edition
 -           "l" change.case$
 -           * "~" * bbl.edition *
 -         }
 -       if$
 -       bbl.in " " * swap$ *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.article.title}
 - { title duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       "t" change.case$
 -     }
 -   if$
 -   "title" bibinfo.check
 -   duplicate$ empty$ 'skip$
 -     { quote.close 'this.status.quote :=
 -       is.last.char.not.punct
 -         { punct.std 'this.status.punct := }
 -         { punct.no 'this.status.punct := }
 -       if$
 -       select.language
 -       "``" swap$ *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.article.title.electronic}
 - { title duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -       "t" change.case$ 
 -     }
 -   if$
 -   "title" bibinfo.check
 -   duplicate$ empty$ 
 -     { skip$ } 
 -     { select.language }
 -   if$
 - }
 - 
 - FUNCTION {format.book.title.edition}
 - { title "title" bibinfo.check
 -   duplicate$ empty$
 -     { "empty title in " cite$ * warning$ }
 -     { this.to.prev.status
 -       this.status.std
 -       select.language
 -       emphasize
 -       edition empty$ 'skip$
 -         { ", " *
 -           edition
 -           convert.edition
 -           status.cap
 -             { "t" }
 -             { "l" }
 -           if$
 -           change.case$
 -           * "~" * bbl.edition *
 -         }
 -       if$
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.book.title}
 - { title "title" bibinfo.check
 -   duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -       select.language
 -       emphasize
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% journal
 - 
 - FUNCTION {format.journal}
 - { journal duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -       select.language
 -       emphasize
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% how published
 - 
 - FUNCTION {format.howpublished}
 - { howpublished duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% institutions/organization/publishers/school
 - 
 - FUNCTION {format.institution}
 - { institution duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.organization}
 - { organization duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.address.publisher.date}
 - { publisher "publisher" bibinfo.warn format.address.org.or.pub.date }
 - 
 - FUNCTION {format.address.publisher.date.nowarn}
 - { publisher "publisher" bibinfo.check format.address.org.or.pub.date }
 - 
 - FUNCTION {format.address.organization.date}
 - { organization "organization" bibinfo.check format.address.org.or.pub.date }
 - 
 - FUNCTION {format.school}
 - { school duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% volume/number/series/chapter/pages
 - 
 - FUNCTION {format.volume}
 - { volume empty.field.to.null.string
 -   duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       bbl.volume 
 -       status.cap
 -         { capitalize }
 -         { skip$ }
 -       if$
 -       swap$ tie.or.space.prefix
 -       "volume" bibinfo.check
 -       * *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.number}
 - { number empty.field.to.null.string
 -   duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       status.cap
 -          { bbl.number capitalize }
 -          { bbl.number }
 -        if$
 -       swap$ tie.or.space.prefix
 -       "number" bibinfo.check
 -       * *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - FUNCTION {format.number.if.use.for.article}
 - { is.use.number.for.article 
 -      { format.number }
 -      { "" }
 -    if$
 - }
 - 
 - % IEEE does not seem to tie the series so closely with the volume
 - % and number as is done in other bibliography styles. Instead the
 - % series is treated somewhat like an extension of the title.
 - FUNCTION {format.series}
 - { series empty$ 
 -    { "" }
 -    { this.to.prev.status
 -      this.status.std
 -      bbl.series " " *
 -      series "series" bibinfo.check *
 -      cap.status.std
 -    }
 -  if$
 - }
 - 
 - 
 - FUNCTION {format.chapter}
 - { chapter empty$
 -     { "" }
 -     { this.to.prev.status
 -       this.status.std
 -       type empty$
 -         { bbl.chapter }
 -         { type "l" change.case$
 -           "type" bibinfo.check
 -         }
 -       if$
 -       chapter tie.or.space.prefix
 -       "chapter" bibinfo.check
 -       * *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - % The intended use of format.paper is for paper numbers of inproceedings.
 - % The paper type can be overridden via the type field.
 - % We allow the type to be displayed even if the paper number is absent
 - % for things like "postdeadline paper"
 - FUNCTION {format.paper}
 - { is.use.paper
 -      { paper empty$
 -         { type empty$
 -             { "" }
 -             { this.to.prev.status
 -               this.status.std
 -               type "type" bibinfo.check
 -               cap.status.std
 -             }
 -           if$
 -         }
 -         { this.to.prev.status
 -           this.status.std
 -           type empty$
 -             { bbl.paper }
 -             { type "type" bibinfo.check }
 -           if$
 -           " " * paper
 -           "paper" bibinfo.check
 -           *
 -           cap.status.std
 -         }
 -       if$
 -      }
 -      { "" } 
 -    if$
 - }
 - 
 - 
 - FUNCTION {format.pages}
 - { pages duplicate$ empty$ 'skip$
 -     { this.to.prev.status
 -       this.status.std
 -       duplicate$ is.multiple.pages
 -         {
 -           bbl.pages swap$
 -           n.dashify
 -         }
 -         {
 -           bbl.page swap$
 -         }
 -       if$
 -       tie.or.space.prefix
 -       "pages" bibinfo.check
 -       * *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% technical report number
 - 
 - FUNCTION {format.tech.report.number}
 - { number "number" bibinfo.check
 -   this.to.prev.status
 -   this.status.std
 -   cap.status.std
 -   type duplicate$ empty$
 -     { pop$ 
 -       bbl.techrep
 -     }
 -     { skip$ }
 -   if$
 -   "type" bibinfo.check 
 -   swap$ duplicate$ empty$
 -     { pop$ }
 -     { tie.or.space.prefix * * }
 -   if$
 - }
 - 
 - 
 - 
 - %% note
 - 
 - FUNCTION {format.note}
 - { note empty$
 -     { "" }
 -     { this.to.prev.status
 -       this.status.std
 -       punct.period 'this.status.punct :=
 -       note #1 #1 substring$
 -       duplicate$ "{" =
 -         { skip$ }
 -         { status.cap
 -           { "u" }
 -           { "l" }
 -         if$
 -         change.case$
 -         }
 -       if$
 -       note #2 global.max$ substring$ * "note" bibinfo.check
 -       cap.yes  'status.cap :=
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - %% patent
 - 
 - FUNCTION {format.patent.date}
 - { this.to.prev.status
 -   this.status.std
 -   year empty$
 -     { monthfiled duplicate$ empty$
 -         { "monthfiled" bibinfo.check pop$ "" }
 -         { "monthfiled" bibinfo.check }
 -       if$
 -       dayfiled duplicate$ empty$
 -         { "dayfiled" bibinfo.check pop$ "" * }
 -         { "dayfiled" bibinfo.check 
 -           monthfiled empty$ 
 -              { "dayfiled without a monthfiled in " cite$ * warning$
 -                * 
 -              }
 -              { " " swap$ * * }
 -            if$
 -         }
 -       if$
 -       yearfiled empty$
 -         { "no year or yearfiled in " cite$ * warning$ }
 -         { yearfiled "yearfiled" bibinfo.check 
 -           swap$
 -           duplicate$ empty$
 -              { pop$ }
 -              { ", " * swap$ * }
 -            if$
 -         }
 -       if$
 -     }
 -     { month duplicate$ empty$
 -         { "month" bibinfo.check pop$ "" }
 -         { "month" bibinfo.check }
 -       if$
 -       day duplicate$ empty$
 -         { "day" bibinfo.check pop$ "" * }
 -         { "day" bibinfo.check 
 -           month empty$ 
 -              { "day without a month in " cite$ * warning$
 -                * 
 -              }
 -              { " " swap$ * * }
 -            if$
 -         }
 -       if$
 -       year "year" bibinfo.check 
 -       swap$
 -       duplicate$ empty$
 -         { pop$ }
 -         { ", " * swap$ * }
 -       if$
 -     }
 -   if$
 -   cap.status.std
 - }
 - 
 - FUNCTION {format.patent.nationality.type.number}
 - { this.to.prev.status
 -   this.status.std
 -   nationality duplicate$ empty$
 -     { "nationality" bibinfo.warn pop$ "" }
 -     { "nationality" bibinfo.check
 -       duplicate$ "l" change.case$ "united states" =
 -         { pop$ bbl.patentUS }
 -         { skip$ }
 -       if$
 -       " " *
 -     }
 -   if$
 -   type empty$
 -     { bbl.patent "type" bibinfo.check }
 -     { type "type" bibinfo.check }
 -   if$  
 -   *
 -   number duplicate$ empty$
 -     { "number" bibinfo.warn pop$ }
 -     { "number" bibinfo.check
 -       large.number.separate
 -       swap$ " " * swap$ *
 -     }
 -   if$ 
 -   cap.status.std
 - }
 - 
 - 
 - 
 - %% standard
 - 
 - FUNCTION {format.organization.institution.standard.type.number}
 - { this.to.prev.status
 -   this.status.std
 -   organization duplicate$ empty$
 -     { pop$ 
 -       institution duplicate$ empty$
 -         { "institution" bibinfo.warn }
 -         { "institution" bibinfo.warn " " * }
 -       if$
 -     }
 -     { "organization" bibinfo.warn " " * }
 -   if$
 -   type empty$
 -     { bbl.standard "type" bibinfo.check }
 -     { type "type" bibinfo.check }
 -   if$  
 -   *
 -   number duplicate$ empty$
 -     { "number" bibinfo.check pop$ }
 -     { "number" bibinfo.check
 -       large.number.separate
 -       swap$ " " * swap$ *
 -     }
 -   if$ 
 -   cap.status.std
 - }
 - 
 - FUNCTION {format.revision}
 - { revision empty$
 -     { "" }
 -     { this.to.prev.status
 -       this.status.std
 -       bbl.revision
 -       revision tie.or.space.prefix
 -       "revision" bibinfo.check
 -       * *
 -       cap.status.std
 -     }
 -   if$
 - }
 - 
 - 
 - %% thesis
 - 
 - FUNCTION {format.master.thesis.type}
 - { this.to.prev.status
 -   this.status.std
 -   type empty$
 -     {
 -       bbl.mthesis
 -     }
 -     { 
 -       type "type" bibinfo.check
 -     }
 -   if$
 - cap.status.std
 - }
 - 
 - FUNCTION {format.phd.thesis.type}
 - { this.to.prev.status
 -   this.status.std
 -   type empty$
 -     {
 -       bbl.phdthesis
 -     }
 -     { 
 -       type "type" bibinfo.check
 -     }
 -   if$
 - cap.status.std
 - }
 - 
 - 
 - 
 - %% URL
 - 
 - FUNCTION {format.url}
 - { url empty$
 -     { "" }
 -     { this.to.prev.status
 -       this.status.std
 -       cap.yes 'status.cap :=
 -       name.url.prefix " " *
 -       "\url{" * url * "}" *
 -       punct.no 'this.status.punct :=
 -       punct.period 'prev.status.punct :=
 -       space.normal 'this.status.space :=
 -       space.normal 'prev.status.space :=
 -       quote.no 'this.status.quote :=
 -     }
 -   if$
 - }
 - 
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%%
 - %% ENTRY HANDLERS %%
 - %%%%%%%%%%%%%%%%%%%%
 - 
 - 
 - % Note: In many journals, IEEE (or the authors) tend not to show the number
 - % for articles, so the display of the number is controlled here by the
 - % switch "is.use.number.for.article"
 - FUNCTION {article}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.journal "journal" bibinfo.check "journal" output.warn
 -   format.volume output
 -   format.number.if.use.for.article output
 -   format.pages output
 -   format.date "year" output.warn
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {book}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   author empty$
 -     { format.editors "author and editor" output.warn }
 -     { format.authors output.nonnull }
 -   if$
 -   name.or.dash
 -   format.book.title.edition output
 -   format.series output
 -   author empty$
 -     { skip$ }
 -     { format.editors output }
 -   if$
 -   format.address.publisher.date output
 -   format.volume output
 -   format.number output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {booklet}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.howpublished "howpublished" bibinfo.check output
 -   format.organization "organization" bibinfo.check output
 -   format.address "address" bibinfo.check output
 -   format.date output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {electronic}
 - { std.status.using.period
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.date.electronic output
 -   format.article.title.electronic output
 -   format.howpublished "howpublished" bibinfo.check output
 -   format.organization "organization" bibinfo.check output
 -   format.address "address" bibinfo.check output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   empty.entry.warn
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {inbook}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   author empty$
 -     { format.editors "author and editor" output.warn }
 -     { format.authors output.nonnull }
 -   if$
 -   name.or.dash
 -   format.book.title.edition output
 -   format.series output
 -   format.address.publisher.date output
 -   format.volume output
 -   format.number output
 -   format.chapter output
 -   format.pages output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {incollection}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.in.booktitle.edition "booktitle" output.warn
 -   format.series output
 -   format.editors output
 -   format.address.publisher.date.nowarn output
 -   format.volume output
 -   format.number output
 -   format.chapter output
 -   format.pages output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {inproceedings}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.in.booktitle "booktitle" output.warn
 -   format.series output
 -   format.editors output
 -   format.volume output
 -   format.number output
 -   publisher empty$
 -     { format.address.organization.date output }
 -     { format.organization "organization" bibinfo.check output
 -       format.address.publisher.date output
 -     }
 -   if$
 -   format.paper output
 -   format.pages output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {manual}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.book.title.edition "title" output.warn
 -   format.howpublished "howpublished" bibinfo.check output 
 -   format.organization "organization" bibinfo.check output
 -   format.address "address" bibinfo.check output
 -   format.date output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {mastersthesis}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.master.thesis.type output.nonnull
 -   format.school "school" bibinfo.warn output
 -   format.address "address" bibinfo.check output
 -   format.date "year" output.warn
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {misc}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.article.title output
 -   format.howpublished "howpublished" bibinfo.check output 
 -   format.organization "organization" bibinfo.check output
 -   format.address "address" bibinfo.check output
 -   format.pages output
 -   format.date output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   empty.entry.warn
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {patent}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.article.title output
 -   format.patent.nationality.type.number output
 -   format.patent.date output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   empty.entry.warn
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {periodical}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.editors output
 -   name.or.dash
 -   format.book.title "title" output.warn
 -   format.series output
 -   format.volume output
 -   format.number output
 -   format.organization "organization" bibinfo.check output
 -   format.date "year" output.warn
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {phdthesis}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.phd.thesis.type output.nonnull
 -   format.school "school" bibinfo.warn output
 -   format.address "address" bibinfo.check output
 -   format.date "year" output.warn
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {proceedings}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.editors output
 -   name.or.dash
 -   format.book.title "title" output.warn
 -   format.series output
 -   format.volume output
 -   format.number output
 -   publisher empty$
 -     { format.address.organization.date output }
 -     { format.organization "organization" bibinfo.check output
 -       format.address.publisher.date output
 -     }
 -   if$
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {standard}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors output
 -   name.or.dash
 -   format.book.title "title" output.warn
 -   format.howpublished "howpublished" bibinfo.check output 
 -   format.organization.institution.standard.type.number output
 -   format.revision output
 -   format.date output
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {techreport}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.howpublished "howpublished" bibinfo.check output 
 -   format.institution "institution" bibinfo.warn output
 -   format.address "address" bibinfo.check output
 -   format.tech.report.number output.nonnull
 -   format.date "year" output.warn
 -   format.note output
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - FUNCTION {unpublished}
 - { std.status.using.comma
 -   start.entry
 -   if.url.alt.interword.spacing
 -   format.authors "author" output.warn
 -   name.or.dash
 -   format.article.title "title" output.warn
 -   format.date output
 -   format.note "note" output.warn
 -   format.url output
 -   fin.entry
 -   if.url.std.interword.spacing
 - }
 - 
 - 
 - % The special entry type which provides the user interface to the
 - % BST controls
 - FUNCTION {IEEEtranBSTCTL}
 - { is.print.banners.to.terminal
 -     { "** IEEEtran BST control entry " quote$ * cite$ * quote$ * " detected." *
 -       top$
 -     }
 -     { skip$ }
 -   if$
 -   CTLuse_article_number
 -   empty$
 -     { skip$ }
 -     { CTLuse_article_number
 -       yes.no.to.int
 -       'is.use.number.for.article :=
 -     }
 -   if$
 -   CTLuse_paper
 -   empty$
 -     { skip$ }
 -     { CTLuse_paper
 -       yes.no.to.int
 -       'is.use.paper :=
 -     }
 -   if$
 -   CTLuse_forced_etal
 -   empty$
 -     { skip$ }
 -     { CTLuse_forced_etal
 -       yes.no.to.int
 -       'is.forced.et.al :=
 -     }
 -   if$
 -   CTLmax_names_forced_etal
 -   empty$
 -     { skip$ }
 -     { CTLmax_names_forced_etal
 -       string.to.integer
 -       'max.num.names.before.forced.et.al :=
 -     }
 -   if$
 -   CTLnames_show_etal
 -   empty$
 -     { skip$ }
 -     { CTLnames_show_etal
 -       string.to.integer
 -       'num.names.shown.with.forced.et.al :=
 -     }
 -   if$
 -   CTLuse_alt_spacing
 -   empty$
 -     { skip$ }
 -     { CTLuse_alt_spacing
 -       yes.no.to.int
 -       'is.use.alt.interword.spacing :=
 -     }
 -   if$
 -   CTLalt_stretch_factor
 -   empty$
 -     { skip$ }
 -     { CTLalt_stretch_factor
 -       'ALTinterwordstretchfactor :=
 -       "\renewcommand{\BIBentryALTinterwordstretchfactor}{"
 -       ALTinterwordstretchfactor * "}" *
 -       write$ newline$
 -     }
 -   if$
 -   CTLdash_repeated_names
 -   empty$
 -     { skip$ }
 -     { CTLdash_repeated_names
 -       yes.no.to.int
 -       'is.dash.repeated.names :=
 -     }
 -   if$
 -   CTLname_format_string
 -   empty$
 -     { skip$ }
 -     { CTLname_format_string
 -       'name.format.string :=
 -     }
 -   if$
 -   CTLname_latex_cmd
 -   empty$
 -     { skip$ }
 -     { CTLname_latex_cmd
 -       'name.latex.cmd :=
 -     }
 -   if$
 -   CTLname_url_prefix
 -   missing$
 -     { skip$ }
 -     { CTLname_url_prefix
 -       'name.url.prefix :=
 -     }
 -   if$
 - 
 - 
 -   num.names.shown.with.forced.et.al max.num.names.before.forced.et.al >
 -     { "CTLnames_show_etal cannot be greater than CTLmax_names_forced_etal in " cite$ * warning$ 
 -       max.num.names.before.forced.et.al 'num.names.shown.with.forced.et.al :=
 -     }
 -     { skip$ }
 -   if$
 - }
 - 
 - 
 - %%%%%%%%%%%%%%%%%%%
 - %% ENTRY ALIASES %%
 - %%%%%%%%%%%%%%%%%%%
 - FUNCTION {conference}{inproceedings}
 - FUNCTION {online}{electronic}
 - FUNCTION {internet}{electronic}
 - FUNCTION {webpage}{electronic}
 - FUNCTION {www}{electronic}
 - FUNCTION {default.type}{misc}
 - 
 - 
 - 
 - %%%%%%%%%%%%%%%%%%
 - %% MAIN PROGRAM %%
 - %%%%%%%%%%%%%%%%%%
 - 
 - READ
 - 
 - EXECUTE {initialize.controls}
 - EXECUTE {initialize.status.constants}
 - EXECUTE {banner.message}
 - 
 - EXECUTE {initialize.longest.label}
 - ITERATE {longest.label.pass}
 - 
 - EXECUTE {begin.bib}
 - ITERATE {call.type$}
 - EXECUTE {end.bib}
 - 
 - EXECUTE{completed.message}
 - 
 - 
 - %% That's all folks, mds.
 
 
  |