arxmliv
arxmliv build tool
 
KWARC group
LaTeXML
About
   
 

Back to Homepage

--- /arXMLiv/repos/arXMLiv/trunk/sty/IEEETran.cls	2012-08-17 10:33:29.033564669 +0200
+++ /arXMLiv/repos/arXMLiv/trunk/sty/IEEEtran1.6b.cls	2010-04-01 12:45:00.000000000 +0200
@@ -1,16 +1,23 @@
 %%
-%% IEEEtran.cls 2007/03/05 version V1.7a
+%% IEEEtran.cls 2002/11/18 version V1.6b
+%%
+%% NOTE: This text file uses UNIX line feed conventions. When (human)
+%% reading this file on other platforms, you may have to use a text
+%% editor that can handle lines terminated by the UNIX line feed
+%% character (0x0A).
 %%
 %%
 %% This is the official IEEE LaTeX class for authors of the Institute of
 %% Electrical and Electronics Engineers (IEEE) Transactions journals and
 %% conferences.
 %%
-%% Support sites:
-%% http://www.michaelshell.org/tex/ieeetran/
-%% http://www.ctan.org/tex-archive/macros/latex/contrib/IEEEtran/
-%% and
-%% http://www.ieee.org/
+%% The latest version and documentation of IEEEtran can be obtained at:
+%% http://www.ieee.org
+%% and/or
+%% http://www.ctan.org/tex-archive/macros/latex/contrib/supported/IEEEtran/
+%%
+%% The CTAN page may have additional files related to obscure,
+%% non-IEEE standard and/or platform dependent use of this tool.
 %%
 %% Based on the original 1993 IEEEtran.cls, but with many bug fixes
 %% and enhancements (from both JVH and MDS) over the 1996/7 version.
@@ -19,49 +26,40 @@
 %% Contributors:
 %% Gerry Murray (1993), Silvano Balemi (1993),
 %% Jon Dixon (1996), Peter N"uchter (1996),
-%% Juergen von Hagen (2000), and Michael Shell (2001-2007)
+%% Juergen von Hagen (2000), and Michael Shell (2001-2002)
 %%
 %%
-%% Copyright (c) 1993-2000 by Gerry Murray, Silvano Balemi,
-%%                         Jon Dixon, Peter N"uchter,
-%%                         Juergen von Hagen
-%%                         and
-%% Copyright (c) 2001-2007 by Michael Shell
+%% Copyright (c) 1993-2002 by Gerry Murray, Silvano Balemi,
+%%                         Jon Dixion, Peter N"uchter,
+%%                         Juergen von Hagen and Michael Shell
 %%
-%% Current maintainer (V1.3 to V1.7): Michael Shell
-%%                                    See:
-%%                                    http://www.michaelshell.org/
+%% Current maintainer (V1.3 to V1.6): Michael Shell
+%%                                    mshell@ece.gatech.edu
+%%                                    See the CTAN website above
 %%                                    for current contact information.
 %%
 %% Special thanks to Peter Wilson (CUA) and Donald Arseneau
 %% for allowing the inclusion of the \@ifmtarg command
 %% from their ifmtarg LaTeX package.
 %%
-%%*************************************************************************
+%%**********************************************************************
 %% 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!
+%% 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.
+%% 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: IEEEtran.cls, IEEEtran_HOWTO.pdf, bare_adv.tex,
-%%                    bare_conf.tex, bare_jrnl.tex, bare_jrnl_compsoc.tex
+%% This code is distributed under the Perl Artistic License
+%% ( http://language.perl.com/misc/Artistic.html )
+%% and may be freely used, distributed and modified.
+%% Retain the contribution notices and credits.
 %%
 %% Major changes to the user interface should be indicated by an
 %% increase in the version numbers. If a version is a beta, it will
@@ -72,11 +70,11 @@
 %% \IEEEtransversionmajor and \IEEEtransversionminor must reflect the
 %% correct version information.
 %% The changes should also be documented via source comments.
-%%*************************************************************************
+%%**********************************************************************
 %%
 %
 % Available class options
-% e.g., \documentclass[10pt,conference]{IEEEtran}
+% (e.g., \documentclass[10pt,conference]{IEEEtran}
 %
 %             *** choose only one from each category ***
 %
@@ -126,7 +124,7 @@
 %    important to dvips users. Fix config.ps, config.pdf, or ~/.dvipsrc for
 %    dvips, or use the dvips -t papersize option instead as needed. See the
 %    testflow documentation
-%    http://www.ctan.org/tex-archive/macros/latex/contrib/IEEEtran/testflow
+%    http://www.ctan.org/tex-archive/macros/latex/contrib/supported/IEEEtran/testflow
 %    for more details on dvips paper size configuration.
 %    The default is letterpaper.
 %
@@ -141,20 +139,6 @@
 %    column mode is usually used only with draft papers.
 %    The default is twocolumn.
 %
-% compsoc
-%    Use the format of the IEEE Computer Society.
-%
-% romanappendices
-%    Use the "Appendix I" convention when numbering appendices. IEEEtran.cls
-%    now defaults to Alpha "Appendix A" convention - the opposite of what
-%    v1.6b and earlier did.
-%
-% captionsoff
-%    disables the display of the figure/table captions. Some IEEE journals
-%    request that captions be removed and figures/tables be put on pages
-%    of their own at the end of an initial paper submission. The endfloat
-%    package can be used with this class option to achieve this format.
-%
 % nofonttune
 %    turns off tuning of the font interword spacing. Maybe useful to those
 %    not using the standard Times fonts or for those who have already "tuned"
@@ -162,93 +146,547 @@
 %    The default is to enable IEEEtran to tune font parameters.
 %
 %
-%----------
-% Available CLASSINPUTs provided (all are macros unless otherwise noted):
-% \CLASSINPUTbaselinestretch
-% \CLASSINPUTinnersidemargin
-% \CLASSINPUToutersidemargin
-% \CLASSINPUTtoptextmargin
-% \CLASSINPUTbottomtextmargin
-%
-% Available CLASSINFOs provided:
-% \ifCLASSINFOpdf                       (TeX if conditional)
-% \CLASSINFOpaperwidth                  (macro)
-% \CLASSINFOpaperheight                 (macro)
-% \CLASSINFOnormalsizebaselineskip      (length)
-% \CLASSINFOnormalsizeunitybaselineskip (length)
-%
-% Available CLASSOPTIONs provided:
-% all class option flags (TeX if conditionals) unless otherwise noted,
-% e.g., \ifCLASSOPTIONcaptionsoff
-% point size options provided as a single macro:
-% \CLASSOPTIONpt
-% which will be defined as 9, 10, 11, or 12 depending on the document's
-% normalsize point size.
-% also, class option peerreviewca implies the use of class option peerreview
-% and classoption draft implies the use of class option draftcls
-
-
-
-
-
-\ProvidesClass{IEEEtran}[2007/03/05 V1.7a by Michael Shell]
+%*******
+% 11/2002 V1.6b (MDS) changes:
+%
+% 1) Fixed problem with figure captions when using hyperref. Thanks to
+%    Leandro Barajas and Michael Bassetti for reporting this bug.
+%
+% 2) Provide a fake nabib command \NAT@parse so that hyperref will not
+%    interfere with the operation of cite.sty. However, as a result citation
+%    numbers will not be hyperlinked. Also, natbib will not be able to work
+%    with IEEEtran. However, this is perhaps the best solution until cite.sty
+%    and hyperref.sty are able to co-exist with each other.
+%    It easy enough to override the fake command via:
+%    \makeatletter
+%    \let\NAT@parse\undefined
+%    \makeatother
+%
+% 3) Revised font selection method so as not to have problems when used
+%    with setspace.sty. Thanks to Zhang Yan for reporting this bug.
+%
+% 4) Added \special to feed papersize to dvips. Thanks to Moritz Borgmann
+%    for suggesting this feature.
+%
+% 5) In addition to the IEEE IED lists, the original IED style list
+%    environments (as is done in article.cls) are now provided as
+%    LaTeXitemize, LaTeXenumerate, and LaTeXdescription. Also, users can
+%    now redefine \makelabel within IEEE IED list controls. There may be
+%    some use for this in specialized applications. Thanks to Eli Barzilay
+%    for suggesting this feature.
+%
+% 6) \table* now defaults to \footnotesize text like \table.
+%
+% 7) The draft modes now no longer force a pagebreak after the title.
+%    Thanks to Christian Peel for suggesting this change.
+%
+% 8) New draftclsnofoot mode is like draftcls, but does not display the
+%    date and the word "DRAFT" at the foot of the page. Thanks to
+%    Christian Peel for suggesting this feature.
+%
+% 9) New peerreview and peerreviewca modes with \IEEEpeerreviewmaketitle
+%    command allows for a "cover" titlepage for anonymous peer review.
+%    Except for the cover titlepage, peerreview is much like journal mode.
+%    peerreviewca is like peerreview, but allows the author names to be
+%    entered and formatted as under conference mode so that author
+%    affiliations and contact information can be easily seen on the cover
+%    page. Thanks to Eric Benedict for suggesting this feature.
+%
+%
+%*******
+% 7/2002 V1.6 (MDS) changes:
+%
+% 1) Added conference mode via conference option. Defaults to the traditional
+%    journal mode. i.e., \documentclass[conference]{IEEEtran}
+%
+% 2) Added support for A4 paper via new a4paper option. Pdflatex's paper size
+%    lengths are now automatically set to the proper paper size being used.
+%
+% 3) Revised margins again. Page text is now horizontally centered.
+%    Conference mode increases the top and bottom margins with the bottom
+%    margin being slightly larger. For A4 paper, the top margin and text
+%    typesetting will not change from those of US letter paper, but the side
+%    margins will be smaller and the bottom margin will be larger than that of
+%    US letter. All per IEEE specs.
+%
+% 4) Fixed footnote line spacing anomaly in draft mode.
+%    Thanks to Alberto Rodriguez for reporting this bug.
+%
+%    Also, slightly revised footnote and \thanks note spacing.
+%    Set \interfootnotelinepenalty=10000 to prevent LaTeX
+%    from breaking footnotes across multiple pages or columns.
+%
+% 5) Fixed bug that caused overwritten photo areas and sometimes anomalous
+%    spacing when a new paragraph was started within a biography. Also,
+%    the presence of \par's, new lines or spaces at the beginning of
+%    abstract, keywords, biography, or biographynophoto will no longer
+%    affect the first word spacing.
+%    Thanks to Eric Durant for reporting this bug.
+%
+%    The biography environment now does a better job in preventing
+%    a biography photo area from being broken across pages or columns.
+%
+% 6) Fixed whitespace between \cite entries bug. i.e.,
+%    both \cite{einstein24, knuth84} and \cite{einstein24,knuth84}
+%    are now valid. \cite is now a robust command as it should be.
+%    IEEEtran now no longer defines the old non-standard \shortcite or
+%    \citename.
+%
+%    The base IEEEtran.cls does not sort citation numbers or produce ranges
+%    for three or more consecutive numbers. However, V1.6 of IEEEtran.cls
+%    now pre-defines the following format control macros to facilitate easy
+%    use with Donald Arseneau's cite.sty package (tested with cite.sty V3.9):
+%
+%    \def\citepunct{], [}
+%    \def\citedash{]--[}
+%
+%    cite.sty is standard on most LaTeX sytems and can be obtained from
+%    www.ctan.org. Thanks to Donald Arseneau for creating cite.sty, providing
+%    the required format arguments to produce the IEEE style. and
+%    designing a cite interface capable of handling the IEEE citation
+%    style.
+%
+%    Note: Historically, IEEE has wanted authors to "hardcode" symbolics.
+%    (i.e., replace all \cite{} with fixed [x]). However, it now seems that
+%    most electronic manuscript submissions to IEEE are in .pdf format, and
+%    as such, do not require the LaTeX document reference numbers to be hard
+%    coded. If an author is required to submit actual LaTeX files, I do
+%    recommend that the bibliography file (.bbl) be copied into the .tex
+%    document and the \bibliographystyle{} and \bibliography{} commands be
+%    commented out so that the .tex file does not depend on (potentially
+%    lengthy and/or confidential) external bibliography database files.
+%
+% 7) Adjusted some spacing parameters. The spacing above and below equations
+%    has been revised (to a typical IEEE value). \jot now has a decent value.
+%    The title text is now exactly 24pt. (On a related note, \fontsubfuzz has
+%    been increased to 0.9pt to prevent annoying font substitution warnings
+%    when using the Computer Modern fonts that use the 24.88pt size.)
+%    In V1.6, \small is now 8.5pt in 9pt docs because \footnotesize is 8pt.
+%    For 9pt docs, you should probably go ahead and use \footnotesize when you
+%    need text a little smaller than \normalsize.
+%    The interword spacing has been adjusted to be extremely close to that
+%    which IEEE uses. You can use a new class option, nofonttune, if you need
+%    to disable the adjusting of the interword spacing. This adjustment and
+%    an increase to \hyphenpenalty have greatly reduced the amount of
+%    hyphenation in a typical paper.
+%       The baselineskip for the normalsize fonts has been tweaked to reduce
+%    underfull vboxes on journal paper columns with only paragraphs.
+%    Conference mode does the same thing but by also tweaking the \textheight
+%    slightly off 9.25in (IEEE spec) to ensure an integer number of lines per
+%    page. Draft (also draftcls) mode has also been revised to reduce
+%    underfull vbox warnings. However, draft mode can still produce underfull
+%    vboxes (a direct result of the increase in line spacing and margins) if:
+%    A non-normalsize font occupies an entire column (abstract and index terms
+%    take up a whole column by themselves); or the beginning of a section
+%    occurs near the end of a column and cannot be squeezed into the bottom,
+%    etc. This is normal as draft mode's liberal spacings cannot guarantee
+%    perfect formatting.
+%
+% 8) New biographynophoto environment for biographies without photos.
+%    Usage:
+%
+%    \begin{biographynophoto}{author name}
+%    biography text here
+%    \end{biographynophoto}
+%
+% 9) Fixed bug that produced multiple table of contents entries for papers
+%    with more than one biography. Also, biography now works better with
+%    hyperref.
+%
+%10) New \sublargesize font size command provides for 11pt text in a 10pt
+%    document. (Needed for things like author names.) For documents not
+%    using 10pt normal size text, \sublargesize is currently identical
+%    to \large.
+%
+%11) New \IEEEmembership command to provide correct font to indicate IEEE
+%    membership for journal papers.
+%
+%12) Fixed author name line overflow problem when in journal mode. This
+%    problem had been introduced in V1.5 in my rush to get \and to work for
+%    conferences. \and is unneeded (and invalid) in journal mode. For
+%    conference mode, \and will work as expected and features an optional
+%    spacing argument. i.e., \and[\hspace{5ex}]
+%    \and will default (recommended) to using \hfill which will result in
+%    equal spacing between author blocks.
+%
+%13) New \authorblockN, \authorblockA and \authorrefmark commands to
+%    facilitate easy formatting of author names, affiliations and cross
+%    reference symbols, respectively, when in conference mode. These
+%    three commands are to be used only for conference papers.
+%    In conference mode, \author text is placed within a modified tabular
+%    environment (somewhat like article.cls). So, within \author in conference
+%    mode, you should not try to enclose multiple \\ within an environment or
+%    command (other than the argument braces of \authorblockX{}). For example:
+%
+%    \author{\authorblockN{{John Doe \\ Jane Doe}}} % WRONG!
+%
+%    will generate an error.
+%
+%    Note that font size/attribute changes will now persists across \\ within
+%    \author. (But, not across author blocks nor across \and.)
+%    However, with the new commands, there should be no need to alter any
+%    font attributes within \author. All text sizing and spacing within
+%    \author{} and the author block commands is per IEEE specs for both
+%    conference and journal modes. (In conference mode, the author names
+%    are only very slightly larger than the affiliations which are in normal
+%    size.) For specialized applications you can alter the justification of
+%    author lines by placing \hfill at the beginning or at the end of a line.
+%    The interline spacing within \author is determined by the font attributes
+%    that are in effect at the end of each line within author.
+%
+%14) Because the titles and author name blocks use different font sizes/styles
+%    from the main text, it was possible that two column papers with titles that
+%    span both columns (standard journal and conference papers, but not technotes)
+%    with certain numbers of lines for the title and authors' name/affiliations
+%    can cause underfull vbox problems (paragraphs with large spacings between
+%    them) in the second column of the main text on the title page - if there were
+%    no new sections, equations or figures in this column (they would provide some
+%    needed rubber spacing). The use of things like special paper notices and
+%    publisher ID marks also affected this issue. The problem could not happen
+%    in the first column because the first column has a rubber length around the
+%    heading of the first section. Furthermore, problems seldom occurred on pages
+%    after the first as the margins had been chosen not to cause it with the popular
+%    font sizes. Rubber lengths after the author names would not fix this problem.
+%       Auto-calculating a "good" spacing after the title is a tad difficult
+%    to do in LaTeX. However, I am pleased to report that V1.6 has this new
+%    capability - "dynamically determined title spacing". IEEEtran will now
+%    measure the height of all the title and author text in \maketitle
+%    and then calculate a rigid (non-rubber) spacer to follow that meets
+%    IEEE specs and also produces a \textheight on the title page that ensures
+%    an integer number of normalsized lines on the rest of the page. Single
+%    column  papers, and two column papers with the title entirely in column
+%    one (technotes) do not need dynamic rigid spacing and therefore use
+%    standard rubber spacers.
+%
+%    Note: This problem can still crop up if you use floats that span both
+%    columns (i.e., figure*). It has been a decade+ long limitation with LaTeX
+%    that the stretchable portion of \dbltextfloatsep is ignored.
+%    If you get a problem with underful vbox warnings and paragraphs that "are
+%    pulled apart" on page with a float that spans both columns, tweak the
+%    space between the figure and the main text a little:
+%
+%    \vskip 5pt
+%    \end{figure*}
+%
+%    If you can't find a value that fixes both columns, you are going to
+%    have to put a rubber spacer somewhere in one or both of the columns.
+%
+%15) Because of change #14 above, those of you using \pubid will, as of V1.6,
+%    have to place it *before* \maketitle in order for it have the intended
+%    affect. The dynamic spacer algorithm must see if you are using \pubid when
+%    \maketitle is called. \pubidadjcol works as before except that it now
+%    has additional logic to prevent it from doing anything if \pubid was never
+%    called.
+%
+%16) In some unusual, non-standard circumstances, an author may desire to
+%    alter the spacing after the title area or put some unusual text above
+%    the main text. For instance, to stop a bad break when a new section
+%    occurs right at the start of the second page. This is difficult to do
+%    when the title spans both columns of two column text since LaTeX treats
+%    such title text as a type of float. A new command, \IEEEaftertitletext{},
+%    gives access to the end of that produced by \maketitle. The types of
+%    things that can go into \IEEEaftertitletext are the same as those into
+%    \twocolumn[] - no \par, but \\ are OK. There is no restriction on the
+%    range of spacings that can be used.
+%    i.e., \IEEEaftertitletext{\vspace{-100pt}} will push the main text well
+%    into the title and \IEEEaftertitletext{\vspace{100pt}} will push it far down
+%    the page. You will have complete control. If used, place
+%    \IEEEaftertitletext{} before \maketitle like \title and \author. IEEEtran's
+%    dynamic title spacing intentionally does not take into consideration the
+%    contents of \IEEEaftertitletext{} when determining the spacer after the title
+%    area (otherwise it would try to second guess you), so the user will have
+%    manually adjust the height of the contents in \IEEEaftertitletext{} if the
+%    problem discussed in #14 above should develop. A safe bet is to keep
+%    the height of contents of \IEEEaftertitletext{} to integer multiples of
+%    \baselineskip, i.e., \IEEEaftertitletext{\vspace{-1\baselineskip}}
+%
+%    Because it can result in an IEEE nonstandard format, the use of
+%    \IEEEaftertitletext{} is discouraged. Possible uses include (1) the use of
+%    IEEEtran for non-IEEE work with different title spacing requirements,
+%    or (2) as an emergency manual override if a problem should develop in
+%    IEEEtran's automatic spacing algorithm.
+%
+%17) completely rewritten \PARstart to:
+%    a. no longer have problems when the user begins an environment
+%       within the paragraph that uses \PARstart.
+%    b. auto-detect and use the current font family
+%    c. revise handling of the space at the end of the first word so that
+%       interword glue will now work as normal.
+%    d. produce correctly aligned edges for the (two) indented lines.
+%
+%    Because the current font family is now auto-detected, there is no
+%    longer any need for \CMPARstart - it is now the same as \PARstart.
+%
+%18) There is now a new "open box" Q.E.D. symbol (\QEDopen) as well as the
+%    original default (\QED) closed one (\QEDclosed). Some journals use
+%    the open form. To make \proof use the open form, just do:
+%    \renewcommand{\QED}{\QEDopen}
+%
+%19) Additional \typeout{} notices added to warn the user when unusual
+%    settings/commands are detected or as reminders to avoid common errors
+%    when in conference mode.
+%
+%20) IEEEtran now provides \abovecaptionskip and \belowcaptionskip skip
+%    registers because article class provides them and some packages
+%    may error if they are missing. However, IEEEtran only uses
+%    \abovecaptionskip for actual caption spacing.
+%
+%21) Fixed bug that prevented users from redefining the section headings
+%    to use arabic digits. Thanks to Richardt H. Wilkinson for reporting
+%    this bug.
+%
+%22) Code cleaned up to be more efficient with the use of TeX registers;
+%    removed some old LaTeX 2.09 code; revised option processing to
+%    LaTeX2e standard; eliminated unwanted "phantom" spaces in some
+%    environments.
+%
+%23) Added new \IEEEeqnarray, \IEEEeqnarraybox, \IEEEeqnarrayboxm and
+%    \IEEEeqnarrayboxt environments to provide superior alternatives to the
+%    standard LaTeX \eqnarray, \array and \tabular. Additional new support
+%    commands include \IEEEeqnarraydecl, \IEEEeqnarrayboxdecl,
+%    \IEEEeqnarraymathstyle, \IEEEeqnarraytextstyle, \yesnumber. \IEEEnonumber,
+%    \IEEEyesnumber, \IEEEyessubnumber, \IEEEeqnarraynumspace, \IEEEeqnarraymulticol,
+%    \IEEEeqnarrayomit, \IEEEeqnarraydefcol, \IEEEeqnarraydefcolsep, \IEEEeqnarrayseprow,
+%    \IEEEeqnarrayseprowcut, \IEEEeqnarrayrulerow, \IEEEeqnarraydblrulerowcut,
+%    \IEEEeqnarraystrutmode, \IEEEeqnarraystrutsize, \IEEEeqnarraystrutsizeadd,
+%    \IEEEvisiblestrutstrue, \IEEEvisiblestrutsfalse and \IEEEstrut.
+%    These are documented in the user's guide.
+%
+%24) V1.6 changed back to using () around theorem names (which are also now in italics)
+%    as this is what IEEE is using now. Thanks to Christian Peel for reporting this.
+%    Also, when section numbers are used as the first part of theorem numbers, display
+%    them in arabic, not Roman.
+%
+%25) New \IEEEtriggeratref{X} command allows a page break to be triggered just
+%    before the given reference number "X". This is most useful when balancing
+%    the columns on the last page and a \newpage between references is desired.
+%    \IEEEtriggercmd{X} allows a different command to be executed at trigger.
+%
+%
+%*******
+% 7/2001 V1.5 (MDS) changes:
+%
+%
+% 1) Fixed \and within \author bug: (! Misplaced \crcr. \endtabular ->\crcr)
+%    Thanks to Rainer Dorsch for discovering and reporting that \and
+%    did not work.
+%
+% 2) Fixed the biography environment so that if a biography's text is shorter
+%    than the area allocated for the photo, a collision with the next
+%    biography does not occur. You can now put real graphics (using the
+%    graphicx package) into the biography photo box with a new optional
+%    argument of the biography command! For example:
+%
+%    \begin{biography}[{\includegraphics[width=1in,height=1.25in,clip,keepaspectratio]{./tux.eps}}]{Linux Penguin}
+%
+%    will use the specified graphic as the author's photo. The photo area is
+%    exactly 1in wide by 1.25in high - as is done in IEEE Transactions. Try
+%    to keep the same 4:5 aspect ratio if scanning/cropping your photos.
+%    Note the need for the extra set of enclosing braces around the
+%    \includegraphics. Without it, The LaTeX parser may get confused when it
+%    sees the \includegraphics's brackets within the biography's optional
+%    argument. Due to the length of the \includegraphics command, you may wish
+%    to define your own shorthand form of it. I have not done so with IEEEtran
+%    to prevent dependence on the graphicx package. If you do not use the
+%    optional argument, or leave it empty, a standard frame box with the
+%    words "Place Photo Here" will be used. If you want the space to remain
+%    completely empty, you can do:
+%
+%    \begin{biography}[\mbox{}]{The Invisible Man}
+%
+%    The interface to biography's optional argument is into a
+%    1in X 1.25in minipage in which the argument text is centered both
+%    horizontally and vertically:
+%
+%    \begin{minipage}[b][1.25in][c]{1in}%
+%    \centering
+%    #1%
+%    \end{minipage}
+%
+%    Within the biography environment, \unitlength is set to 1in.
+%    With this in mind, you can even design your own custom frameboxes.
+%    For instance:
+%
+%    \begin{biography}[\framebox(1,1.25){\parbox[][\height][c]{0.9in}{\centering PLACE\\ PHOTO\\ HERE}}]{Author Name}
+%
+%    will yield the same type of result as the default photo box.
+%
+%    Thanks to Herbert Voss for discovering the collision bug, suggesting the ability
+%    to handle graphics and providing some prototype code.
+%
+%
+%
+%*******
+% 3/2001 V1.4 (MDS) changes:
+%
+%
+% 1) New "draftcls" and "final" options have been added.
+%    Thanks to Dragan Cvetkovic for suggesting an option like draftcls.
+%
+% 2) Documentation changes to reflect the fact that this IEEEtran.cls
+%    is no longer beta test.
+%
+% 3) Slightly revised caption sizes. Figure and table captions are now
+%    in \footnotesize, not \small as before.
+%
+% 4) Allow user to control figure caption justification. IEEEtran.cls
+%    normally defaults to left justified as is done in Transactions.
+%    However, for conferences, you may wish to issue the command:
+%    \centerfigcaptionstrue
+%    in the preamble. Short (less than one line long) figure captions
+%    will then be centered. Multi-line figure captions will always be
+%    properly left justified. V1.6: This is already done for you when
+%    using the conference mode.
+%
+%
+%
+%*******
+% 1/2001 V1.3
+% Michael Shell (MDS) made extensive changes and additions:
+%
+%
+% BUGS FIXED (and many others too numerous to mention!):
+% 1) Fixed improper alignment with itemized, enumerated and
+%    description lists. Added new controls to these three
+%    environments so that it is easy to get the alignment IEEE
+%    uses. Furthermore, the itemize, enumerate and description lists
+%    no longer force a new paragraph to begin at the end the list
+%    (\par). (Sometimes lists are used within paragraphs.)
+%
+% 2) JVH's fixes now allow things like $\mathbf{N}(0,P(0))$
+%    to work properly without needing the extra braces:
+%    ${\mathbf{N}}(0,P(0))$. There is no longer any dependence
+%    on the "rawfonts" and "oldlfont" packages. Thanks Juergen!
+%
+% 3) Fixed underfull hbox errors and incorrect reference number
+%    alignment when the number of references in the bibliography
+%    exceeded 9 entries (which is almost every paper!).
+%
+% 4) Removed dependence on the LaTeX sizexx.clo files.
+%    Now, 9pt documents should work correctly even on systems that
+%    lack a size9.clo file. This is most often used in conjunction
+%    with the option "technote" for "correspondence" papers like those
+%    in IEEE Transactions on Information Theory. For virtually all
+%    other papers, 10pt is used and so it is the default.
+%    Some improper font sizes have been corrected. \footnotesize is
+%    now 8pt in 9pt docs, so footnotes in technotes should be the
+%    correct size now.
+%
+% 5) Added \interlinepenalty within the bibliography section to discourage
+%    LaTeX from breaking within a reference. IEEE almost never breaks within
+%    a reference and when they do it is usually in technotes
+%    (correspondence papers). You may get an underfull vbox warning in the
+%    bibliography indicating that the spacing just before the "REFERENCES"
+%    section is larger than normal, but the final result will be more like
+%    what IEEE will publish. See the comments in the BIBLIOGRAPHY section
+%    around line 2034 below if you want to change this behavior.
+%
+% 6) No longer "blows up" when you use \paragraph and have a table
+%    of contents.
+%
+% 7) Theorem environment changed, (but for V1.6, back to the old way, sigh).
+%
+% 8) Figure captions adjusted: IEEE left (not center) justifies
+%    figure captions (for journals) and does not indent figure caption text.
+%
+% 9) Adjusted some spacings in the table of contents(TOC))/list-of-figures/
+%    list-of-tables so that section/table numbers will not so easily
+%    collide with the titles. Section VIII was usually the worst offender.
+%    Still doesn't right justify the section numbers, but neither does
+%    article.cls (This must be why LaTeX likes the x.y.z section numbering
+%    scheme unlike I, II, III, etc. of IEEE. )
+%    It may be "normal" as it is (left justified). sigh.
+%
+%10) Now uses "index terms" now as a heading instead of "keywords".
+%    Furthermore, the "index terms" and "abstract" headings are in bold
+%    italic. This is how IEEE does things.
+%
+%11) \thebibliography and \biography now put entries into
+%    the table of contents for you.
+%
+% *******
+%
+%
+%
+%
+%
+% *******
+% 9/2000 (JVH) changes: (now designated as V1.2)
+%
+% made some corrections to get closer to LaTeX2e
+% 20000906 Juergen v.Hagen
+% vonhagen@ihefiji.etec.uni-karlsruhe.de
+%
+% Permission to redistribute granted as of December 2000.
+% *******
+%
+%
+%
+%
+%
+% *******
+%
+% 1996 (JWD) LaTeX2e version: (now designated as V1.1)
+%
+% In the most recent TeXhax digest, there was a request for a copy of
+% IEEEtrans.sty modified to work with LaTeX2e.  I have a version I
+% modified to make it IEEEtrans.cls, which I have sent to the person
+% making the request and am now sending to you to consider posting to
+% the archives.
+% --
+% Jon Dixon
+% dixonj@colorado.edu
+% http://spot.colorado.edu/~dixonj/
+%
+%*******
+%
+%
+%
+%
+%
+%*******
+%
+% 30-August-1993 original LaTeX 2.09 version (IEEEtran.sty),
+% (now designated as V1.0):
+%
+% by Gerry Murray and Silvano Balemi
+% Automatic Control Lab, ETH Zurich, Switzerland
+% balemi@aut.ee.ethz.ch
+%
+%*******
+%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%
+%
+%
+%
+%
+\ProvidesClass{IEEEtran}[2002/11/18 revision V1.6b by Michael Shell]
 \typeout{-- See the "IEEEtran_HOWTO" manual for usage information.}
-\typeout{-- http://www.michaelshell.org/tex/ieeetran/}
+\typeout{-- The source comments contain changelog notes.}
 \NeedsTeXFormat{LaTeX2e}

-% IEEEtran.cls version numbers, provided as of V1.3
-% These values serve as a way a .tex file can
-% determine if the new features are provided.
-% The version number of this IEEEtrans.cls can be obtained from
-% these values. i.e., V1.4
-% KEEP THESE AS INTEGERS! i.e., NO {4a} or anything like that-
-% (no need to enumerate "a" minor changes here)
-\def\IEEEtransversionmajor{1}
-\def\IEEEtransversionminor{7}
-
-% These do nothing, but provide them like in article.cls
-\newif\if@restonecol
-\newif\if@titlepage
-
-
-% class option conditionals
-\newif\ifCLASSOPTIONonecolumn       \CLASSOPTIONonecolumnfalse
-\newif\ifCLASSOPTIONtwocolumn       \CLASSOPTIONtwocolumntrue
-
-\newif\ifCLASSOPTIONoneside         \CLASSOPTIONonesidetrue
-\newif\ifCLASSOPTIONtwoside         \CLASSOPTIONtwosidefalse
-
-\newif\ifCLASSOPTIONfinal           \CLASSOPTIONfinaltrue
-\newif\ifCLASSOPTIONdraft           \CLASSOPTIONdraftfalse
-\newif\ifCLASSOPTIONdraftcls        \CLASSOPTIONdraftclsfalse
-\newif\ifCLASSOPTIONdraftclsnofoot  \CLASSOPTIONdraftclsnofootfalse
-
-\newif\ifCLASSOPTIONpeerreview      \CLASSOPTIONpeerreviewfalse
-\newif\ifCLASSOPTIONpeerreviewca    \CLASSOPTIONpeerreviewcafalse
-
-\newif\ifCLASSOPTIONjournal         \CLASSOPTIONjournaltrue
-\newif\ifCLASSOPTIONconference      \CLASSOPTIONconferencefalse
-\newif\ifCLASSOPTIONtechnote        \CLASSOPTIONtechnotefalse
-
-\newif\ifCLASSOPTIONnofonttune      \CLASSOPTIONnofonttunefalse
-
-\newif\ifCLASSOPTIONcaptionsoff     \CLASSOPTIONcaptionsofffalse
-
-\newif\ifCLASSOPTIONcompsoc         \CLASSOPTIONcompsocfalse
-
-\newif\ifCLASSOPTIONromanappendices \CLASSOPTIONromanappendicesfalse
-
-
-% class info conditionals
-
-% indicates if pdf (via pdflatex) output
-\newif\ifCLASSINFOpdf               \CLASSINFOpdffalse
-
-
-% V1.6b internal flag to show if using a4paper
-\newif\if@IEEEusingAfourpaper       \@IEEEusingAfourpaperfalse
-
+% define new needed flags to indicate document options
+% and set a few "failsafe" defaults
+\newif\if@twocolumnmode      \global\@twocolumnmodetrue
+\newif\if@draftversion       \global\@draftversionfalse
+\newif\if@draftclsmode       \global\@draftclsmodefalse
+\newif\if@draftclsmodefoot   \global\@draftclsmodefootfalse
+\newif\if@confmode           \global\@confmodefalse
+\newif\if@peerreviewoption   \global\@peerreviewoptionfalse
+\newif\if@peerreviewcaoption \global\@peerreviewcaoptionfalse
+
+% we HAVE to turn off technote as there is no
+% "not a tech note" option
+\newif\if@technote      \global\@technotefalse
+
+% V1.6 we allow the user to control whether or not the
+% font interword spacings are tuned to be more like
+% that of IEEE. The default is to tune things.
+\newif\if@fonttunesettings   \global\@fonttunesettingstrue

+% V1.6b flag to show if using a4paper
+\newif\if@IEEEusingAfourpaper      \global\@IEEEusingAfourpaperfalse

 % IEEEtran class scratch pad registers
 % dimen
@@ -260,117 +698,92 @@
 % token list
 \newtoks\@IEEEtrantmptoksA

-% we use \CLASSOPTIONpt so that we can ID the point size (even for 9pt docs)
+% we use \@IEEEptsize so that we can ID the point size (even for 9pt docs)
 % as well as LaTeX's \@ptsize to retain some compatability with some
 % external packages
+\def\@IEEEptsize{10}
 \def\@ptsize{0}
 % LaTeX does not support 9pt, so we set \@ptsize to 0 - same as that of 10pt
-\DeclareOption{9pt}{\def\CLASSOPTIONpt{9}\def\@ptsize{0}}
-\DeclareOption{10pt}{\def\CLASSOPTIONpt{10}\def\@ptsize{0}}
-\DeclareOption{11pt}{\def\CLASSOPTIONpt{11}\def\@ptsize{1}}
-\DeclareOption{12pt}{\def\CLASSOPTIONpt{12}\def\@ptsize{2}}
-
+\DeclareOption{9pt}{\def\@IEEEptsize{9}\def\@ptsize{0}}
+\DeclareOption{10pt}{\def\@IEEEptsize{10}\def\@ptsize{0}}
+\DeclareOption{11pt}{\def\@IEEEptsize{11}\def\@ptsize{1}}
+\DeclareOption{12pt}{\def\@IEEEptsize{12}\def\@ptsize{2}}


+% \@IEEEmarginE is the side margin for equal margins
+% \@IEEEmarginW is the wider side margin when the margins are not equal
+% NOTE: BOTH of the above margins are as they appear
+% on the paper - they are NOT offset by 1 inch
 \DeclareOption{letterpaper}{\setlength{\paperheight}{11in}%
                             \setlength{\paperwidth}{8.5in}%
-                            \@IEEEusingAfourpaperfalse
-                            \def\CLASSOPTIONpaper{letter}%
-                            \def\CLASSINFOpaperwidth{8.5in}%
-                            \def\CLASSINFOpaperheight{11in}}
+                            \def\@IEEEmarginE{0.680in}%
+                            \def\@IEEEmarginW{0.775in}%
+                            \@IEEEusingAfourpaperfalse}


 \DeclareOption{a4paper}{\setlength{\paperheight}{297mm}%
                         \setlength{\paperwidth}{210mm}%
-                        \@IEEEusingAfourpapertrue
-                        \def\CLASSOPTIONpaper{a4}%
-                        \def\CLASSINFOpaperwidth{210mm}%
-                        \def\CLASSINFOpaperheight{297mm}}
-
-\DeclareOption{oneside}{\@twosidefalse\@mparswitchfalse
-                        \CLASSOPTIONonesidetrue\CLASSOPTIONtwosidefalse}
-\DeclareOption{twoside}{\@twosidetrue\@mparswitchtrue
-                        \CLASSOPTIONtwosidetrue\CLASSOPTIONonesidefalse}
-
-\DeclareOption{onecolumn}{\CLASSOPTIONonecolumntrue\CLASSOPTIONtwocolumnfalse}
-\DeclareOption{twocolumn}{\CLASSOPTIONtwocolumntrue\CLASSOPTIONonecolumnfalse}
+                        \def\@IEEEmarginE{14.32mm}%
+                        \def\@IEEEmarginW{17mm}
+                        \@IEEEusingAfourpapertrue}
+
+\DeclareOption{oneside}{\@twosidefalse \@mparswitchfalse}
+\DeclareOption{twoside}{\@twosidetrue \@mparswitchtrue}
+
+\DeclareOption{onecolumn}{\global\@twocolumnmodefalse}
+% the file twocolumn.sty is not read as it changes \textwidth.
+\DeclareOption{twocolumn}{\global\@twocolumnmodetrue}

 % If the user selects draft, then this class AND any packages
 % will go into draft mode.
-\DeclareOption{draft}{\CLASSOPTIONdrafttrue\CLASSOPTIONdraftclstrue
-                      \CLASSOPTIONdraftclsnofootfalse}
+\DeclareOption{draft}{\global\@draftversiontrue \global\@draftclsmodetrue
+\global\@draftclsmodefoottrue}
 % draftcls is for a draft mode which will not affect any packages
 % used by the document.
-\DeclareOption{draftcls}{\CLASSOPTIONdraftfalse\CLASSOPTIONdraftclstrue
-                         \CLASSOPTIONdraftclsnofootfalse}
+\DeclareOption{draftcls}{\global\@draftversionfalse \global\@draftclsmodetrue
+\global\@draftclsmodefoottrue}
 % draftclsnofoot is like draftcls, but without the footer.
-\DeclareOption{draftclsnofoot}{\CLASSOPTIONdraftfalse\CLASSOPTIONdraftclstrue
-                               \CLASSOPTIONdraftclsnofoottrue}
-\DeclareOption{final}{\CLASSOPTIONdraftfalse\CLASSOPTIONdraftclsfalse
-                      \CLASSOPTIONdraftclsnofootfalse}
-
-\DeclareOption{journal}{\CLASSOPTIONpeerreviewfalse\CLASSOPTIONpeerreviewcafalse
-                        \CLASSOPTIONjournaltrue\CLASSOPTIONconferencefalse\CLASSOPTIONtechnotefalse}
-
-\DeclareOption{conference}{\CLASSOPTIONpeerreviewfalse\CLASSOPTIONpeerreviewcafalse
-                           \CLASSOPTIONjournalfalse\CLASSOPTIONconferencetrue\CLASSOPTIONtechnotefalse}
-
-\DeclareOption{technote}{\CLASSOPTIONpeerreviewfalse\CLASSOPTIONpeerreviewcafalse
-                         \CLASSOPTIONjournalfalse\CLASSOPTIONconferencefalse\CLASSOPTIONtechnotetrue}
-
-\DeclareOption{peerreview}{\CLASSOPTIONpeerreviewtrue\CLASSOPTIONpeerreviewcafalse
-                           \CLASSOPTIONjournalfalse\CLASSOPTIONconferencefalse\CLASSOPTIONtechnotefalse}
-
-\DeclareOption{peerreviewca}{\CLASSOPTIONpeerreviewtrue\CLASSOPTIONpeerreviewcatrue
-                             \CLASSOPTIONjournalfalse\CLASSOPTIONconferencefalse\CLASSOPTIONtechnotefalse}
+\DeclareOption{draftclsnofoot}{\global\@draftversionfalse \global\@draftclsmodetrue
+\global\@draftclsmodefootfalse}
+% we provide a final option just for completeness (article.cls has one)
+\DeclareOption{final}{\global\@draftversionfalse \global\@draftclsmodefalse
+\global\@draftclsmodefootfalse}

-\DeclareOption{nofonttune}{\CLASSOPTIONnofonttunetrue}
+\DeclareOption{journal}{\global\@peerreviewoptionfalse \global\@peerreviewcaoptionfalse
+\global\@confmodefalse \global\@technotefalse}

-\DeclareOption{captionsoff}{\CLASSOPTIONcaptionsofftrue}
+\DeclareOption{conference}{\global\@peerreviewoptionfalse \global\@peerreviewcaoptionfalse
+\global\@confmodetrue \global\@technotefalse}

-\DeclareOption{compsoc}{\CLASSOPTIONcompsoctrue}
+\DeclareOption{technote}{\global\@peerreviewoptionfalse \global\@peerreviewcaoptionfalse
+\global\@confmodefalse \global\@technotetrue}

-\DeclareOption{romanappendices}{\CLASSOPTIONromanappendicestrue}
-
-
-% default to US letter paper, 10pt, twocolumn, one sided, final, journal
-\ExecuteOptions{letterpaper,10pt,twocolumn,oneside,final,journal}
-% overrride these defaults per user requests
-\ProcessOptions
+\DeclareOption{peerreview}{\global\@peerreviewoptiontrue \global\@peerreviewcaoptionfalse
+\global\@confmodefalse \global\@technotefalse}

+\DeclareOption{peerreviewca}{\global\@peerreviewoptiontrue \global\@peerreviewcaoptiontrue
+\global\@confmodefalse \global\@technotefalse}

+\DeclareOption{nofonttune}{\global\@fonttunesettingsfalse}

-% Computer Society conditional execution command
-\long\def\@IEEEcompsoconly#1{\relax\ifCLASSOPTIONcompsoc\relax#1\relax\fi\relax}
-% inverse
-\long\def\@IEEEnotcompsoconly#1{\relax\ifCLASSOPTIONcompsoc\else\relax#1\relax\fi\relax}
-% compsoc conference
-\long\def\@IEEEcompsocconfonly#1{\relax\ifCLASSOPTIONcompsoc\ifCLASSOPTIONconference\relax#1\relax\fi\fi\relax}
-% compsoc not conference
-\long\def\@IEEEcompsocnotconfonly#1{\relax\ifCLASSOPTIONcompsoc\ifCLASSOPTIONconference\else\relax#1\relax\fi\fi\relax}

-
-% IEEE uses Times Roman font, so we'll default to Times.
+% IEEE uses Times font, so we'll default to times.
 % These three commands make up the entire times.sty package.
 \renewcommand{\sfdefault}{phv}
 \renewcommand{\rmdefault}{ptm}
 \renewcommand{\ttdefault}{pcr}
-
-\@IEEEcompsoconly{\typeout{-- Using IEEE Computer Society mode.}}
-
-% V1.7 compsoc nonconference papers, use Palatino/Palladio as the main text font,
-% not Times Roman.
-\@IEEEcompsocnotconfonly{\renewcommand{\rmdefault}{ppl}}
-
-% enable Times/Palatino main text font
+% enable Times now - so that all class options can see the correct font families
 \normalfont\selectfont


+% default to US letter paper, 10pt, twocolumn, one sided, final, journal
+\ExecuteOptions{letterpaper,10pt,twocolumn,oneside,final,journal}
+% overrride these defaults per user requests
+\ProcessOptions

-
-
-% V1.7 conference notice message hook
-\def\@IEEEconsolenoticeconference{\typeout{}%
+% we can send console reminder messages to the user here
+\AtEndDocument{\if@confmode%
+\typeout{}%
 \typeout{** Conference Paper **}%
 \typeout{Before submitting the final camera ready copy, remember to:}%
 \typeout{}%
@@ -379,50 +792,33 @@
 \typeout{}%
 \typeout{ 2. Ensure that any PostScript and/or PDF output post-processing}%
 \typeout{ uses only Type 1 fonts and that every step in the generation}%
-\typeout{ process uses the appropriate paper size.}%
-\typeout{}}
-
-
-% we can send console reminder messages to the user here
-\AtEndDocument{\ifCLASSOPTIONconference\@IEEEconsolenoticeconference\fi}
+\typeout{ process uses the US letter (8.5in X 11in) paper size.}%
+\typeout{}%
+\fi}


 % warn about the use of single column other than for draft mode
-\ifCLASSOPTIONtwocolumn\else%
-  \ifCLASSOPTIONdraftcls\else%
-   \typeout{** ATTENTION: Single column mode is not typically used with IEEE publications.}%
+\if@twocolumnmode\else%
+  \if@draftclsmode\else%
+   \typeout{** ATTENTION: Single column mode is not normally used with IEEE publications.}%
   \fi%
 \fi


-% V1.7 improved paper size setting code.
-% Set pdfpage and dvips paper sizes. Conditional tests are similar to that
-% of ifpdf.sty. Retain within {} to ensure tested macros are never altered,
-% even if only effect is to set them to \relax.
-% if \pdfoutput is undefined or equal to relax, output a dvips special
-{\@ifundefined{pdfoutput}{\AtBeginDvi{\special{papersize=\CLASSINFOpaperwidth,\CLASSINFOpaperheight}}}{%
-% pdfoutput is defined and not equal to \relax
-% check for pdfpageheight existence just in case someone sets pdfoutput
-% under non-pdflatex. If exists, set them regardless of value of \pdfoutput.
-\@ifundefined{pdfpageheight}{\relax}{\global\pdfpagewidth\paperwidth
-\global\pdfpageheight\paperheight}%
-% if using \pdfoutput=0 under pdflatex, send dvips papersize special
-\ifcase\pdfoutput
-\AtBeginDvi{\special{papersize=\CLASSINFOpaperwidth,\CLASSINFOpaperheight}}%
+% V1.6, if the user is using pdflatex, go ahead and set the output paper size.
+% Otherwise, we declare the papersize via a \special for dvips.
+% We keep the tests within braces because otherwise, if not using pdflatex,
+% \pdfpageheight and \pdfpagewidth will be set to \relax - possibly affecting
+% similar tests of other packages.
+{\@ifundefined{pdfpageheight}{% not using pdflatex, setup paper size for dvips
+\if@IEEEusingAfourpaper
+\special{papersize=210mm,297mm}%
 \else
-% we are using pdf output, set CLASSINFOpdf flag
-\global\CLASSINFOpdftrue
-\fi}}
+\special{papersize=8.5in,11in}%
+\fi}%
+{% using pdftex, set paper size for pdftex
+\global\pdfpageheight\paperheight\global\pdfpagewidth\paperwidth}}

-% let the user know the selected papersize
-\typeout{-- Using \CLASSINFOpaperwidth\space x \CLASSINFOpaperheight\space
-(\CLASSOPTIONpaper)\space paper.}
-
-\ifCLASSINFOpdf
-\typeout{-- Using PDF output.}
-\else
-\typeout{-- Using DVI output.}
-\fi


 % The idea hinted here is for LaTeX to generate markleft{} and markright{}
@@ -459,14 +855,13 @@

 % we need to store the nominal baselineskip for the given font size
 % in case baselinestretch ever changes.
-% this is a dimen, so it will not hold stretch or shrink
-\newdimen\@IEEEnormalsizeunitybaselineskip
-\@IEEEnormalsizeunitybaselineskip\baselineskip
+\newskip\@IEEEnormalsizefontbaselineskip
+\@IEEEnormalsizefontbaselineskip\baselineskip

-\ifx\CLASSOPTIONpt\@IEEEptsizenine
+\ifx\@IEEEptsize\@IEEEptsizenine
 \typeout{-- This is a 9 point document.}
 \def\normalsize{\@setfontsize{\normalsize}{9}{11.0476pt}}%
-\setlength{\@IEEEnormalsizeunitybaselineskip}{11.0476pt}%
+\setlength{\@IEEEnormalsizefontbaselineskip}{11.0476pt}%
 \normalsize
 \abovedisplayskip 1.5ex plus3pt minus1pt%
 \belowdisplayskip \abovedisplayskip%
@@ -487,10 +882,10 @@


 % Check if we have selected 10 points
-\ifx\CLASSOPTIONpt\@IEEEptsizeten
+\ifx\@IEEEptsize\@IEEEptsizeten
 \typeout{-- This is a 10 point document.}
 \def\normalsize{\@setfontsize{\normalsize}{10}{12.00pt}}%
-\setlength{\@IEEEnormalsizeunitybaselineskip}{12pt}%
+\setlength{\@IEEEnormalsizefontbaselineskip}{12pt}%
 \normalsize
 \abovedisplayskip 1.5ex plus4pt minus2pt%
 \belowdisplayskip \abovedisplayskip%
@@ -511,10 +906,10 @@


 % Check if we have selected 11 points
-\ifx\CLASSOPTIONpt\@IEEEptsizeeleven
+\ifx\@IEEEptsize\@IEEEptsizeeleven
 \typeout{-- This is an 11 point document.}
 \def\normalsize{\@setfontsize{\normalsize}{11}{13.3846pt}}%
-\setlength{\@IEEEnormalsizeunitybaselineskip}{13.3846pt}%
+\setlength{\@IEEEnormalsizefontbaselineskip}{13.3846pt}%
 \normalsize
 \abovedisplayskip 1.5ex plus5pt minus3pt%
 \belowdisplayskip \abovedisplayskip%
@@ -535,10 +930,10 @@


 % Check if we have selected 12 points
-\ifx\CLASSOPTIONpt\@IEEEptsizetwelve
+\ifx\@IEEEptsize\@IEEEptsizetwelve
 \typeout{-- This is a 12 point document.}
 \def\normalsize{\@setfontsize{\normalsize}{12}{13.92pt}}%
-\setlength{\@IEEEnormalsizeunitybaselineskip}{13.92pt}%
+\setlength{\@IEEEnormalsizefontbaselineskip}{13.92pt}%
 \normalsize
 \abovedisplayskip 1.5ex plus6pt minus4pt%
 \belowdisplayskip \abovedisplayskip%
@@ -567,70 +962,45 @@

 % warn the user in case they forget to use the 9pt option with
 % technote
-\ifCLASSOPTIONtechnote%
- \ifx\CLASSOPTIONpt\@IEEEptsizenine\else%
+\if@technote%
+ \ifx\@IEEEptsize\@IEEEptsizenine\else%
   \typeout{** ATTENTION: Technotes are normally 9pt documents.}%
  \fi%
 \fi


-% V1.7
-% Improved \textunderscore to provide a much better fake _ when used with
-% OT1 encoding. Under OT1, detect use of pcr or cmtt \ttfamily and use
-% available true _ glyph for those two typewriter fonts.
-\def\@IEEEstringptm{ptm} % Times Roman family
-\def\@IEEEstringppl{ppl} % Palatino Roman family
-\def\@IEEEstringphv{phv} % Helvetica Sans Serif family
-\def\@IEEEstringpcr{pcr} % Courier typewriter family
-\def\@IEEEstringcmtt{cmtt} % Computer Modern typewriter family
-\DeclareTextCommandDefault{\textunderscore}{\leavevmode
-\ifx\f@family\@IEEEstringpcr\string_\else
-\ifx\f@family\@IEEEstringcmtt\string_\else
-\ifx\f@family\@IEEEstringptm\kern 0em\vbox{\hrule\@width 0.5em\@height 0.5pt\kern -0.3ex}\else
-\ifx\f@family\@IEEEstringppl\kern 0em\vbox{\hrule\@width 0.5em\@height 0.5pt\kern -0.3ex}\else
-\ifx\f@family\@IEEEstringphv\kern -0.03em\vbox{\hrule\@width 0.62em\@height 0.52pt\kern -0.33ex}\kern -0.03em\else
-\kern 0.09em\vbox{\hrule\@width 0.6em\@height 0.44pt\kern -0.63pt\kern -0.42ex}\kern 0.09em\fi\fi\fi\fi\fi\relax}
-
-
-
-
-% set the default \baselinestretch
+% set \baselinestretch
 \def\baselinestretch{1}
-\ifCLASSOPTIONdraftcls
-  \def\baselinestretch{1.5}% default baselinestretch for draft modes
-\fi
-
-
-% process CLASSINPUT baselinestretch
-\ifx\CLASSINPUTbaselinestretch\@IEEEundefined
-\else
-  \edef\baselinestretch{\CLASSINPUTbaselinestretch} % user CLASSINPUT override
-  \typeout{** ATTENTION: Overriding \string\baselinestretch\space to
-           \baselinestretch\space via \string\CLASSINPUT.}
-\fi
+\if@draftclsmode% draft mode uses larger than normal spacing
+\def\baselinestretch{1.5} % controls line spacing for draft version
+\fi                       % some people may like 1.7 or greater
+                          % so that there will be even more space
+                          % for hand written comments

 \normalsize % make \baselinestretch take affect


-
-
+% V1.6
 % store the normalsize baselineskip
-\newdimen\CLASSINFOnormalsizebaselineskip
-\CLASSINFOnormalsizebaselineskip=\baselineskip\relax
-% and the normalsize unity (baselinestretch=1) baselineskip
-% we could save a register by giving the user access to
-% \@IEEEnormalsizeunitybaselineskip. However, let's protect
-% its read only internal status
-\newdimen\CLASSINFOnormalsizeunitybaselineskip
-\CLASSINFOnormalsizeunitybaselineskip=\@IEEEnormalsizeunitybaselineskip\relax
+\newskip\normalsizebaselineskip
+\normalsizebaselineskip=\baselineskip\relax
 % store the nominal value of jot
-\newdimen\IEEEnormaljot
-\IEEEnormaljot=0.25\baselineskip\relax
+\newskip\normaljot
+\normaljot=0.25\normalsizebaselineskip\relax

 % set \jot
-\jot=\IEEEnormaljot\relax
+\jot=\normaljot\relax


+% abstract and keywords are in \small, except
+% for 9pt docs in which they are in \footnotesize
+% Since 9pt docs use an 8pt footnotesize, \small
+% becomes a rather awkward 8.5pt
+\let\@IEEEabskeysecsize=\small
+\ifx\@IEEEptsize\@IEEEptsizenine
+ \let\@IEEEabskeysecsize=\footnotesize
+\fi
+


 % V1.6, we are now going to fine tune the interword spacing
@@ -702,10 +1072,13 @@
 \@@IEEEsetfontdimens
 }}

-% command to revise the interword spacing for each font size (and shape
-% and weight). Only the \rmfamily is done here as \ttfamily uses a
-% fixed spacing and \sffamily is not used as the main text of IEEE papers.
-\def\@IEEEtunefonts{{\selectfont\rmfamily
+% if the nofonttune class option is not given, revise the interword spacing
+% for each font size (and shape and weight). Only the \rmfamily is done here
+% as \ttfamily uses a fixed spacing and \sffamily is not used as the main
+% text of IEEE papers.
+\def\@IEEEtunefonts{%
+\if@fonttunesettings
+{\selectfont\rmfamily
 \tiny\@IEEEsetfontdimens
 \scriptsize\@IEEEsetfontdimens
 \footnotesize\@IEEEsetfontdimens
@@ -715,17 +1088,14 @@
 \large\@IEEEsetfontdimens
 \LARGE\@IEEEsetfontdimens
 \huge\@IEEEsetfontdimens
-\Huge\@IEEEsetfontdimens}}
+\Huge\@IEEEsetfontdimens}\fi}

-% if the nofonttune class option is not given, revise the interword spacing
-% now - in case IEEEtran makes any default length measurements, and make
-% sure all the default fonts are loaded
-\ifCLASSOPTIONnofonttune\else
+% if needed, revise the interword spacing now - in case IEEEtran makes any default
+% length measurements, and make sure all the default fonts are loaded
 \@IEEEtunefonts
-\fi

 % and again at the start of the document in case the user loaded different fonts
-\AtBeginDocument{\ifCLASSOPTIONnofonttune\else\@IEEEtunefonts\fi}
+\AtBeginDocument{\@IEEEtunefonts}



@@ -744,208 +1114,153 @@
 % IEEE does not use extra spacing after punctuation
 \frenchspacing

-% V1.7 increase this a tad to discourage equation breaks
-\binoppenalty=1000 % default 700
-\relpenalty=800     % default 500


-% margin note stuff
-\marginparsep      10pt
-\marginparwidth    20pt
-\marginparpush     25pt
-
-
-% if things get too close, go ahead and let them touch
-\lineskip            0pt
-\normallineskip      0pt
-\lineskiplimit       0pt
-\normallineskiplimit 0pt
+% we want to maintain textheight as an integer multiple of
+% \baselineskip.  Keep \topsep in with this game plan too.
+\topskip=\baselineskip
+% set sizes and margins
+% Book typesetting is a world where point and pica (12pt) reign supreme.
+% IEEE textwidth is 21 pica. They have a colsep of 1 pica.
+% V1.6 conference mode margins
+\if@confmode
+ \topmargin        -0.25in
+ \textheight        9.25in % The standard for conferences
+  % However, we will adjust this a  tad so that an integer number
+  % of lines will always fit on each page
+  % The baselineskip (leading) for each document point size is used
+  % to determine these values
+  % rounded up an extra 0.1pt or so to prevent trouble with any rounding errors
+ \ifx\@IEEEptsize\@IEEEptsizenine\textheight=674.0pt\fi      %9.3261in  61 lines/page
+ \ifx\@IEEEptsize\@IEEEptsizeten\textheight=672.1pt\fi       %9.2998in  56 lines/page
+ \ifx\@IEEEptsize\@IEEEptsizeeleven\textheight=669.3pt\fi   %9.2611in  50 lines/page
+ \ifx\@IEEEptsize\@IEEEptsizetwelve\textheight=668.3pt\fi   %9.2473in  48 lines/page
+\else
+ \topmargin        -49.0pt
+ \textheight        58pc % = 9.63in or 696pt
+\fi

-% The distance from the lower edge of the text body to the
-% footline
-\footskip 0.4in

-% normally zero, should be relative to font height.
-% put in a little rubber to help stop some bad breaks (underfull vboxes)
-\parskip 0ex plus 0.2ex minus 0.1ex
+\textwidth         43pc   % 2 x 21pc + 1pc = 43pc
+\columnsep          1pc

-\parindent    1.0em

-\topmargin    -49.0pt
-\headheight   12pt
-\headsep      0.25in
+% IEEE MARGIN INFO and new \overrideIEEEmargins command
+% V1.6 revised margins again
+% IEEE wants the side margins to be equal under both US letter
+% and A4 paper
+%
+% However, for those of you who need to bind copies of your work
+% (for review distribution, etc.) the \overrideIEEEmargins
+% command will shift the text a tad away from the binding
+% edge.
+%
+%

-% use the normal font baselineskip
-% so that \topskip is unaffected by changes in \baselinestretch
-\topskip=\@IEEEnormalsizeunitybaselineskip
-\textheight       58pc  % 9.63in, 696pt
-% Tweak textheight to a perfect integer number of lines/page.
-% The normal baselineskip for each document point size is used
-% to determine these values.
-\ifx\CLASSOPTIONpt\@IEEEptsizenine\textheight=63\@IEEEnormalsizeunitybaselineskip\fi      % 63 lines/page
-\ifx\CLASSOPTIONpt\@IEEEptsizeten\textheight=58\@IEEEnormalsizeunitybaselineskip\fi       % 58 lines/page
-\ifx\CLASSOPTIONpt\@IEEEptsizeeleven\textheight=52\@IEEEnormalsizeunitybaselineskip\fi    % 52 lines/page
-\ifx\CLASSOPTIONpt\@IEEEptsizetwelve\textheight=50\@IEEEnormalsizeunitybaselineskip\fi    % 50 lines/page

+% the default side margins are equal
+\oddsidemargin    \@IEEEmarginE
+\addtolength{\oddsidemargin}{-1in}% compensate for LaTeX's 1in offset
+\evensidemargin   \@IEEEmarginE
+\addtolength{\evensidemargin}{-1in}% compensate for LaTeX's 1in offset
+
+% execute \overrideIEEEmargins in the preamble to make the side margin
+% near the spine slightly wider so that the paper will be much more
+% agreeable to being bound.  \overrideIEEEmargins will have no effect
+% when in draft or draftcls mode.
+\def\overrideIEEEmargins{\if@draftclsmode\relax\else%
+ \typeout{** ATTENTION: Overriding IEEE standard margins (line \the\inputlineno).}%
+ \if@twoside
+  % for double sided, odd pages have the bound side on the left
+  % make this the wide margin
+  \oddsidemargin\@IEEEmarginW
+  % and even pages have the narrow margin on the left
+  % as they are bound on the right
+  % evensidemargin is to be the narrow margin
+  % calculate the narrow margin and set evensidemargin
+  \setlength{\evensidemargin}{\paperwidth}%
+  \addtolength{\evensidemargin}{-\@IEEEmarginW}%
+  \addtolength{\evensidemargin}{-\textwidth}%
+ \else
+  % for single sided the bound side is always on the left
+  % make this the wide margin
+  \oddsidemargin\@IEEEmarginW
+  \evensidemargin\@IEEEmarginW
+ \fi
+ \addtolength{\oddsidemargin}{-1.0in}%  compensate for LaTeX's 1in offset
+ \addtolength{\evensidemargin}{-1.0in}%
+\fi}

-\columnsep         1pc
-\textwidth        43pc   % 2 x 21pc + 1pc = 43pc

+\parindent        1.0em

-% the default side margins are equal
-\if@IEEEusingAfourpaper
-\oddsidemargin        14.32mm
-\evensidemargin       14.32mm
+% conference papers do not have headers, other papers need
+% to reserve space for them
+\if@confmode
+\headsep          0in
+\headheight       0in
 \else
-\oddsidemargin        0.680in
-\evensidemargin       0.680in
+\headsep          0.25in
+\headheight       12pt
 \fi
-% compensate for LaTeX's 1in offset
-\addtolength{\oddsidemargin}{-1in}
-\addtolength{\evensidemargin}{-1in}

+% V1.6, if things get too close, go ahead and let them touch
+\lineskip            0pt
+\normallineskip      0pt
+\lineskiplimit       0pt
+\normallineskiplimit 0pt


-% adjust margins for conference mode
-\ifCLASSOPTIONconference
- \topmargin        -0.25in
- % we retain the reserved, but unused space for headers
- \addtolength{\topmargin}{-\headheight}
- \addtolength{\topmargin}{-\headsep}
- \textheight        9.25in % The standard for conferences (668.4975pt)
- % Tweak textheight to a perfect integer number of lines/page.
- \ifx\CLASSOPTIONpt\@IEEEptsizenine\textheight=61\@IEEEnormalsizeunitybaselineskip\fi      % 61 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizeten\textheight=56\@IEEEnormalsizeunitybaselineskip\fi       % 56 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizeeleven\textheight=50\@IEEEnormalsizeunitybaselineskip\fi    % 50 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizetwelve\textheight=48\@IEEEnormalsizeunitybaselineskip\fi    % 48 lines/page
-\fi
-
+% The distance from the lower edge of the text body to the
+% footline
+\footskip 0.4in

-% compsoc conference
-\ifCLASSOPTIONcompsoc
-\ifCLASSOPTIONconference
- % compsoc conference use a larger value for columnsep
- \columnsep 0.375in
- % compsoc conferences want 1in top margin, 1.125in bottom margin
- \topmargin        0in
- \addtolength{\topmargin}{-6pt}% we tweak this a tad to better comply with top of line stuff
- % we retain the reserved, but unused space for headers
- \addtolength{\topmargin}{-\headheight}
- \addtolength{\topmargin}{-\headsep}
- \textheight        8.875in % (641.39625pt)
- % Tweak textheight to a perfect integer number of lines/page.
- \ifx\CLASSOPTIONpt\@IEEEptsizenine\textheight=58\@IEEEnormalsizeunitybaselineskip\fi      % 58 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizeten\textheight=53\@IEEEnormalsizeunitybaselineskip\fi       % 53 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizeeleven\textheight=48\@IEEEnormalsizeunitybaselineskip\fi    % 48 lines/page
- \ifx\CLASSOPTIONpt\@IEEEptsizetwelve\textheight=46\@IEEEnormalsizeunitybaselineskip\fi    % 46 lines/page
- \textwidth 6.5in
- % the default side margins are equal
- \if@IEEEusingAfourpaper
-  \oddsidemargin        22.45mm
-  \evensidemargin       22.45mm
- \else
-  \oddsidemargin        1in
-  \evensidemargin       1in
- \fi
- % compensate for LaTeX's 1in offset
- \addtolength{\oddsidemargin}{-1in}
- \addtolength{\evensidemargin}{-1in}
-\fi\fi
+% normally zero, should be relative to font height.
+% put in a little rubber to help stop some bad breaks (underfull vboxes)
+\parskip 0ex plus 0.2ex minus 0.1ex



 % draft mode settings override that of all other modes
-% provides a nice 1in margin all around the paper and extra
+% provides a nice 1" margin all around the paper and extra
 % space between the lines for editor's comments
-\ifCLASSOPTIONdraftcls
-  % want 1in from top of paper to text
+\if@draftclsmode
+\headsep          0.25in
+\headheight       12pt
+% want 1" from top of paper to text
   \setlength{\topmargin}{-\headsep}%
   \addtolength{\topmargin}{-\headheight}%
+
   % we want 1in side margins regardless of paper type
   \oddsidemargin      0in
   \evensidemargin     0in
-  % set the text width
+
+% set the text width - start with the entire page
   \setlength{\textwidth}{\paperwidth}%
+% subtract for the 1" top/bottom margins
   \addtolength{\textwidth}{-2.0in}%
+% give them a textheight that won't have underfull
+% vbox problems, but can't help them if they later change
+% baselinestretch from its default
   \setlength{\textheight}{\paperheight}%
   \addtolength{\textheight}{-2.0in}%
-  % digitize textheight to be an integer number of lines.
-  % this may cause the bottom margin to be off a tad
+% subtract of first line taken by \topskip
   \addtolength{\textheight}{-1\topskip}%
+% now digitize \textheight so that the length after
+% the first line is an integer multiple of  \baselineskip
+% to cut down on underfull vbox errors in draft mode
   \divide\textheight  by \baselineskip%
   \multiply\textheight  by \baselineskip%
+% add back the first line
   \addtolength{\textheight}{\topskip}%
 \fi



-% process CLASSINPUT inner/outer margin
-% if inner margin defined, but outer margin not, set outer to inner.
-\ifx\CLASSINPUTinnersidemargin\@IEEEundefined
-\else
-  \ifx\CLASSINPUToutersidemargin\@IEEEundefined
-    \edef\CLASSINPUToutersidemargin{\CLASSINPUTinnersidemargin}
-  \fi
-\fi
-
-\ifx\CLASSINPUToutersidemargin\@IEEEundefined
-\else
-  % if outer margin defined, but inner margin not, set inner to outer.
-  \ifx\CLASSINPUTinnersidemargin\@IEEEundefined
-    \edef\CLASSINPUTinnersidemargin{\CLASSINPUToutersidemargin}
-  \fi
-  \setlength{\oddsidemargin}{\CLASSINPUTinnersidemargin}
-  \ifCLASSOPTIONtwoside
-    \setlength{\evensidemargin}{\CLASSINPUToutersidemargin}
-  \else
-    \setlength{\evensidemargin}{\CLASSINPUTinnersidemargin}
-  \fi
-  \addtolength{\oddsidemargin}{-1in}
-  \addtolength{\evensidemargin}{-1in}
-  \setlength{\textwidth}{\paperwidth}
-  \addtolength{\textwidth}{-\CLASSINPUTinnersidemargin}
-  \addtolength{\textwidth}{-\CLASSINPUToutersidemargin}
-  \typeout{** ATTENTION: Overriding inner side margin to \CLASSINPUTinnersidemargin\space and
-           outer side margin to \CLASSINPUToutersidemargin\space via \string\CLASSINPUT.}
-\fi
-
-
-
-% process CLASSINPUT top/bottom text margin
-% if toptext margin defined, but bottomtext margin not, set bottomtext to toptext margin
-\ifx\CLASSINPUTtoptextmargin\@IEEEundefined
-\else
-  \ifx\CLASSINPUTbottomtextmargin\@IEEEundefined
-    \edef\CLASSINPUTbottomtextmargin{\CLASSINPUTtoptextmargin}
-  \fi
-\fi
-
-\ifx\CLASSINPUTbottomtextmargin\@IEEEundefined
-\else
-  % if bottomtext margin defined, but toptext margin not, set toptext to bottomtext margin
-  \ifx\CLASSINPUTtoptextmargin\@IEEEundefined
-    \edef\CLASSINPUTtoptextmargin{\CLASSINPUTbottomtextmargin}
-  \fi
-  \setlength{\topmargin}{\CLASSINPUTtoptextmargin}
-  \addtolength{\topmargin}{-1in}
-  \addtolength{\topmargin}{-\headheight}
-  \addtolength{\topmargin}{-\headsep}
-  \setlength{\textheight}{\paperheight}
-  \addtolength{\textheight}{-\CLASSINPUTtoptextmargin}
-  \addtolength{\textheight}{-\CLASSINPUTbottomtextmargin}
-  % in the default format we use the normal baselineskip as topskip
-  % we only need 0.7 of this to clear typical top text and we need
-  % an extra 0.3 spacing at the bottom for descenders. This will
-  % correct for both.
-  \addtolength{\topmargin}{-0.3\@IEEEnormalsizeunitybaselineskip}
-  \typeout{** ATTENTION: Overriding top text margin to \CLASSINPUTtoptextmargin\space and
-           bottom text margin to \CLASSINPUTbottomtextmargin\space via \string\CLASSINPUT.}
-\fi
-
-
-
-
-
+% margin note stuff
+\marginparsep      10pt
+\marginparwidth    20pt
+\marginparpush     25pt


 % LIST SPACING CONTROLS
@@ -1054,6 +1369,16 @@
 \def\labelitemiv{$\cdot$}


+% IEEEtran.cls version numbers, provided as of V1.3
+% These values serve as a way a .tex file can
+% determine if the new features are provided.
+% The version number of this IEEEtrans.cls can be obtained from
+% these values. i.e., V1.4
+% KEEP THESE AS INTEGERS! i.e., NO {4a} or anything like that-
+% (no need to enumerate "a" minor changes here)
+\def\IEEEtransversionmajor{1}
+\def\IEEEtransversionminor{6}
+

 % **** V1.3 ENHANCEMENTS ****
 % Itemize, Enumerate and Description (IED) List Controls
@@ -1096,14 +1421,14 @@
 % The IED environments automatically set its value to
 % one of the three values above, so global changes do
 % not have any effect
-\newdimen\IEEElabelindent
-\IEEElabelindent \parindent
+\newdimen\labelindent
+\labelindent \parindent

 % The actual amount labels will be indented is
-% \IEEElabelindent multiplied by the factor below
+% \labelindent multiplied by the factor below
 % corresponding to the level of nesting depth
 % This provides a means by which the user can
-% alter the effective \IEEElabelindent for deeper
+% alter the effective \labelindent for deeper
 % levels
 % There may not be such a thing as correct "standard IEEE"
 % values. What IEEE actually does may depend on the specific
@@ -1122,7 +1447,7 @@
 % value actually used within IED lists, it is auto
 % set to one of the 6 values above
 % global changes here have no effect
-\def\IEEElabelindentfactor{1.0}
+\def\labelindentfactor{1.0}

 % This controls the default spacing between the end of the IED
 % list labels and the list text, when normal text is used for
@@ -1148,18 +1473,18 @@
 % at the beginning of the list. You can use this to set the
 % parameters for some/all your IED list(s) without disturbing
 % global parameters that affect things other than lists.
-% i.e., renewcommand{\IEEEiedlistdecl}{\setlength{\labelsep}{5em}}
+% i.e., renewcommand{\iedlistdecl}{\setlength{\labelsep}{5em}}
 % will alter the \labelsep for the next list(s) until
-% \IEEEiedlistdecl is redefined.
-\def\IEEEiedlistdecl{\relax}
+% \iedlistdecl is redefined.
+\def\iedlistdecl{\relax}

 % This command provides an easy way to set \leftmargin based
-% on the \labelwidth, \labelsep and the argument \IEEElabelindent
-% Usage: \IEEEcalcleftmargin{width-to-indent-the-label}
+% on the \labelwidth, \labelsep and the argument \labelindent
+% Usage: \calcleftmargin{width-to-indent-the-label}
 % output is in the \leftmargin variable, i.e., effectively:
 % \leftmargin = argument + \labelwidth + \labelsep
 % Note controlled spacing here, shield end of lines with %
-\def\IEEEcalcleftmargin#1{\setlength{\leftmargin}{#1}%
+\def\calcleftmargin#1{\setlength{\leftmargin}{#1}%
 \addtolength{\leftmargin}{\labelwidth}%
 \addtolength{\leftmargin}{\labelsep}}

@@ -1169,41 +1494,41 @@
 % and useful as a shorter alternative.
 % Typically used to set \labelwidth to be the width
 % of the longest label in the list
-\def\IEEEsetlabelwidth#1{\settowidth{\labelwidth}{#1}}
+\def\setlabelwidth#1{\settowidth{\labelwidth}{#1}}

 % When this command is executed, IED lists will use the
 % IEEEiedmathlabelsep label separation rather than the normal
 % spacing. To have an effect, this command must be executed via
-% the \IEEEiedlistdecl or within the option of the IED list
+% the \iedlistdecl or within the option of the IED list
 % environments.
-\def\IEEEusemathlabelsep{\setlength{\labelsep}{\IEEEiedmathlabelsep}}
+\def\usemathlabelsep{\setlength{\labelsep}{\IEEEiedmathlabelsep}}

 % A flag which controls whether the IED lists automatically
-% calculate \leftmargin from \IEEElabelindent, \labelwidth and \labelsep
+% calculate \leftmargin from \labelindent, \labelwidth and \labelsep
 % Useful if you want to specify your own \leftmargin
-% This flag must be set (\IEEEnocalcleftmargintrue or \IEEEnocalcleftmarginfalse)
-% via the \IEEEiedlistdecl or within the option of the IED list
+% This flag must be set (\nocalcleftmargintrue or \nocalcleftmarginfalse)
+% via the \iedlistdecl or within the option of the IED list
 % environments to have an effect.
-\newif\ifIEEEnocalcleftmargin
-\IEEEnocalcleftmarginfalse
+\newif\ifnocalcleftmargin
+\nocalcleftmarginfalse

-% A flag which controls whether \IEEElabelindent is multiplied by
-% the \IEEElabelindentfactor for each list level.
-% This flag must be set via the \IEEEiedlistdecl or within the option
+% A flag which controls whether \labelindent is multiplied by
+% the \labelindentfactor for each list level.
+% This flag must be set via the \iedlistdecl or within the option
 % of the IED list environments to have an effect.
-\newif\ifIEEEnolabelindentfactor
-\IEEEnolabelindentfactorfalse
+\newif\ifnolabelindentfactor
+\nolabelindentfactorfalse


 % internal variable to indicate type of IED label
 % justification
 % 0 - left; 1 - center; 2 - right
-\def\@IEEEiedjustify{0}
+\def\@iedjustify{0}


 % commands to allow the user to control IED
 % label justifications. Use these commands within
-% the IED environment option or in the \IEEEiedlistdecl
+% the IED environment option or in the \iedlistdecl
 % Note that changing the normal list justifications
 % is nonstandard and IEEE may not like it if you do so!
 % I include these commands as they may be helpful to
@@ -1211,9 +1536,9 @@
 % other non-IEEE related LaTeX work.
 % itemize and enumerate automatically default to right
 % justification, description defaults to left.
-\def\IEEEiedlabeljustifyl{\def\@IEEEiedjustify{0}}%left
-\def\IEEEiedlabeljustifyc{\def\@IEEEiedjustify{1}}%center
-\def\IEEEiedlabeljustifyr{\def\@IEEEiedjustify{2}}%right
+\def\iedlabeljustifyl{\def\@iedjustify{0}}%left
+\def\iedlabeljustifyc{\def\@iedjustify{1}}%center
+\def\iedlabeljustifyr{\def\@iedjustify{2}}%right



@@ -1305,14 +1630,14 @@
                 \edef\@itemitem{labelitem\romannumeral\the\@itemdepth}%
                 % get the labelindentfactor for this level
                 \advance\@listdepth\@ne% we need to know what the level WILL be
-                \edef\IEEElabelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
+                \edef\labelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
                 \advance\@listdepth-\@ne% undo our increment
-                \def\@IEEEiedjustify{2}% right justified labels are default
+                \def\@iedjustify{2}% right justified labels are default
                 % set other defaults
-                \IEEEnocalcleftmarginfalse%
-                \IEEEnolabelindentfactorfalse%
+                \nocalcleftmarginfalse%
+                \nolabelindentfactorfalse%
                 \topsep\IEEEiedtopsep%
-                \IEEElabelindent\IEEEilabelindent%
+                \labelindent\IEEEilabelindent%
                 \labelsep\IEEEiednormlabelsep%
                 \partopsep 0ex%
                 \parsep 0ex%
@@ -1329,19 +1654,19 @@
                 \@IEEErestorelistparams% override any list{} changes
                                        % to our globals
                 \let\makelabel\@IEEEiedmakelabel% v1.6b setup \makelabel
-                \IEEEiedlistdecl% let user alter parameters
+                \iedlistdecl% let user alter parameters
                 #1\relax%
                 % If the user has requested not to use the
                 % labelindent factor, don't revise \labelindent
-                \ifIEEEnolabelindentfactor\relax%
-                \else\IEEElabelindent=\IEEElabelindentfactor\labelindent%
+                \ifnolabelindentfactor\relax%
+                \else\labelindent=\labelindentfactor\labelindent%
                 \fi%
                 % Unless the user has requested otherwise,
                 % calculate our left margin based
-                % on \IEEElabelindent, \labelwidth and
+                % on \labelindent, \labelwidth and
                 % \labelsep
-                \ifIEEEnocalcleftmargin\relax%
-                \else\IEEEcalcleftmargin{\IEEElabelindent}%
+                \ifnocalcleftmargin\relax%
+                \else\calcleftmargin{\labelindent}%
                 \fi}\fi\fi}%


@@ -1356,14 +1681,14 @@
                 \edef\@enumctr{enum\romannumeral\the\@enumdepth}%
                 % get the labelindentfactor for this level
                 \advance\@listdepth\@ne% we need to know what the level WILL be
-                \edef\IEEElabelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
+                \edef\labelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
                 \advance\@listdepth-\@ne% undo our increment
-                \def\@IEEEiedjustify{2}% right justified labels are default
+                \def\@iedjustify{2}% right justified labels are default
                 % set other defaults
-                \IEEEnocalcleftmarginfalse%
-                \IEEEnolabelindentfactorfalse%
+                \nocalcleftmarginfalse%
+                \nolabelindentfactorfalse%
                 \topsep\IEEEiedtopsep%
-                \IEEElabelindent\IEEEelabelindent%
+                \labelindent\IEEEelabelindent%
                 \labelsep\IEEEiednormlabelsep%
                 \partopsep 0ex%
                 \parsep 0ex%
@@ -1381,19 +1706,19 @@
                 \@IEEErestorelistparams% override any list{} changes
                                        % to our globals
                 \let\makelabel\@IEEEiedmakelabel% v1.6b setup \makelabel
-                \IEEEiedlistdecl% let user alter parameters
+                \iedlistdecl% let user alter parameters
                 #1\relax%
                 % If the user has requested not to use the
-                % IEEElabelindent factor, don't revise \IEEElabelindent
-                \ifIEEEnolabelindentfactor\relax%
-                \else\IEEElabelindent=\IEEElabelindentfactor\IEEElabelindent%
+                % labelindent factor, don't revise \labelindent
+                \ifnolabelindentfactor\relax%
+                \else\labelindent=\labelindentfactor\labelindent%
                 \fi%
                 % Unless the user has requested otherwise,
                 % calculate our left margin based
-                % on \IEEElabelindent, \labelwidth and
+                % on \labelindent, \labelwidth and
                 % \labelsep
-                \ifIEEEnocalcleftmargin\relax%
-                \else\IEEEcalcleftmargin{\IEEElabelindent}%
+                \ifnocalcleftmargin\relax%
+                \else\calcleftmargin{\labelindent}%
                 \fi}\fi\fi}%


@@ -1405,14 +1730,14 @@
                 \ifnum\@listdepth>5\relax\@toodeep\else%
                 % get the labelindentfactor for this level
                 \advance\@listdepth\@ne% we need to know what the level WILL be
-                \edef\IEEElabelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
+                \edef\labelindentfactor{\csname IEEElabelindentfactor\romannumeral\the\@listdepth\endcsname}%
                 \advance\@listdepth-\@ne% undo our increment
-                \def\@IEEEiedjustify{0}% left justified labels are default
+                \def\@iedjustify{0}% left justified labels are default
                 % set other defaults
-                \IEEEnocalcleftmarginfalse%
-                \IEEEnolabelindentfactorfalse%
+                \nocalcleftmarginfalse%
+                \nolabelindentfactorfalse%
                 \topsep\IEEEiedtopsep%
-                \IEEElabelindent\IEEEdlabelindent%
+                \labelindent\IEEEdlabelindent%
                 % assume normal labelsep
                 \labelsep\IEEEiednormlabelsep%
                 \partopsep 0ex%
@@ -1433,40 +1758,39 @@
                 \list{}{\@IEEErestorelistparams% override any list{} changes
                                                % to our globals
                 \let\makelabel\@IEEEiedmakelabel% v1.6b setup \makelabel
-                \IEEEiedlistdecl% let user alter parameters
+                \iedlistdecl% let user alter parameters
                 #1\relax%
                 % If the user has requested not to use the
-                % labelindent factor, don't revise \IEEElabelindent
-                \ifIEEEnolabelindentfactor\relax%
-                \else\IEEElabelindent=\IEEElabelindentfactor\IEEElabelindent%
+                % labelindent factor, don't revise \labelindent
+                \ifnolabelindentfactor\relax%
+                \else\labelindent=\labelindentfactor\labelindent%
                 \fi%
                 % Unless the user has requested otherwise,
                 % calculate our left margin based
-                % on \IEEElabelindent, \labelwidth and
+                % on \labelindent, \labelwidth and
                 % \labelsep
-                \ifIEEEnocalcleftmargin\relax%
-                \else\IEEEcalcleftmargin{\IEEElabelindent}\relax%
+                \ifnocalcleftmargin\relax%
+                \else\calcleftmargin{\labelindent}\relax%
                 \fi}\fi}

 % v1.6b we use one makelabel that does justification as needed.
-\def\@IEEEiedmakelabel#1{\relax\if\@IEEEiedjustify 0\relax
+\def\@IEEEiedmakelabel#1{\relax\if\@iedjustify 0\relax
 \makebox[\labelwidth][l]{\normalfont #1}\else
-\if\@IEEEiedjustify 1\relax
+\if\@iedjustify 1\relax
 \makebox[\labelwidth][c]{\normalfont #1}\else
 \makebox[\labelwidth][r]{\normalfont #1}\fi\fi}


 % VERSE and QUOTE
-% V1.7 define environments with newenvironment
-\newenvironment{verse}{\let\\=\@centercr
+\def\verse{\let\\=\@centercr
     \list{}{\itemsep\z@ \itemindent -1.5em \listparindent \itemindent
-    \rightmargin\leftmargin\advance\leftmargin 1.5em}\item\relax}
-    {\endlist}
-\newenvironment{quotation}{\list{}{\listparindent 1.5em \itemindent\listparindent
-    \rightmargin\leftmargin \parsep 0pt plus 1pt}\item\relax}
-    {\endlist}
-\newenvironment{quote}{\list{}{\rightmargin\leftmargin}\item\relax}
-    {\endlist}
+    \rightmargin\leftmargin\advance\leftmargin 1.5em}\item[]}
+\let\endverse\endlist
+\def\quotation{\list{}{\listparindent 1.5em \itemindent\listparindent
+    \rightmargin\leftmargin \parsep 0pt plus 1pt}\item[]}
+\let\endquotation=\endlist
+\def\quote{\list{}{\rightmargin\leftmargin}\item[]}
+\let\endquote=\endlist


 % \titlepage
@@ -1503,8 +1827,8 @@
 % use 0.7/baselineskip as a \footnotesep to maintain equal spacing
 % between all the lines of the footnotes. IEEE often uses a tad
 % more, so use 0.8\baselineskip. This slightly larger value also helps
-% the text to clear the footnote marks. Note that \thanks in IEEEtran
-% uses its own value of \footnotesep which is set in \maketitle.
+% the text to clear the footnote marks. Note that \thanks now uses
+% its own value of \footnotesep.
 {\footnotesize
 \global\footnotesep 0.8\baselineskip}

@@ -1512,34 +1836,13 @@
 \skip\@mpfootins = \skip\footins
 \fboxsep = 3pt
 \fboxrule = .4pt
-% V1.6 use 1em, then use LaTeX2e's \@makefnmark
+% V1.6 use 1em, the use LaTeX2e's \@makefnmark
 % Note that IEEE normally *left* aligns the footnote marks, so we don't need
 % box resizing tricks here.
 \long\def\@makefntext#1{\parindent 1em\indent\hbox{\@makefnmark}#1}% V1.6 use 1em
-% V1.7 compsoc does not use superscipts for footnote marks
-\ifCLASSOPTIONcompsoc
-\def\@IEEEcompsocmakefnmark{\hbox{\normalfont\@thefnmark.\ }}
-\long\def\@makefntext#1{\parindent 1em\indent\hbox{\@IEEEcompsocmakefnmark}#1}
-\fi

-% IEEE does not use footnote rules
 \def\footnoterule{}

-% V1.7 for compsoc, IEEE uses a footnote rule only for \thanks. We devise a "one-shot"
-% system to implement this.
-\newif\if@IEEEenableoneshotfootnoterule
-\@IEEEenableoneshotfootnoterulefalse
-\ifCLASSOPTIONcompsoc
-\def\footnoterule{\relax\if@IEEEenableoneshotfootnoterule
-\kern-5pt
-\hbox to \columnwidth{\hfill\vrule width 0.5\columnwidth height 0.4pt\hfill}
-\kern4.6pt
-\global\@IEEEenableoneshotfootnoterulefalse
-\else
-\relax
-\fi}
-\fi
-
 % V1.6 do not allow LaTeX to break a footnote across multiple pages
 \interfootnotelinepenalty=10000

@@ -1548,15 +1851,12 @@
 % but LaTeX2e normally uses 100.
 \interdisplaylinepenalty=2500

-% default allows section depth up to /paragraph
-\setcounter{secnumdepth}{4}

-% technotes do not allow /paragraph
-\ifCLASSOPTIONtechnote
+\if@technote
    \setcounter{secnumdepth}{3}
+\else
+   \setcounter{secnumdepth}{4}
 \fi
-% neither do compsoc conferences
-\@IEEEcompsocconfonly{\setcounter{secnumdepth}{3}}


 \newcounter{section}
@@ -1569,53 +1869,20 @@
 \newcounter{IEEEsubequation}[equation]

 % as shown when called by user from \ref, \label and in table of contents
+\def\thesection{\Roman{section}}                             % I
+\def\thesubsection{\thesection-\Alph{subsection}}            % I-A
+\def\thesubsubsection{\thesubsection.\arabic{subsubsection}} % I-A.1
+\def\theparagraph{\thesubsubsection.\alph{paragraph}}        % I-A.1.a
 \def\theequation{\arabic{equation}}                          % 1
 \def\theIEEEsubequation{\theequation\alph{IEEEsubequation}}  % 1a (used only by IEEEtran's IEEEeqnarray)
-\ifCLASSOPTIONcompsoc
-% compsoc is all arabic
-\def\thesection{\arabic{section}}
-\def\thesubsection{\thesection.\arabic{subsection}}
-\def\thesubsubsection{\thesubsection.\arabic{subsubsection}}
-\def\theparagraph{\thesubsubsection.\arabic{paragraph}}
-\else
-\def\thesection{\Roman{section}}                             % I
-% V1.7, \mbox prevents breaks around -
-\def\thesubsection{\mbox{\thesection-\Alph{subsection}}}     % I-A
-% V1.7 use I-A1 format used by IEEE rather than I-A.1
-\def\thesubsubsection{\thesubsection\arabic{subsubsection}}  % I-A1
-\def\theparagraph{\thesubsubsection\alph{paragraph}}         % I-A1a
-\fi
-
-% From Heiko Oberdiek. Because of the \mbox in \thesubsection, we need to
-% tell hyperref to disable the \mbox command when making PDF bookmarks.
-% This done already with hyperref.sty version 6.74o and later, but
-% it will not hurt to do it here again for users of older versions.
-\@ifundefined{pdfstringdefPreHook}{\let\pdfstringdefPreHook\@empty}{}%
-\g@addto@macro\pdfstringdefPreHook{\let\mbox\relax}
-

 % Main text forms (how shown in main text headings)
 % V1.6, using \thesection in \thesectiondis allows changes
 % in the former to automatically appear in the latter
-\ifCLASSOPTIONcompsoc
-  \ifCLASSOPTIONconference% compsoc conference
-    \def\thesectiondis{\thesection.}
-    \def\thesubsectiondis{\thesectiondis\arabic{subsection}.}
-    \def\thesubsubsectiondis{\thesubsectiondis\arabic{subsubsection}.}
-    \def\theparagraphdis{\thesubsubsectiondis\arabic{paragraph}.}
-  \else% compsoc not conferencs
-    \def\thesectiondis{\thesection}
-    \def\thesubsectiondis{\thesectiondis.\arabic{subsection}}
-    \def\thesubsubsectiondis{\thesubsectiondis.\arabic{subsubsection}}
-    \def\theparagraphdis{\thesubsubsectiondis.\arabic{paragraph}}
-  \fi
-\else% not compsoc
   \def\thesectiondis{\thesection.}                   % I.
   \def\thesubsectiondis{\Alph{subsection}.}          % B.
   \def\thesubsubsectiondis{\arabic{subsubsection})}  % 3)
   \def\theparagraphdis{\alph{paragraph})}            % d)
-\fi
-
 % just like LaTeX2e's \@eqnnum
 \def\theequationdis{{\normalfont \normalcolor (\theequation)}}% (1)
 % IEEEsubequation used only by IEEEtran's IEEEeqnarray
@@ -1624,25 +1891,6 @@
 % it, through IEEEtran's \theequationdis
 \def\@eqnnum{\theequationdis}

-
-
-% V1.7 provide string macros as article.cls does
-\def\contentsname{Contents}
-\def\listfigurename{List of Figures}
-\def\listtablename{List of Tables}
-\def\refname{References}
-\def\indexname{Index}
-\def\figurename{Fig.}
-\def\tablename{TABLE}
-\@IEEEcompsocconfonly{\def\figurename{Figure}\def\tablename{Table}}
-\def\partname{Part}
-\def\appendixname{Appendix}
-\def\abstractname{Abstract}
-% IEEE specific names
-\def\IEEEkeywordsname{Index Terms}
-\def\IEEEproofname{Proof}
-
-
 % LIST OF FIGURES AND TABLES AND TABLE OF CONTENTS
 %
 \def\@pnumwidth{1.55em}
@@ -1654,7 +1902,7 @@
 % collide with the section titles.
 % VIII; VIII-A; and VIII-A.1 are usually the worst offenders.
 % MDS 1/2001
-\def\tableofcontents{\section*{\contentsname}\@starttoc{toc}}
+\def\tableofcontents{\section*{Contents}\@starttoc{toc}}
 \def\l@section#1#2{\addpenalty{\@secpenalty}\addvspace{1.0em plus 1pt}%
     \@tempdima 2.75em \begingroup \parindent \z@ \rightskip \@pnumwidth%
     \parfillskip-\@pnumwidth {\bfseries\leavevmode #1}\hfil\hbox to\@pnumwidth{\hss #2}\par%
@@ -1667,9 +1915,9 @@
 % these defs are how TOC knows what level these things are!
 \def\l@paragraph{\@dottedtocline{4}{6.5em}{5.5em}}
 \def\l@subparagraph{\@dottedtocline{5}{6.5em}{6.5em}}
-\def\listoffigures{\section*{\listfigurename}\@starttoc{lof}}
+\def\listoffigures{\section*{List of Figures}\@starttoc{lof}}
 \def\l@figure{\@dottedtocline{1}{0em}{2.75em}}
-\def\listoftables{\section*{\listtablename}\@starttoc{lot}}
+\def\listoftables{\section*{List of Tables}\@starttoc{lot}}
 \let\l@table\l@figure


@@ -1681,11 +1929,10 @@
 \@fptop 0pt plus 1fil
 \@fpsep 0.75\baselineskip plus 2fil
 \@fpbot 0pt plus 1fil
-\def\topfraction{0.9}
-\def\bottomfraction{0.4}
+\def\topfraction{1.0}
+\def\bottomfraction{.4}
 \def\floatpagefraction{0.8}
-% V1.7, let top floats approach 90% of page
-\def\textfraction{0.1}
+\def\textfraction{.2}

 %% Double Column Floats
 \dblfloatsep 1\baselineskip plus  0.2\baselineskip minus  0.2\baselineskip
@@ -1704,7 +1951,7 @@
 \@dblfptop 0pt plus 1fil
 \@dblfpsep 0.75\baselineskip plus 2fil
 \@dblfpbot 0pt plus 1fil
-\def\dbltopfraction{0.8}
+\def\dbltopfraction{1.0}
 \def\dblfloatpagefraction{0.8}
 \setcounter{dbltopnumber}{4}

@@ -1714,6 +1961,16 @@
 \setcounter{totalnumber}{4}


+%% redefine CAPTION
+% V1.4 add user control for short figure caption justification
+\newif\ifcenterfigcaptions
+
+% V1.6 set the default according to conference mode
+\if@confmode
+\centerfigcaptionstrue
+\else
+\centerfigcaptionsfalse
+\fi

 % article class provides these, we should too.
 \newlength\abovecaptionskip
@@ -1732,112 +1989,49 @@
 % as with LaTeX2e. Otherwise, there will be problems when using hyperref.
 \def\@IEEEtablestring{table}

-\ifCLASSOPTIONcompsoc
-% V1.7 compsoc \@makecaption
-\ifCLASSOPTIONconference% compsoc conference
 \long\def\@makecaption#1#2{%
 % test if is a for a figure or table
 \ifx\@captype\@IEEEtablestring%
 % if a table, do table caption
-\normalsize\begin{center}{\normalfont\sffamily\normalsize {#1.}~ #2}\end{center}%
-\@IEEEtablecaptionsepspace
+\begin{center}{\footnotesize #1}\\{\footnotesize\scshape #2}\end{center}%
+\@IEEEtablecaptionsepspace% V1.6 was a hard coded 8pt
 % if not a table, format it as a figure
 \else
-\@IEEEfigurecaptionsepspace
-\setbox\@tempboxa\hbox{\normalfont\sffamily\normalsize {#1.}~ #2}%
-\ifdim \wd\@tempboxa >\hsize%
-% if caption is longer than a line, let it wrap around
-\setbox\@tempboxa\hbox{\normalfont\sffamily\normalsize {#1.}~ }%
-\parbox[t]{\hsize}{\normalfont\sffamily\normalsize \noindent\unhbox\@tempboxa#2}%
-% if caption is shorter than a line, center
-\else%
-\hbox to\hsize{\normalfont\sffamily\normalsize\hfil\box\@tempboxa\hfil}%
-\fi\fi}
-\else% nonconference compsoc
-\long\def\@makecaption#1#2{%
-% test if is a for a figure or table
-\ifx\@captype\@IEEEtablestring%
-% if a table, do table caption
-\normalsize\begin{center}{\normalfont\sffamily\normalsize #1}\\{\normalfont\sffamily\normalsize #2}\end{center}%
-\@IEEEtablecaptionsepspace
-% if not a table, format it as a figure
-\else
-\@IEEEfigurecaptionsepspace
-\setbox\@tempboxa\hbox{\normalfont\sffamily\normalsize {#1.}~ #2}%
-\ifdim \wd\@tempboxa >\hsize%
-% if caption is longer than a line, let it wrap around
-\setbox\@tempboxa\hbox{\normalfont\sffamily\normalsize {#1.}~ }%
-\parbox[t]{\hsize}{\normalfont\sffamily\normalsize \noindent\unhbox\@tempboxa#2}%
-% if caption is shorter than a line, left justify
-\else%
-\hbox to\hsize{\normalfont\sffamily\normalsize\box\@tempboxa\hfil}%
-\fi\fi}
-\fi
-
-\else% traditional noncompsoc \@makecaption
-\long\def\@makecaption#1#2{%
-% test if is a for a figure or table
-\ifx\@captype\@IEEEtablestring%
-% if a table, do table caption
-\footnotesize\begin{center}{\normalfont\footnotesize #1}\\{\normalfont\footnotesize\scshape #2}\end{center}%
-\@IEEEtablecaptionsepspace
-% if not a table, format it as a figure
-\else
-\@IEEEfigurecaptionsepspace
+\@IEEEfigurecaptionsepspace% V1.6 was a hard coded 5pt
 % 3/2001 use footnotesize, not small; use two nonbreaking spaces, not one
-\setbox\@tempboxa\hbox{\normalfont\footnotesize {#1.}~~ #2}%
+\setbox\@tempboxa\hbox{\footnotesize #1.~~ #2}%
 \ifdim \wd\@tempboxa >\hsize%
 % if caption is longer than a line, let it wrap around
-\setbox\@tempboxa\hbox{\normalfont\footnotesize {#1.}~~ }%
-\parbox[t]{\hsize}{\normalfont\footnotesize\noindent\unhbox\@tempboxa#2}%
-% if caption is shorter than a line, center if conference, left justify otherwise
+\setbox\@tempboxa\hbox{\footnotesize #1.~~ }%
+\parbox[t]{\hsize}{\footnotesize \noindent\unhbox\@tempboxa#2}%
+% if caption is shorter than a line,
+% allow user to control short figure caption justification (left or center)
 \else%
-\ifCLASSOPTIONconference \hbox to\hsize{\normalfont\footnotesize\hfil\box\@tempboxa\hfil}%
-\else \hbox to\hsize{\normalfont\footnotesize\box\@tempboxa\hfil}%
+\ifcenterfigcaptions \hbox to\hsize{\footnotesize\hfil\box\@tempboxa\hfil}%
+\else \hbox to\hsize{\footnotesize\box\@tempboxa\hfil}%
 \fi\fi\fi}
-\fi
-


-% V1.7 disable captions class option, do so in a way that retains operation of \label
-% within \caption
-\ifCLASSOPTIONcaptionsoff
-\long\def\@makecaption#1#2{\vspace*{2em}\footnotesize\begin{center}{\footnotesize #1}\end{center}%
-\let\@IEEEtemporiglabeldefsave\label
-\let\@IEEEtemplabelargsave\relax
-\def\label##1{\gdef\@IEEEtemplabelargsave{##1}}%
-\setbox\@tempboxa\hbox{#2}%
-\let\label\@IEEEtemporiglabeldefsave
-\ifx\@IEEEtemplabelargsave\relax\else\label{\@IEEEtemplabelargsave}\fi}
-\fi
-
-
-% V1.7 define end environments with \def not \let so as to work OK with
-% preview-latex
 \newcounter{figure}
 \def\thefigure{\@arabic\c@figure}
 \def\fps@figure{tbp}
 \def\ftype@figure{1}
 \def\ext@figure{lof}
-\def\fnum@figure{\figurename~\thefigure}
+\def\fnum@figure{Fig.~\thefigure}
 \def\figure{\@float{figure}}
-\def\endfigure{\end@float}
+\let\endfigure\end@float
 \@namedef{figure*}{\@dblfloat{figure}}
 \@namedef{endfigure*}{\end@dblfloat}
 \newcounter{table}
-\ifCLASSOPTIONcompsoc
-\def\thetable{\arabic{table}}
-\else
 \def\thetable{\@Roman\c@table}
-\fi
 \def\fps@table{tbp}
 \def\ftype@table{2}
 \def\ext@table{lot}
-\def\fnum@table{\tablename~\thetable}
+\def\fnum@table{TABLE~\thetable}
 % V1.6 IEEE uses 8pt text for tables
 % to default to footnotesize, we hack into LaTeX2e's \@floatboxreset and pray
 \def\table{\def\@floatboxreset{\reset@font\footnotesize\@setminipage}\@float{table}}
-\def\endtable{\end@float}
+\let\endtable\end@float
 % v1.6b double column tables need to default to footnotesize as well.
 \@namedef{table*}{\def\@floatboxreset{\reset@font\footnotesize\@setminipage}\@dblfloat{table}}
 \@namedef{endtable*}{\end@dblfloat}
@@ -2405,7 +2599,7 @@
    \lineskip=0pt\relax
    \lineskiplimit=0pt\relax
    \baselineskip=\normalbaselineskip\relax%
-   \jot=\IEEEnormaljot\relax%
+   \jot=\normaljot\relax%
    \mathsurround\z@\relax% no extra spacing around math
    \@advanceIEEEeqncolcnttrue% advance the col counter for each col the user uses,
                              % used in \IEEEeqnarraymulticol and in the preamble build
@@ -2564,7 +2758,7 @@
    \lineskip=0pt\relax%
    \lineskiplimit=0pt\relax%
    \baselineskip=\normalbaselineskip\relax%
-   \jot=\IEEEnormaljot\relax%
+   \jot=\normaljot\relax%
    \mathsurround\z@\relax% no extra spacing around math
    % the default end glues are zero for an \IEEEeqnarraybox
    \edef\@IEEEeqnarraycolSEPdefaultstart{\@IEEEeqnarraycolSEPzero}% default start glue
@@ -2923,37 +3117,37 @@
 % set up the running headings, this complex because of all the different
 % modes IEEEtran supports
 \if@twoside
- \ifCLASSOPTIONtechnote
+ \if@technote
    \def\ps@headings{%
        \def\@oddhead{\hbox{}\scriptsize\leftmark \hfil \thepage}
        \def\@evenhead{\scriptsize\thepage \hfil \leftmark\hbox{}}
-       \ifCLASSOPTIONdraftcls
-            \ifCLASSOPTIONdraftclsnofoot
-               \def\@oddfoot{}\def\@evenfoot{}%
-            \else
+       \if@draftclsmode
+            \if@draftclsmodefoot
                \def\@oddfoot{\scriptsize\@date\hfil DRAFT}
                \def\@evenfoot{\scriptsize DRAFT\hfil\@date}
+            \else
+               \def\@oddfoot{}\def\@evenfoot{}%
             \fi
        \else
             \def\@oddfoot{}\def\@evenfoot{}
        \fi}
  \else % not a technote
    \def\ps@headings{%
-       \ifCLASSOPTIONconference
+       \if@confmode
         \def\@oddhead{}
         \def\@evenhead{}
        \else
         \def\@oddhead{\hbox{}\scriptsize\rightmark \hfil \thepage}
         \def\@evenhead{\scriptsize\thepage \hfil \leftmark\hbox{}}
        \fi
-       \ifCLASSOPTIONdraftcls
+       \if@draftclsmode
             \def\@oddhead{\hbox{}\scriptsize\rightmark \hfil \thepage}
             \def\@evenhead{\scriptsize\thepage \hfil \leftmark\hbox{}}
-            \ifCLASSOPTIONdraftclsnofoot
-               \def\@oddfoot{}\def\@evenfoot{}%
-            \else
+            \if@draftclsmodefoot
                \def\@oddfoot{\scriptsize\@date\hfil DRAFT}
                \def\@evenfoot{\scriptsize DRAFT\hfil\@date}
+            \else
+               \def\@oddfoot{}\def\@evenfoot{}%
             \fi
        \else
             \def\@oddfoot{}\def\@evenfoot{}%
@@ -2961,20 +3155,20 @@
  \fi
 \else % single side
 \def\ps@headings{%
-    \ifCLASSOPTIONconference
+    \if@confmode
      \def\@oddhead{}
      \def\@evenhead{}
     \else
      \def\@oddhead{\hbox{}\scriptsize\leftmark \hfil \thepage}
      \def\@evenhead{}
     \fi
-    \ifCLASSOPTIONdraftcls
+    \if@draftclsmode
           \def\@oddhead{\hbox{}\scriptsize\leftmark \hfil \thepage}
           \def\@evenhead{}
-          \ifCLASSOPTIONdraftclsnofoot
-             \def\@oddfoot{}
-          \else
+          \if@draftclsmodefoot
              \def\@oddfoot{\scriptsize \@date \hfil DRAFT}
+          \else
+             \def\@oddfoot{}
           \fi
     \else
          \def\@oddfoot{}
@@ -2984,18 +3178,18 @@


 % title page style
-\def\ps@IEEEtitlepagestyle{\def\@oddfoot{}\def\@evenfoot{}%
-\ifCLASSOPTIONconference
+\def\ps@titlepagestyle{\def\@oddfoot{}\def\@evenfoot{}%
+\if@confmode
    \def\@oddhead{}%
    \def\@evenhead{}%
 \else
    \def\@oddhead{\hbox{}\scriptsize\leftmark \hfil \thepage}%
    \def\@evenhead{\scriptsize\thepage \hfil \leftmark\hbox{}}%
 \fi
-\ifCLASSOPTIONdraftcls
+\if@draftclsmode
    \def\@oddhead{\hbox{}\scriptsize\leftmark \hfil \thepage}%
    \def\@evenhead{\scriptsize\thepage \hfil \leftmark\hbox{}}%
-   \ifCLASSOPTIONdraftclsnofoot\else
+   \if@draftclsmodefoot
       \def\@oddfoot{\scriptsize \@date\hfil DRAFT}%
       \def\@evenfoot{\scriptsize DRAFT\hfil \@date}%
    \fi
@@ -3004,27 +3198,22 @@
    \if@IEEEusingpubid
       % for title pages that are using a pubid
       % do not repeat pubid if using peer review option
-      \ifCLASSOPTIONpeerreview
+      \if@peerreviewoption
       \else
          \footskip 0pt%
-         \ifCLASSOPTIONcompsoc
-           \def\@oddfoot{\hss\normalfont\scriptsize\raisebox{-1.5\@IEEEnormalsizeunitybaselineskip}[0ex][0ex]{\@IEEEpubid}\hss}%
-           \def\@evenfoot{\hss\normalfont\scriptsize\raisebox{-1.5\@IEEEnormalsizeunitybaselineskip}[0ex][0ex]{\@IEEEpubid}\hss}%
-         \else
-           \def\@oddfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@IEEEpubid}\hss}%
-           \def\@evenfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@IEEEpubid}\hss}%
-         \fi
+         \def\@oddfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@pubid}\hss}%
+         \def\@evenfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@pubid}\hss}%
       \fi
    \fi
 \fi}


 % peer review cover page style
-\def\ps@IEEEpeerreviewcoverpagestyle{%
+\def\ps@peerreviewcoverpagestyle{%
 \def\@oddhead{}\def\@evenhead{}%
 \def\@oddfoot{}\def\@evenfoot{}%
-\ifCLASSOPTIONdraftcls
-   \ifCLASSOPTIONdraftclsnofoot\else
+\if@draftclsmode
+   \if@draftclsmodefoot
       \def\@oddfoot{\scriptsize \@date\hfil DRAFT}%
       \def\@evenfoot{\scriptsize DRAFT\hfil \@date}%
    \fi
@@ -3032,13 +3221,8 @@
    % non-draft mode footers
    \if@IEEEusingpubid
       \footskip 0pt%
-      \ifCLASSOPTIONcompsoc
-        \def\@oddfoot{\hss\normalfont\scriptsize\raisebox{-1.5\@IEEEnormalsizeunitybaselineskip}[0ex][0ex]{\@IEEEpubid}\hss}%
-        \def\@evenfoot{\hss\normalfont\scriptsize\raisebox{-1.5\@IEEEnormalsizeunitybaselineskip}[0ex][0ex]{\@IEEEpubid}\hss}%
-      \else
-        \def\@oddfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@IEEEpubid}\hss}%
-        \def\@evenfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@IEEEpubid}\hss}%
-      \fi
+      \def\@oddfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@pubid}\hss}%
+      \def\@evenfoot{\hss\normalfont\footnotesize\raisebox{1.5ex}[1.5ex]{\@pubid}\hss}%
    \fi
 \fi}

@@ -3053,8 +3237,7 @@
 %% that needs to be in lower case, for instance et. al., then either manually
 %% set \leftmark and \rightmark or use \MakeLowercase{et. al.} within the
 %% arguments to \markboth.
-\def\markboth#1#2{\def\leftmark{\@IEEEcompsoconly{\sffamily}\MakeUppercase{#1}}%
-\def\rightmark{\@IEEEcompsoconly{\sffamily}\MakeUppercase{#2}}}
+\def\markboth#1#2{\def\leftmark{\MakeUppercase{#1}}\def\rightmark{\MakeUppercase{#2}}}
 \def\footernote#1{\markboth{#1}{#1}}

 \def\today{\ifcase\month\or
@@ -3099,24 +3282,27 @@
 \def\citepunct{], [}
 \def\citedash{]--[}

-% V1.7 default to using same font for urls made by url.sty
-\AtBeginDocument{\csname url@samestyle\endcsname}
+
+% V1.6b providing this command makes hyperref think the natbib package is
+% in use so that it will not interfere with cite.sty. However, as a result,
+% citation numbers will not be hyperlinked.
+\def\NAT@parse{\typeout{IEEEtran error: Attempt to use fake Natbib command
+which is provided to fool Hyperref.}}
+% it easy enough to override via:
+% \let\NAT@parse\undefined
+

 % V1.6 class files should always provide these
 \def\newblock{\hskip .11em\@plus.33em\@minus.07em}
 \let\@openbib@code\@empty


+
 % Provide support for the control entries of IEEEtran.bst V1.00 and later.
-% V1.7 optional argument allows for a different aux file to be specified in
-% order to handle multiple bibliographies. For example, with multibib.sty:
-% \newcites{sec}{Secondary Literature}
-% \bstctlcite[@auxoutsec]{BSTcontrolhak}
-\def\bstctlcite{\@ifnextchar[{\@bstctlcite}{\@bstctlcite[@auxout]}}
-\def\@bstctlcite[#1]#2{\@bsphack
-  \@for\@citeb:=#2\do{%
+\def\bstctlcite#1{\@bsphack
+  \@for\@citeb:=#1\do{%
     \edef\@citeb{\expandafter\@firstofone\@citeb}%
-    \if@filesw\immediate\write\csname #1\endcsname{\string\citation{\@citeb}}\fi}%
+    \if@filesw\immediate\write\@auxout{\string\citation{\@citeb}}\fi}%
   \@esphack}

 % V1.6 provide a way for a user to execute a command just before
@@ -3139,27 +3325,17 @@
 \advance\@IEEEtrantmpcountA by -1\relax%
 \ifnum\c@enumiv=\@IEEEtrantmpcountA\relax\@IEEEtriggercmd\relax\fi}

-
 \def\@biblabel#1{[#1]}

-% compsoc journals left align the reference numbers
-\@IEEEcompsocnotconfonly{\def\@biblabel#1{[#1]\hfill}}
-
-% controls bib item spacing
-\def\IEEEbibitemsep{0pt plus .5pt}
-
-\@IEEEcompsocconfonly{\def\IEEEbibitemsep{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}}
-
-
-\def\thebibliography#1{\section*{\refname}%
-    \addcontentsline{toc}{section}{\refname}%
+\def\thebibliography#1{\section*{References}%
+    \addcontentsline{toc}{section}{References}%
     % V1.6 add some rubber space here and provide a command trigger
-    \footnotesize\@IEEEcompsocconfonly{\small}\vskip 0.3\baselineskip plus 0.1\baselineskip minus 0.1\baselineskip%
+    \footnotesize \vskip 0.3\baselineskip plus 0.1\baselineskip minus 0.1\baselineskip%
     \list{\@biblabel{\@arabic\c@enumiv}}%
     {\settowidth\labelwidth{\@biblabel{#1}}%
     \leftmargin\labelwidth
     \advance\leftmargin\labelsep\relax
-    \itemsep \IEEEbibitemsep\relax
+    \itemsep 0pt plus .5pt\relax%
     \usecounter{enumiv}%
     \let\p@enumiv\@empty
     \renewcommand\theenumiv{\@arabic\c@enumiv}}%
@@ -3174,7 +3350,7 @@
 % technotes). You may get an underfull vbox warning around the bibliography,
 % but the final result will be much more like what IEEE will publish.
 % MDS 11/2000
-\ifCLASSOPTIONtechnote\sloppy\clubpenalty4000\widowpenalty4000\interlinepenalty100%
+\if@technote\sloppy\clubpenalty4000\widowpenalty4000\interlinepenalty100%
 \else\sloppy\clubpenalty4000\widowpenalty4000\interlinepenalty500\fi%
     \sfcode`\.=1000\relax}
 \let\endthebibliography=\endlist
@@ -3186,22 +3362,21 @@
 %
 %
 % \IEEEmembership is used to produce the sublargesize italic font used to indicate author
-% IEEE membership. compsoc uses a large size sans slant font
-\def\IEEEmembership#1{{\@IEEEnotcompsoconly{\sublargesize}\normalfont\@IEEEcompsoconly{\sffamily}\textit{#1}}}
+% IEEE membership.
+\def\IEEEmembership#1{{\sublargesize\normalfont\textit{#1}}}


-% \IEEEauthorrefmark{} produces a footnote type symbol to indicate author affiliation.
-% When given an argument of 1 to 9, \IEEEauthorrefmark{} follows the standard LaTeX footnote
-% symbol sequence convention. However, for arguments 10 and above, \IEEEauthorrefmark{}
+% \authorrefmark{} produces a footnote type symbol to indicate author affiliation.
+% When given an argument of 1 to 9, \authorrefmark{} follows the standard LaTeX footnote
+% symbol sequence convention. However, for arguments 10 and above, \authorrefmark{}
 % reverts to using lower case roman numerals, so it cannot overflow. Do note that you
-% cannot use \footnotemark[] in place of \IEEEauthorrefmark{} within \author as the footnote
+% cannot use \footnotemark[] in place of \authorrefmark{} within \author as the footnote
 % symbols will have been turned off to prevent \thanks from creating footnote marks.
-% \IEEEauthorrefmark{} produces a symbol that appears to LaTeX as having zero vertical
+% \authorrefmark{} produces a symbol that appears to LaTeX as having zero vertical
 % height - this allows for a more compact line packing, but the user must ensure that
-% the interline spacing is large enough to prevent \IEEEauthorrefmark{} from colliding
+% the interline spacing is large enough to prevent \authorrefmark{} from colliding
 % with the text above.
-% V1.7 make this a robust command
-\DeclareRobustCommand*{\IEEEauthorrefmark}[1]{\raisebox{0pt}[0pt][0pt]{\textsuperscript{\footnotesize\ensuremath{\ifcase#1\or *\or \dagger\or \ddagger\or%
+\def\authorrefmark#1{\raisebox{0pt}[0pt][0pt]{\textsuperscript{\footnotesize\ensuremath{\ifcase#1\or *\or \dagger\or \ddagger\or%
     \mathsection\or \mathparagraph\or \|\or **\or \dagger\dagger%
     \or \ddagger\ddagger \else\textsuperscript{\expandafter\romannumeral#1}\fi}}}}

@@ -3209,16 +3384,14 @@
 % FONT CONTROLS AND SPACINGS FOR CONFERENCE MODE AUTHOR NAME AND AFFILIATION BLOCKS
 %
 % The default font styles for the author name and affiliation blocks (confmode)
-\def\@IEEEauthorblockNstyle{\normalfont\@IEEEcompsocnotconfonly{\sffamily}\sublargesize\@IEEEcompsocconfonly{\large}}
-\def\@IEEEauthorblockAstyle{\normalfont\@IEEEcompsocnotconfonly{\sffamily}\@IEEEcompsocconfonly{\itshape}\normalsize\@IEEEcompsocconfonly{\large}}
+\def\@IEEEauthorblockNstyle{\normalfont\sublargesize}
+\def\@IEEEauthorblockAstyle{\normalfont\normalsize}
 % The default if the user does not use an author block
-\def\@IEEEauthordefaulttextstyle{\normalfont\@IEEEcompsocnotconfonly{\sffamily}\sublargesize}
+\def\@IEEEauthordefaulttextstyle{\normalfont\sublargesize}

 % spacing from title (or special paper notice) to author name blocks (confmode)
 % can be negative
 \def\@IEEEauthorblockconfadjspace{-0.25em}
-% compsoc conferences need more space here
-\@IEEEcompsocconfonly{\def\@IEEEauthorblockconfadjspace{0.75\@IEEEnormalsizeunitybaselineskip}}

 % spacing between name and affiliation blocks (confmode)
 % This can be negative.
@@ -3288,7 +3461,7 @@
 %
 % use real definitions in conference mode
 % name block
-\def\IEEEauthorblockN#1{\relax\@IEEEauthorblockNstyle% set the default text style
+\def\authorblockN#1{\relax\@IEEEauthorblockNstyle% set the default text style
 \gdef\@IEEEauthorblockXinterlinespace{0pt}% disable strut for spacer row
 % the \expandafter hides the \cr in conditional tex, see the array.sty docs
 % for details, probably not needed here as the \cr is in a macro
@@ -3305,7 +3478,7 @@
 \def\@IEEEauthorblockNtopspaceline{\cr\noalign{\vskip\@IEEEauthorblockNtopspace}}
 %
 % affiliation block
-\def\IEEEauthorblockA#1{\relax\@IEEEauthorblockAstyle% set the default text style
+\def\authorblockA#1{\relax\@IEEEauthorblockAstyle% set the default text style
 \gdef\@IEEEauthorblockXinterlinespace{0pt}%disable strut for spacer row
 % the \expandafter hides the \cr in conditional tex, see the array.sty docs
 % for details, probably not needed here as the \cr is in a macro
@@ -3324,12 +3497,12 @@

 % allow papers to compile even if author blocks are used in modes other
 % than conference or peerreviewca. For such cases, we provide dummy blocks.
-\ifCLASSOPTIONconference
+\if@confmode
 \else
-   \ifCLASSOPTIONpeerreviewca\else
+   \if@peerreviewcaoption\else
       % not conference or peerreviewca mode
-      \def\IEEEauthorblockN#1{#1}%
-      \def\IEEEauthorblockA#1{#1}%
+      \def\authorblockN#1{#1}%
+      \def\authorblockA#1{#1}%
    \fi
 \fi

@@ -3377,10 +3550,10 @@
 \renewcommand{\and}[1][\relax]{\if@IEEEWARNand\typeout{** WARNING: \noexpand\and is valid only
                                when in conference or peerreviewca}\typeout{modes (line \the\inputlineno).}\fi\global\@IEEEWARNandfalse}

-\ifCLASSOPTIONconference%
+\if@confmode%
 \renewcommand{\and}[1][\hfill]{\end{@IEEEauthorhalign}#1\begin{@IEEEauthorhalign}}%
 \fi
-\ifCLASSOPTIONpeerreviewca
+\if@peerreviewcaoption
 \renewcommand{\and}[1][\hfill]{\end{@IEEEauthorhalign}#1\begin{@IEEEauthorhalign}}%
 \fi

@@ -3398,18 +3571,15 @@
   \normalfont%
   \def\thefootnote{}%  the \thanks{} mark type is empty
   \def\footnotemark{}% and kill space from \thanks within author
-  \let\@makefnmark\relax% V1.7, must *really* kill footnotemark to remove all \textsuperscript spacing as well.
   \footnotesize%       equal spacing between thanks lines
   \footnotesep 0.7\baselineskip%see global setting of \footnotesep for more info
-  % V1.7 disable \thanks note indention for compsoc
-  \@IEEEcompsoconly{\long\def\@makefntext##1{\parindent 1em\noindent\hbox{\@makefnmark}##1}}%
   \normalsize%
-  \ifCLASSOPTIONpeerreview
+  \if@peerreviewoption
      \newpage\global\@topnum\z@ \@maketitle\@IEEEstatictitlevskip\@IEEEaftertitletext%
-     \thispagestyle{IEEEpeerreviewcoverpagestyle}\@thanks%
+     \thispagestyle{peerreviewcoverpagestyle}\@thanks%
   \else
      \if@twocolumn%
-        \ifCLASSOPTIONtechnote%
+        \if@technote%
            \newpage\global\@topnum\z@ \@maketitle\@IEEEstatictitlevskip\@IEEEaftertitletext%
         \else
            \twocolumn[\@maketitle\@IEEEdynamictitlevspace\@IEEEaftertitletext]%
@@ -3417,127 +3587,62 @@
      \else
         \newpage\global\@topnum\z@ \@maketitle\@IEEEstatictitlevskip\@IEEEaftertitletext%
      \fi
-     \thispagestyle{IEEEtitlepagestyle}\@thanks%
+     \thispagestyle{titlepagestyle}\@thanks%
   \fi
   % pullup page for pubid if used.
   \if@IEEEusingpubid
-     \enlargethispage{-\@IEEEpubidpullup}%
+     \enlargethispage{-\@pubidpullup}%
   \fi
   \endgroup
   \setcounter{footnote}{0}\let\maketitle\relax\let\@maketitle\relax
-  \gdef\@thanks{}%
+  \gdef\@thanks{}
   % v1.6b do not clear these as we will need the title again for peer review papers
   % \gdef\@author{}\gdef\@title{}%
   \let\thanks\relax}


-
-% V1.7 parbox to format \@IEEEcompsoctitleabstractindextext
-\long\def\@IEEEcompsoctitleabstractindextextbox#1{\parbox{0.915\textwidth}{#1}}
-
 % formats the Title, authors names, affiliations and special paper notice
 % THIS IS A CONTROLLED SPACING COMMAND! Do not allow blank lines or unintentional
 % spaces to enter the definition - use % at the end of each line
 \def\@maketitle{\newpage
 \begin{center}%
-\ifCLASSOPTIONtechnote% technotes
-   {\bfseries\large\@IEEEcompsoconly{\sffamily}\@title\par}\vskip 1.3em{\lineskip .5em\@IEEEcompsoconly{\sffamily}\@author
-   \@IEEEspecialpapernotice\par{\@IEEEcompsoconly{\vskip 1.5em\relax
-   \@IEEEcompsoctitleabstractindextextbox{\@IEEEcompsoctitleabstractindextext}\par
-   \hfill\@IEEEcompsocdiamondline\hfill\hbox{}\par}}}\relax
+\if@technote%
+   {\bfseries\large\@title\par}\vskip 1.3em{\lineskip .5em\@author\@specialpapernotice\par}%
 \else% not a technote
-   \vskip0.2em{\Huge\@IEEEcompsoconly{\sffamily}\@IEEEcompsocconfonly{\normalfont\normalsize\vskip 2\@IEEEnormalsizeunitybaselineskip
-   \bfseries\Large}\@title\par}\vskip1.0em\par%
+   \vskip0.2em{\Huge\@title\par}\vskip1.0em\par%
    % V1.6 handle \author differently if in conference mode
-   \ifCLASSOPTIONconference%
-      {\@IEEEspecialpapernotice\mbox{}\vskip\@IEEEauthorblockconfadjspace%
-       \mbox{}\hfill\begin{@IEEEauthorhalign}\@author\end{@IEEEauthorhalign}\hfill\mbox{}\par}\relax
+   \if@confmode%
+      {\@specialpapernotice\mbox{}\vskip\@IEEEauthorblockconfadjspace%
+      \mbox{}\hfill\begin{@IEEEauthorhalign}\@author\end{@IEEEauthorhalign}\hfill\mbox{}\par}%
    \else% peerreviewca, peerreview or journal
-      \ifCLASSOPTIONpeerreviewca
+      \if@peerreviewcaoption
          % peerreviewca handles author names just like conference mode
-         {\@IEEEcompsoconly{\sffamily}\@IEEEspecialpapernotice\mbox{}\vskip\@IEEEauthorblockconfadjspace%
-          \mbox{}\hfill\begin{@IEEEauthorhalign}\@author\end{@IEEEauthorhalign}\hfill\mbox{}\par
-          {\@IEEEcompsoconly{\vskip 1.5em\relax
-           \@IEEEcompsoctitleabstractindextextbox{\@IEEEcompsoctitleabstractindextext}\par\hfill
-           \@IEEEcompsocdiamondline\hfill\hbox{}\par}}}\relax
+         {\@specialpapernotice\mbox{}\vskip\@IEEEauthorblockconfadjspace%
+         \mbox{}\hfill\begin{@IEEEauthorhalign}\@author\end{@IEEEauthorhalign}\hfill\mbox{}\par}%
       \else% journal or peerreview
-         {\lineskip.5em\@IEEEcompsoconly{\sffamily}\sublargesize\@author\@IEEEspecialpapernotice\par
-          {\@IEEEcompsoconly{\vskip 1.5em\relax
-           \@IEEEcompsoctitleabstractindextextbox{\@IEEEcompsoctitleabstractindextext}\par\hfill
-           \@IEEEcompsocdiamondline\hfill\hbox{}\par}}}\relax
+         {\lineskip.5em\sublargesize\@author\@specialpapernotice\par}%
       \fi
    \fi
 \fi\end{center}}



-% V1.7 Computer Society "diamond line" which follows index terms for nonconference papers
-\def\@IEEEcompsocdiamondline{\vrule depth 0pt height 0.5pt width 4cm\hspace{7.5pt}%
-\raisebox{-3.5pt}{\fontfamily{pzd}\fontencoding{U}\fontseries{m}\fontshape{n}\fontsize{11}{12}\selectfont\char70}%
-\hspace{7.5pt}\vrule depth 0pt height 0.5pt width 4cm\relax}
-
-% V1.7 standard LateX2e \thanks, but with \itshape under compsoc. Also make it a \long\def
-% We also need to trigger the one-shot footnote rule
-\def\@IEEEtriggeroneshotfootnoterule{\global\@IEEEenableoneshotfootnoteruletrue}
-
-
-\long\def\thanks#1{\footnotemark
-    \protected@xdef\@thanks{\@thanks
-        \protect\footnotetext[\the\c@footnote]{\@IEEEcompsoconly{\itshape
-        \protect\@IEEEtriggeroneshotfootnoterule\relax}\ignorespaces#1}}}
-\let\@thanks\@empty
-
-% V1.7 allow \author to contain \par's. This is needed to allow \thanks to contain \par.
-\long\def\author#1{\gdef\@author{#1}}
-
-
-% in addition to setting up IEEEitemize, we need to remove a baselineskip space above and
-% below it because \list's \pars introduce blank lines because of the footnote struts.
-\def\@IEEEsetupcompsocitemizelist{\def\labelitemi{$\bullet$}%
-\setlength{\IEEElabelindent}{0pt}\setlength{\parskip}{0pt}%
-\setlength{\partopsep}{0pt}\setlength{\topsep}{0.5\baselineskip}\vspace{-1\baselineskip}\relax}
-
-
-% flag for fake non-compsoc \IEEEcompsocthanksitem - prevents line break on very first item
-\newif\if@IEEEbreakcompsocthanksitem \@IEEEbreakcompsocthanksitemfalse
-
-\ifCLASSOPTIONcompsoc
-% V1.7 compsoc bullet item \thanks
-% also, we need to redefine this to destroy the argument in \@IEEEdynamictitlevspace
-\long\def\IEEEcompsocitemizethanks#1{\relax\@IEEEbreakcompsocthanksitemfalse\footnotemark
-    \protected@xdef\@thanks{\@thanks
-        \protect\footnotetext[\the\c@footnote]{\itshape\protect\@IEEEtriggeroneshotfootnoterule
-        {\let\IEEEiedlistdecl\relax\protect\begin{IEEEitemize}[\protect\@IEEEsetupcompsocitemizelist]\ignorespaces#1\relax
-        \protect\end{IEEEitemize}}\protect\vspace{-1\baselineskip}}}}
-\DeclareRobustCommand*{\IEEEcompsocthanksitem}{\item}
-\else
-% non-compsoc, allow for dual compilation via rerouting to normal \thanks
-\long\def\IEEEcompsocitemizethanks#1{\thanks{#1}}
-% redirect to "pseudo-par" \hfil\break\indent after swallowing [] from \IEEEcompsocthanksitem[]
-\DeclareRobustCommand{\IEEEcompsocthanksitem}{\@ifnextchar [{\@IEEEthanksswallowoptionalarg}%
-{\@IEEEthanksswallowoptionalarg[\relax]}}
-% be sure and break only after first item, be sure and ignore spaces after optional argument
-\def\@IEEEthanksswallowoptionalarg[#1]{\relax\if@IEEEbreakcompsocthanksitem\hfil\break
-\indent\fi\@IEEEbreakcompsocthanksitemtrue\ignorespaces}
-\fi
-
-
 % V1.6b define the \IEEEpeerreviewmaketitle as needed
-\ifCLASSOPTIONpeerreview
+\if@peerreviewoption
 \def\IEEEpeerreviewmaketitle{\@IEEEcleardoublepage{empty}%
-\ifCLASSOPTIONtwocolumn
+\if@twocolumnmode
 \twocolumn[\@IEEEpeerreviewmaketitle\@IEEEdynamictitlevspace]
 \else
 \newpage\@IEEEpeerreviewmaketitle\@IEEEstatictitlevskip
 \fi
-\thispagestyle{IEEEtitlepagestyle}}
+\thispagestyle{titlepagestyle}}
 \else
 % \IEEEpeerreviewmaketitle does nothing if peer review option has not been selected
 \def\IEEEpeerreviewmaketitle{\relax}
 \fi

 % peerreview formats the repeated title like the title in journal papers.
-\def\@IEEEpeerreviewmaketitle{\begin{center}\@IEEEcompsoconly{\sffamily}%
+\def\@IEEEpeerreviewmaketitle{\begin{center}%
 \normalfont\normalsize\vskip0.2em{\Huge\@title\par}\vskip1.0em\par
 \end{center}}

@@ -3550,15 +3655,15 @@
 \def\@IEEEstatictitlevskip{{\normalfont\normalsize
 % adjust spacing to next text
 % v1.6b handle peer review papers
-\ifCLASSOPTIONpeerreview
+\if@peerreviewoption
 % for peer review papers, the same value is used for both title pages
 % regardless of the other paper modes
    \vskip 1\baselineskip plus 0.375\baselineskip minus 0.1875\baselineskip
 \else
-   \ifCLASSOPTIONconference% conference
+   \if@confmode% conference
       \vskip 1\baselineskip plus 0.375\baselineskip minus 0.1875\baselineskip%
    \else%
-      \ifCLASSOPTIONtechnote% technote
+      \if@technote% technote
          \vskip 1\baselineskip plus 0.375\baselineskip minus 0.1875\baselineskip%
       \else% journal uses more space
          \vskip 2.5\baselineskip plus 0.75\baselineskip minus 0.375\baselineskip%
@@ -3575,49 +3680,48 @@
 % main text is an integer multiple of \baselineskip
 % otherwise underfull vbox problems may develop in the second column of the
 % text on the titlepage
-% The possible use of \IEEEpubid must also be taken into account.
+% The possible use of \pubid must also be taken into account.
 \def\@IEEEdynamictitlevspace{{%
     % we run within a group so that all the macros can be forgotten when we are done
-    \long\def\thanks##1{\relax}%don't allow \thanks to run when we evaluate the vbox height
-    \long\def\IEEEcompsocitemizethanks##1{\relax}%don't allow \IEEEcompsocitemizethanks to run when we evaluate the vbox height
+    \def\thanks##1{\relax}%don't allow \thanks to run when we evaluate the vbox height
     \normalfont\normalsize% we declare more descriptive variable names
-    \let\@IEEEmaintextheight=\@IEEEtrantmpdimenA%height of the main text columns
-    \let\@IEEEINTmaintextheight=\@IEEEtrantmpdimenB%height of the main text columns with integer # lines
+    \let\@maintextheight=\@IEEEtrantmpdimenA%height of the main text columns
+    \let\@INTmaintextheight=\@IEEEtrantmpdimenB%height of the main text columns with integer # lines
     % set the nominal and minimum values for the title spacer
     % the dynamic algorithm will not allow the spacer size to
-    % become less than \@IEEEMINtitlevspace - instead it will be
+    % become less than \@MINtitlevspace - instead it will be
     % lengthened
     % default to journal values
-    \def\@IEEENORMtitlevspace{2.5\baselineskip}%
-    \def\@IEEEMINtitlevspace{2\baselineskip}%
+    \def\@NORMtitlevspace{2.5\baselineskip}%
+    \def\@MINtitlevspace{2\baselineskip}%
     % conferences and technotes need tighter spacing
-    \ifCLASSOPTIONconference%conference
-     \def\@IEEENORMtitlevspace{1\baselineskip}%
-     \def\@IEEEMINtitlevspace{0.75\baselineskip}%
-    \fi
-    \ifCLASSOPTIONtechnote%technote
-      \def\@IEEENORMtitlevspace{1\baselineskip}%
-      \def\@IEEEMINtitlevspace{0.75\baselineskip}%
+    \if@confmode%conference
+     \def\@NORMtitlevspace{1\baselineskip}%
+     \def\@MINtitlevspace{0.75\baselineskip}%
+    \fi
+    \if@technote%technote
+      \def\@NORMtitlevspace{1\baselineskip}%
+      \def\@MINtitlevspace{0.75\baselineskip}%
     \fi%
     % get the height that the title will take up
-    \ifCLASSOPTIONpeerreview
-       \settoheight{\@IEEEmaintextheight}{\vbox{\hsize\textwidth \@IEEEpeerreviewmaketitle}}%
+    \if@peerreviewoption
+       \settoheight{\@maintextheight}{\vbox{\hsize\textwidth \@IEEEpeerreviewmaketitle}}%
     \else
-       \settoheight{\@IEEEmaintextheight}{\vbox{\hsize\textwidth \@maketitle}}%
+       \settoheight{\@maintextheight}{\vbox{\hsize\textwidth \@maketitle}}%
     \fi
-    \@IEEEmaintextheight=-\@IEEEmaintextheight% title takes away from maintext, so reverse sign
+    \@maintextheight=-\@maintextheight% title takes away from maintext, so reverse sign
     % add the height of the page textheight
-    \advance\@IEEEmaintextheight by \textheight%
+    \advance\@maintextheight by \textheight%
     % correct for title pages using pubid
-    \ifCLASSOPTIONpeerreview\else
+    \if@peerreviewoption\else
        % peerreview papers use the pubid on the cover page only.
        % And the cover page uses a static spacer.
-       \if@IEEEusingpubid\advance\@IEEEmaintextheight by -\@IEEEpubidpullup\fi
+       \if@IEEEusingpubid\advance\@maintextheight by -\@pubidpullup\fi
     \fi%
     % subtract off the nominal value of the title bottom spacer
-    \advance\@IEEEmaintextheight by -\@IEEENORMtitlevspace%
+    \advance\@maintextheight by -\@NORMtitlevspace%
     % \topskip takes away some too
-    \advance\@IEEEmaintextheight by -\topskip%
+    \advance\@maintextheight by -\topskip%
     % calculate the column height of the main text for lines
     % now we calculate the main text height as if holding
     % an integer number of \normalsize lines after the first
@@ -3625,37 +3729,37 @@
     % we subtracted the first line, because the first line
     % is placed \topskip into the maintext, not \baselineskip like the
     % rest of the lines.
-    \@IEEEINTmaintextheight=\@IEEEmaintextheight%
-    \divide\@IEEEINTmaintextheight  by \baselineskip%
-    \multiply\@IEEEINTmaintextheight  by \baselineskip%
+    \@INTmaintextheight=\@maintextheight%
+    \divide\@INTmaintextheight  by \baselineskip%
+    \multiply\@INTmaintextheight  by \baselineskip%
     % now we calculate how much the title spacer height will
-    % have to be reduced from nominal (\@IEEEREDUCEmaintextheight is always
+    % have to be reduced from nominal (\@REDUCEmaintextheight is always
     % a positive value) so that the maintext area will contain an integer
     % number of normal size lines
     % we change variable names here (to avoid confusion) as we no longer
-    % need \@IEEEINTmaintextheight and can reuse its dimen register
-    \let\@IEEEREDUCEmaintextheight=\@IEEEINTmaintextheight%
-    \advance\@IEEEREDUCEmaintextheight by -\@IEEEmaintextheight%
-    \advance\@IEEEREDUCEmaintextheight by \baselineskip%
+    % need \@INTmaintextheight and can reuse its dimen register
+    \let\@REDUCEmaintextheight=\@INTmaintextheight%
+    \advance\@REDUCEmaintextheight by -\@maintextheight%
+    \advance\@REDUCEmaintextheight by \baselineskip%
     % this is the calculated height of the spacer
     % we change variable names here (to avoid confusion) as we no longer
-    % need \@IEEEmaintextheight and can reuse its dimen register
-    \let\@IEEECOMPENSATElen=\@IEEEmaintextheight%
-    \@IEEECOMPENSATElen=\@IEEENORMtitlevspace% set the nominal value
+    % need \@maintextheight and can reuse its dimen register
+    \let\@COMPENSATElen=\@maintextheight%
+    \@COMPENSATElen=\@NORMtitlevspace% set the nominal value
     % we go with the reduced length if it is smaller than an increase
-    \ifdim\@IEEEREDUCEmaintextheight < 0.5\baselineskip\relax%
-     \advance\@IEEECOMPENSATElen by -\@IEEEREDUCEmaintextheight%
+    \ifdim\@REDUCEmaintextheight < 0.5\baselineskip\relax%
+     \advance\@COMPENSATElen by -\@REDUCEmaintextheight%
      % if the resulting spacer is too small back out and go with an increase instead
-     \ifdim\@IEEECOMPENSATElen<\@IEEEMINtitlevspace\relax%
-      \advance\@IEEECOMPENSATElen by \baselineskip%
+     \ifdim\@COMPENSATElen<\@MINtitlevspace\relax%
+      \advance\@COMPENSATElen by \baselineskip%
      \fi%
     \else%
      % go with an increase because it is closer to the nominal than a decrease
-     \advance\@IEEECOMPENSATElen by -\@IEEEREDUCEmaintextheight%
-     \advance\@IEEECOMPENSATElen by \baselineskip%
+     \advance\@COMPENSATElen by -\@REDUCEmaintextheight%
+     \advance\@COMPENSATElen by \baselineskip%
     \fi%
     % set the calculated rigid spacer
-    \vspace{\@IEEECOMPENSATElen}}}
+    \vspace{\@COMPENSATElen}}}



@@ -3664,97 +3768,33 @@
 % useful in emergencies such as when a different spacing is needed
 % This text is NOT compensated for in the dynamic sizer.
 \let\@IEEEaftertitletext=\relax
-\long\def\IEEEaftertitletext#1{\def\@IEEEaftertitletext{#1}}
-
-% V1.7 provide a way for users to enter abstract and keywords
-% into the onecolumn title are. This text is compensated for
-% in the dynamic sizer.
-\let\@IEEEcompsoctitleabstractindextext=\relax
-\long\def\IEEEcompsoctitleabstractindextext#1{\def\@IEEEcompsoctitleabstractindextext{#1}}
-% V1.7 provide a way for users to get the \@IEEEcompsoctitleabstractindextext if
-% not in compsoc journal mode - this way abstract and keywords can be placed
-% in their conventional position if not in compsoc mode.
-\def\IEEEdisplaynotcompsoctitleabstractindextext{%
-\ifCLASSOPTIONcompsoc% display if compsoc conf
-\ifCLASSOPTIONconference\@IEEEcompsoctitleabstractindextext\fi
-\else% or if not compsoc
-\@IEEEcompsoctitleabstractindextext\fi}
-
-
-% command to allow alteration of baselinestretch, but only if the current
-% baselineskip is unity. Used to tweak the compsoc abstract and keywords line spacing.
-\def\@IEEEtweakunitybaselinestretch#1{{\def\baselinestretch{1}\selectfont
-\global\@tempskipa\baselineskip}\ifnum\@tempskipa=\baselineskip%
-\def\baselinestretch{#1}\selectfont\fi\relax}
-
-
-% abstract and keywords are in \small, except
-% for 9pt docs in which they are in \footnotesize
-% Because 9pt docs use an 8pt footnotesize, \small
-% becomes a rather awkward 8.5pt
-\def\@IEEEabskeysecsize{\small}
-\ifx\CLASSOPTIONpt\@IEEEptsizenine
- \def\@IEEEabskeysecsize{\footnotesize}
-\fi
-
-% compsoc journals use \footnotesize, compsoc conferences use normalsize
-\@IEEEcompsoconly{\def\@IEEEabskeysecsize{\footnotesize}}
-\@IEEEcompsocconfonly{\def\@IEEEabskeysecsize{\normalsize}}
-
-
+\def\IEEEaftertitletext#1{\def\@IEEEaftertitletext{#1}}


 % V1.6 have abstract and keywords strip leading spaces, pars and newlines
 % so that spacing is more tightly controlled.
-\def\abstract{\normalfont
-    \if@twocolumn
-      \@IEEEabskeysecsize\bfseries\textit{\abstractname}---\relax
-    \else
-      \begin{center}\vspace{-1.78ex}\@IEEEabskeysecsize\textbf{\abstractname}\end{center}\quotation\@IEEEabskeysecsize
+\def\abstract{\normalfont%
+    \if@twocolumn%
+      \@IEEEabskeysecsize\bfseries\textit{Abstract}---\,%
+    \else%
+      \begin{center}\vspace{-1.78ex}\@IEEEabskeysecsize\textbf{Abstract}\end{center}\quotation\@IEEEabskeysecsize%
     \fi\@IEEEgobbleleadPARNLSP}
 % V1.6 IEEE wants only 1 pica from end of abstract to introduction heading when in
 % conference mode (the heading already has this much above it)
-\def\endabstract{\relax\ifCLASSOPTIONconference\vspace{0ex}\else\vspace{1.34ex}\fi\par\if@twocolumn\else\endquotation\fi
+\def\endabstract{\relax\if@confmode\vspace{0ex}\else\vspace{1.34ex}\fi\par\if@twocolumn\else\endquotation\fi%
     \normalfont\normalsize}

-\def\IEEEkeywords{\normalfont
-    \if@twocolumn
-      \@IEEEabskeysecsize\bfseries\textit{\IEEEkeywordsname}---\relax
-    \else
-      \begin{center}\@IEEEabskeysecsize\textbf{\IEEEkeywordsname}\end{center}\quotation\@IEEEabskeysecsize
-    \fi\@IEEEgobbleleadPARNLSP}
-\def\endIEEEkeywords{\relax\ifCLASSOPTIONtechnote\vspace{1.34ex}\else\vspace{0.67ex}\fi
-    \par\if@twocolumn\else\endquotation\fi%
-    \normalfont\normalsize}

-% V1.7 compsoc keywords index terms
-\ifCLASSOPTIONcompsoc
-  \ifCLASSOPTIONconference% compsoc conference
-\def\abstract{\normalfont
-      \begin{center}\@IEEEabskeysecsize\textbf{\large\abstractname}\end{center}\vskip 0.5\baselineskip plus 0.1\baselineskip minus 0.1\baselineskip
-      \if@twocolumn\else\quotation\fi\itshape\@IEEEabskeysecsize%
-      \par\@IEEEgobbleleadPARNLSP}
-\def\IEEEkeywords{\normalfont\vskip 1.5\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip
-      \begin{center}\@IEEEabskeysecsize\textbf{\large\IEEEkeywordsname}\end{center}\vskip 0.5\baselineskip plus 0.1\baselineskip minus 0.1\baselineskip
-      \if@twocolumn\else\quotation\fi\itshape\@IEEEabskeysecsize%
-      \par\@IEEEgobbleleadPARNLSP}
-  \else% compsoc not conference
-\def\abstract{\normalfont\@IEEEtweakunitybaselinestretch{1.15}\sffamily
-    \if@twocolumn
-      \@IEEEabskeysecsize\noindent\textbf{\abstractname}---\relax
-    \else
-      \begin{center}\vspace{-1.78ex}\@IEEEabskeysecsize\textbf{\abstractname}\end{center}\quotation\@IEEEabskeysecsize%
-    \fi\@IEEEgobbleleadPARNLSP}
-\def\IEEEkeywords{\normalfont\@IEEEtweakunitybaselinestretch{1.15}\sffamily
-    \if@twocolumn
-      \@IEEEabskeysecsize\vskip 0.5\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip\noindent
-      \textbf{\IEEEkeywordsname}---\relax
-    \else
-      \begin{center}\@IEEEabskeysecsize\textbf{\IEEEkeywordsname}\end{center}\quotation\@IEEEabskeysecsize%
+\def\keywords{\normalfont%
+    % IEEE uses the term (in bold italics) "Index Terms" now.
+    \if@twocolumn%
+      \@IEEEabskeysecsize\bfseries\textit{Index Terms}---\,\relax%
+    \else%
+      \begin{center}\@IEEEabskeysecsize\bfseries Index Terms\end{center}\quotation\@IEEEabskeysecsize%
     \fi\@IEEEgobbleleadPARNLSP}
-  \fi
-\fi
-
+\def\endkeywords{\relax\if@technote\vspace{1.34ex}\else\vspace{0.67ex}\fi%
+    \par\if@twocolumn\else\endquotation\fi%
+    \normalsize\normalfont}


 % gobbles all leading \, \\ and \par, upon finding first token that
@@ -3794,63 +3834,48 @@

 % TITLING OF SECTIONS
 \def\@IEEEsectpunct{:\ \,}  % Punctuation after run-in section heading  (headings which are
-                            % part of the paragraphs), need little bit more than a single space
-                            % spacing from section number to title
-% compsoc conferences use regular period/space punctuation
-\ifCLASSOPTIONcompsoc
-\ifCLASSOPTIONconference
-\def\@IEEEsectpunct{.\ }
-\fi\fi
-
+                            % part of the paragraphs), need little bit more than a space

 \def\@seccntformat#1{\csname the#1dis\endcsname\hskip 0.5em\relax}

-\ifCLASSOPTIONcompsoc
-% compsoc journals need extra spacing
-\ifCLASSOPTIONconference\else
-\def\@seccntformat#1{\csname the#1dis\endcsname\hskip 1em\relax}
-\fi\fi
-
-%v1.7 put {} after #6 to allow for some types of user font control
-%and use \@@par rather than \par
 \def\@sect#1#2#3#4#5#6[#7]#8{%
-  \ifnum #2>\c@secnumdepth
-     \let\@svsec\@empty
-  \else
-     \refstepcounter{#1}%
+  \ifnum #2>\c@secnumdepth%
+     \def\@svsec{}%
+  \else%
+     \refstepcounter{#1}
      % load section label and spacer into \@svsec
      \protected@edef\@svsec{\@seccntformat{#1}\relax}%
   \fi%
-  \@tempskipa #5\relax
+  \@tempskipa #5\relax%
   \ifdim \@tempskipa>\z@% tempskipa determines whether is treated as a high
-     \begingroup #6{\relax% or low level heading
+     \begingroup #6\relax% or low level heading
       \noindent % subsections are NOT indented
        % print top level headings. \@svsec is label, #8 is heading title
+       %\@hangfrom{\hskip #3\relax\@svsec}{\interlinepenalty \@M #8\par}
        % IEEE does not block indent the section title text, it flows like normal
-       {\hskip #3\relax\@svsec}{\interlinepenalty \@M #8\@@par}}%
-     \endgroup
-     \addcontentsline{toc}{#1}{\ifnum #2>\c@secnumdepth\relax\else
+       \relax{\hskip #3\relax\@svsec}{\interlinepenalty \@M #8\par}%
+     \endgroup%
+     % got rid of sectionmark stuff
+     % \csname #1mark\endcsname{#7}
+     \addcontentsline{toc}{#1}{\ifnum #2>\c@secnumdepth\relax\else%
                \protect\numberline{\csname the#1\endcsname}\fi#7}%
   \else % printout low level headings
      % svsechd seems to swallow the trailing space, protect it with \mbox{}
      % got rid of sectionmark stuff
-     \def\@svsechd{#6{\hskip #3\relax\@svsec #8\@IEEEsectpunct\mbox{}}%
-     \addcontentsline{toc}{#1}{\ifnum #2>\c@secnumdepth\relax\else
-               \protect\numberline{\csname the#1\endcsname}\fi#7}}%
+     \def\@svsechd{#6\hskip #3\@svsec #8\@IEEEsectpunct\mbox{}%\csname #1mark\endcsname{#7}
+     \addcontentsline{toc}{#1}{\ifnum #2>\c@secnumdepth\relax\else%
+               \protect\numberline{\csname the#1\endcsname}\fi#7}}
   \fi%skip down
   \@xsect{#5}}

-
 % section* handler
-%v1.7 put {} after #4 to allow for some types of user font control
-%and use \@@par rather than \par
-\def\@ssect#1#2#3#4#5{\@tempskipa #3\relax
-  \ifdim \@tempskipa>\z@
+\def\@ssect#1#2#3#4#5{\@tempskipa #3\relax%
+  \ifdim \@tempskipa>\z@%
      %\begingroup #4\@hangfrom{\hskip #1}{\interlinepenalty \@M #5\par}\endgroup
      % IEEE does not block indent the section title text, it flows like normal
-     \begingroup \noindent #4{\relax{\hskip #1}{\interlinepenalty \@M #5\@@par}}\endgroup
+     \begingroup \noindent #4\relax{\hskip #1}{\interlinepenalty \@M #5\par}\endgroup%
   % svsechd swallows the trailing space, protect it with \mbox{}
-  \else \def\@svsechd{#4{\hskip #1\relax #5\@IEEEsectpunct\mbox{}}}\fi
+  \else \def\@svsechd{#4\hskip #1\relax #5\@IEEEsectpunct\mbox{}}\fi%
   \@xsect{#3}}


@@ -3871,7 +3896,7 @@
 % IEEE sometimes REALLY stretches the area before a section
 % heading by up to about 0.5in. However, it may not be a good
 % idea to let LaTeX have quite this much rubber.
-\ifCLASSOPTIONconference%
+\if@confmode%
 % IEEE wants section heading spacing to decrease for conference mode
 \def\section{\@startsection{section}{1}{\z@}{1.5ex plus 1.5ex minus 0.5ex}%
 {0.7ex plus 1ex minus 0ex}{\normalfont\normalsize\centering\scshape}}%
@@ -3883,8 +3908,6 @@
 \def\subsection{\@startsection{subsection}{2}{\z@}{3.5ex plus 1.5ex minus 1.5ex}%
 {0.7ex plus .5ex minus 0ex}{\normalfont\normalsize\itshape}}%
 \fi
-
-% for both journals and conferences
 % decided to put in a little rubber above the section, might help somebody
 \def\subsubsection{\@startsection{subsubsection}{3}{\parindent}{0ex plus 0.1ex minus 0.1ex}%
 {0ex}{\normalfont\normalsize\itshape}}%
@@ -3892,53 +3915,16 @@
 {0ex}{\normalfont\normalsize\itshape}}%


-% compsoc
-\ifCLASSOPTIONcompsoc
-\ifCLASSOPTIONconference
-% compsoc conference
-\def\section{\@startsection{section}{1}{\z@}{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}%
-{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}{\normalfont\large\bfseries}}%
-\def\subsection{\@startsection{subsection}{2}{\z@}{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}%
-{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}{\normalfont\sublargesize\bfseries}}%
-\def\subsubsection{\@startsection{subsubsection}{3}{\z@}{1\baselineskip plus 0.25\baselineskip minus 0.25\baselineskip}%
-{0ex}{\normalfont\normalsize\bfseries}}%
-\def\paragraph{\@startsection{paragraph}{4}{2\parindent}{0ex plus 0.1ex minus 0.1ex}%
-{0ex}{\normalfont\normalsize}}%
-\else% compsoc journals
-% use negative top separation as compsoc journals do not indent paragraphs after section titles
-\def\section{\@startsection{section}{1}{\z@}{-3ex plus -2ex minus -1.5ex}%
-{0.7ex plus 1ex minus 0ex}{\normalfont\large\sffamily\bfseries\scshape}}%
-% Note that subsection and smaller may not be correct for the Computer Society,
-% I have to look up an example.
-\def\subsection{\@startsection{subsection}{2}{\z@}{-3.5ex plus -1.5ex minus -1.5ex}%
-{0.7ex plus .5ex minus 0ex}{\normalfont\normalsize\sffamily\bfseries}}%
-\def\subsubsection{\@startsection{subsubsection}{3}{\z@}{-2.5ex plus -1ex minus -1ex}%
-{0.5ex plus 0.5ex minus 0ex}{\normalfont\normalsize\sffamily\itshape}}%
-\def\paragraph{\@startsection{paragraph}{4}{2\parindent}{-0ex plus -0.1ex minus -0.1ex}%
-{0ex}{\normalfont\normalsize}}%
-\fi\fi
-
-
-

 %% ENVIRONMENTS
 % "box" symbols at end of proofs
-\def\IEEEQEDclosed{\mbox{\rule[0pt]{1.3ex}{1.3ex}}} % for a filled box
+\def\QEDclosed{\mbox{\rule[0pt]{1.3ex}{1.3ex}}} % for a filled box
 % V1.6 some journals use an open box instead that will just fit around a closed one
-\def\IEEEQEDopen{{\setlength{\fboxsep}{0pt}\setlength{\fboxrule}{0.2pt}\fbox{\rule[0pt]{0pt}{1.3ex}\rule[0pt]{1.3ex}{0pt}}}}
-\ifCLASSOPTIONcompsoc
-\def\IEEEQED{\IEEEQEDopen}   % default to open for compsoc
-\else
-\def\IEEEQED{\IEEEQEDclosed} % otherwise default to closed
-\fi
-
-% v1.7 name change to avoid namespace collision with amsthm. Also add support
-% for an optional argument.
-\def\IEEEproof{\@ifnextchar[{\@IEEEproof}{\@IEEEproof[\IEEEproofname]}}
-\def\@IEEEproof[#1]{\par\noindent\hspace{2em}{\itshape #1: }}
-\def\endIEEEproof{\hspace*{\fill}~\IEEEQED\par}
-
+\def\QEDopen{{\setlength{\fboxsep}{0pt}\setlength{\fboxrule}{0.2pt}\fbox{\rule[0pt]{0pt}{1.3ex}\rule[0pt]{1.3ex}{0pt}}}}
+\def\QED{\QEDclosed} % default to closed

+\def\proof{\noindent\hspace{2em}{\itshape Proof: }}
+\def\endproof{\hspace*{\fill}~\QED\par\endtrivlist\unskip}
 %\itemindent is set to \z@ by list, so define new temporary variable
 \newdimen\@IEEEtmpitemindent
 \def\@begintheorem#1#2{\@IEEEtmpitemindent\itemindent\topsep 0pt\rmfamily\trivlist%
@@ -3947,38 +3933,20 @@
 % V1.6 IEEE is back to using () around theorem names which are also in italics
 % Thanks to Christian Peel for reporting this.
     \item[\hskip\labelsep{\indent\itshape #1\ #2\ (#3):}]\itemindent\@IEEEtmpitemindent}
-% V1.7 remove bogus \unskip that caused equations in theorems to collide with
-% lines below.
-\def\@endtheorem{\endtrivlist}
+\def\@endtheorem{\endtrivlist\unskip}

 % V1.6
 % display command for the section the theorem is in - so that \thesection
 % is not used as this will be in Roman numerals when we want arabic.
 % LaTeX2e uses \def\@thmcounter#1{\noexpand\arabic{#1}} for the theorem number
 % (second part) display and \def\@thmcountersep{.} as a separator.
-% V1.7 intercept calls to the section counter and reroute to \@IEEEthmcounterinsection
-% to allow \appendix(ices} to override as needed.
-%
-% special handler for sections, allows appendix(ices) to override
-\gdef\@IEEEthmcounterinsection#1{\arabic{#1}}
-% string macro
-\edef\@IEEEstringsection{section}
-
-% redefine the #1#2[#3] form of newtheorem to use a hook to \@IEEEthmcounterinsection
-% if section in_counter is used
+\def\@IEEEthmcounterin#1{\arabic{#1}}
+% redefine the #1#2[#3] form of newtheorem to use a hook to \@IEEEthmcounterin
 \def\@xnthm#1#2[#3]{%
   \expandafter\@ifdefinable\csname #1\endcsname
     {\@definecounter{#1}\@newctr{#1}[#3]%
-     \edef\@IEEEstringtmp{#3}
-     \ifx\@IEEEstringtmp\@IEEEstringsection
      \expandafter\xdef\csname the#1\endcsname{%
-     \noexpand\@IEEEthmcounterinsection{#3}\@thmcountersep
-          \@thmcounter{#1}}%
-     \else
-     \expandafter\xdef\csname the#1\endcsname{%
-       \expandafter\noexpand\csname the#3\endcsname \@thmcountersep
-          \@thmcounter{#1}}%
-     \fi
+     \noexpand\@IEEEthmcounterin{#3}\@thmcountersep\@thmcounter{#1}}%
      \global\@namedef{#1}{\@thm{#1}{#2}}%
      \global\@namedef{end#1}{\@endtheorem}}}

@@ -3992,7 +3960,7 @@
 \setcounter{page}{1}
 % however, for peerreview the cover sheet is page 0 or page -1
 % (for duplex printing)
-\ifCLASSOPTIONpeerreview
+\if@peerreviewoption
    \if@twoside
       \setcounter{page}{-1}
    \else
@@ -4002,12 +3970,12 @@

 % standard book class behavior - let bottom line float up and down as
 % needed when single sided
-\ifCLASSOPTIONtwoside\else\raggedbottom\fi
+\if@twoside\else\raggedbottom\fi
 % if two column - turn on twocolumn, allow word spacings to stretch more and
 % enforce a rigid position for the last lines
-\ifCLASSOPTIONtwocolumn
+\if@twocolumnmode
 % the peer review option delays invoking twocolumn
-   \ifCLASSOPTIONpeerreview\else
+   \if@peerreviewoption\else
       \twocolumn
    \fi
 \sloppy
@@ -4042,14 +4010,9 @@
 \endgroup
 % end of \@ifmtarg defs

-
-% V1.7
-% command that allows the one time saving of the original definition
-% of section to \@IEEEappendixsavesection for \appendix or \appendices
-% we don't save \section here as it may be redefined later by other
-% packages (hyperref.sty, etc.)
-\def\@IEEEsaveoriginalsectiononce{\let\@IEEEappendixsavesection\section
-\let\@IEEEsaveoriginalsectiononce\relax}
+% save the "original" meaning of \section so we can redefine
+% \section after a call to \appendix or \appendices
+\let\@IEEEappendixsavesection\section

 % neat trick to grab and process the argument from \section{argument}
 % we process differently if the user invoked \section{} with no
@@ -4057,10 +4020,10 @@
 % note we reroute the call to the old \section*
 \def\@IEEEprocessthesectionargument#1{%
 \@ifmtarg{#1}{%
-\@IEEEappendixsavesection*{\appendixname~\thesectiondis}%
-\addcontentsline{toc}{section}{\appendixname~\thesection}}{%
-\@IEEEappendixsavesection*{\appendixname~\thesectiondis \\* #1}%
-\addcontentsline{toc}{section}{\appendixname~\thesection: #1}}}
+\@IEEEappendixsavesection*{Appendix \thesectiondis}%
+\addcontentsline{toc}{section}{Appendix \thesection}}{%
+\@IEEEappendixsavesection*{Appendix \thesectiondis \\* #1}%
+\addcontentsline{toc}{section}{Appendix \thesection: #1}}}

 % we use this if the user calls \section{} after
 % \appendix-- which has no meaning. So, we ignore the
@@ -4078,24 +4041,23 @@
 % heading, you can do so via the optional argument:
 % \appendix[Optional Heading]
 \def\appendix{\relax}
-\renewcommand{\appendix}[1][]{\@IEEEsaveoriginalsectiononce\par
+\renewcommand{\appendix}[1][]{\par%
     % v1.6 keep hyperref's identifiers unique
-    \gdef\theHsection{Appendix.A}%
+    \def\theHsection{Appendix.A}%
     % v1.6 adjust hyperref's string name for the section
     \xdef\Hy@chapapp{appendix}%
     \setcounter{section}{0}%
     \setcounter{subsection}{0}%
     \setcounter{subsubsection}{0}%
     \setcounter{paragraph}{0}%
-    \gdef\thesection{A}%
-    \gdef\thesectiondis{}%
-    \gdef\thesubsection{\Alph{subsection}}%
-    \gdef\@IEEEthmcounterinsection##1{A}
+    \def\thesection{}%
+    \def\thesectiondis{}%
+    \def\thesubsection{\Alph{subsection}}%
     \refstepcounter{section}% update the \ref counter
-    \@ifmtarg{#1}{\@IEEEappendixsavesection*{\appendixname}%
-                  \addcontentsline{toc}{section}{\appendixname}}{%
-             \@IEEEappendixsavesection*{\appendixname~\\* #1}%
-             \addcontentsline{toc}{section}{\appendixname: #1}}%
+    \@ifmtarg{#1}{\@IEEEappendixsavesection*{Appendix}%
+                  \addcontentsline{toc}{section}{Appendix}}{%
+             \@IEEEappendixsavesection*{Appendix \\* #1}%
+             \addcontentsline{toc}{section}{Appendix: #1}}%
     % redefine \section command for appendix
     % leave \section* as is
     \def\section{\@ifstar{\@IEEEappendixsavesection*}{%
@@ -4104,29 +4066,34 @@
 }


+% provides the user a way to choose between
+% Appendix A
+%    and
+% Appendix I
+% notation
+% defaults to Roman.
+\newif\ifuseRomanappendices
+\useRomanappendicestrue
+

 % appendices command for multiple appendices
 % user then calls \section with an argument (possibly empty) to
 % declare the individual appendices
-\def\appendices{\@IEEEsaveoriginalsectiononce\par
+\def\appendices{\par%
     % v1.6 keep hyperref's identifiers unique
-    \gdef\theHsection{Appendix.\Alph{section}}%
+    \def\theHsection{Appendix.\Alph{section}}%
     % v1.6 adjust hyperref's string name for the section
     \xdef\Hy@chapapp{appendix}%
     \setcounter{section}{-1}% we want \refstepcounter to use section 0
     \setcounter{subsection}{0}%
     \setcounter{subsubsection}{0}%
     \setcounter{paragraph}{0}%
-    \ifCLASSOPTIONromanappendices%
-    \gdef\thesection{\Roman{section}}%
-    \gdef\thesectiondis{\Roman{section}}%
-    \@IEEEcompsocconfonly{\gdef\thesectiondis{\Roman{section}.}}%
-    \gdef\@IEEEthmcounterinsection##1{A\arabic{##1}}
+    \ifuseRomanappendices%
+    \def\thesection{\Roman{section}}%
+    \def\thesectiondis{\Roman{section}}%
     \else%
-    \gdef\thesection{\Alph{section}}%
-    \gdef\thesectiondis{\Alph{section}}%
-    \@IEEEcompsocconfonly{\gdef\thesectiondis{\Alph{section}.}}%
-    \gdef\@IEEEthmcounterinsection##1{\Alph{##1}}
+    \def\thesection{\Alph{section}}%
+    \def\thesectiondis{\Alph{section}}%
     \fi%
     \refstepcounter{section}% update the \ref counter
     \setcounter{section}{0}% NEXT \section will be the FIRST appendix
@@ -4140,7 +4107,7 @@



-% \IEEEPARstart
+% \PARstart
 % Definition for the big two line drop cap letter at the beginning of the
 % first paragraph of journal papers. The first argument is the first letter
 % of the first word, the second argument is the remaining letters of the
@@ -4148,7 +4115,7 @@
 % In V1.6 this has been completely rewritten to:
 %
 % 1. no longer have problems when the user begins an environment
-%    within the paragraph that uses \IEEEPARstart.
+%    within the paragraph that uses \PARstart.
 % 2. auto-detect and use the current font family
 % 3. revise handling of the space at the end of the first word so that
 %    interword glue will now work as normal.
@@ -4156,88 +4123,57 @@
 %
 % We generalize things via control macros - playing with these is fun too.
 %
-% V1.7 added more control macros to make it easy for IEEEtrantools.sty users
-% to change the font style.
-%
 % the number of lines that are indented to clear it
-% may need to increase if using decenders
 \def\@IEEEPARstartDROPLINES{2}
-% minimum number of lines left on a page to allow a \@IEEEPARstart
+% minimum number of lines left on a page to allow a \@PARstart
 % Does not take into consideration rubber shrink, so it tends to
 % be overly cautious
 \def\@IEEEPARstartMINPAGELINES{2}
-% V1.7 the height of the drop cap is adjusted to match the height of this text
-% in the current font (when \IEEEPARstart is called).
-\def\@IEEEPARstartHEIGHTTEXT{T}
 % the depth the letter is lowered below the baseline
 % the height (and size) of the letter is determined by the sum
-% of this value and the height of the \@IEEEPARstartHEIGHTTEXT in the current
+% of this value and the height of a capital "T" in the current
 % font. It is a good idea to set this value in terms of the baselineskip
 % so that it can respond to changes therein.
 \def\@IEEEPARstartDROPDEPTH{1.1\baselineskip}
-% V1.7 the font the drop cap will be rendered in,
-% can take zero or one argument.
-\def\@IEEEPARstartFONTSTYLE{\bfseries}
-% V1.7 any additional, non-font related commands needed to modify
-% the drop cap letter, can take zero or one argument.
-\def\@IEEEPARstartCAPSTYLE{\MakeUppercase}
-% V1.7 the font that will be used to render the rest of the word,
-% can take zero or one argument.
-\def\@IEEEPARstartWORDFONTSTYLE{\relax}
-% V1.7 any additional, non-font related commands needed to modify
-% the rest of the word, can take zero or one argument.
-\def\@IEEEPARstartWORDCAPSTYLE{\MakeUppercase}
-% This is the horizontal separation distance from the drop letter to the main text.
-% Lengths that depend on the font (e.g., ex, em, etc.) will be referenced
-% to the font that is active when \IEEEPARstart is called.
+% This is the separation distance from the drop letter to the main text.
+% Lengths that depend on the font (i.e., ex, em, etc.) will be referenced
+% to the font that is active when PARstart is called.
 \def\@IEEEPARstartSEP{0.15em}
-% V1.7 horizontal offset applied to the left of the drop cap.
-\def\@IEEEPARstartHOFFSET{0em}
-% V1.7 Italic correction command applied at the end of the drop cap.
-\def\@IEEEPARstartITLCORRECT{\/}
-
-% V1.7 compoc uses nonbold drop cap and small caps word style
-\ifCLASSOPTIONcompsoc
-\def\@IEEEPARstartFONTSTYLE{\mdseries}
-\def\@IEEEPARstartWORDFONTSTYLE{\scshape}
-\def\@IEEEPARstartWORDCAPSTYLE{\relax}
-\fi

-% definition of \IEEEPARstart
+
+% definition of \PARstart
 % THIS IS A CONTROLLED SPACING AREA, DO NOT ALLOW SPACES WITHIN THESE LINES
 %
 % The token \@IEEEPARstartfont will be globally defined after the first use
-% of \IEEEPARstart and will be a font command which creates the big letter
+% of \PARstart and will be a font command which creates the big letter
 % The first argument is the first letter of the first word and the second
 % argument is the rest of the first word(s).
-\def\IEEEPARstart#1#2{\par{%
+\def\PARstart#1#2{\par{%
 % if this page does not have enough space, break it and lets start
 % on a new one
 \@IEEEtranneedspace{\@IEEEPARstartMINPAGELINES\baselineskip}{\relax}%
-% V1.7 move this up here in case user uses \textbf for \@IEEEPARstartFONTSTYLE
-% which uses command \leavevmode which causes an unwanted \indent to be issued
-\noindent
 % calculate the desired height of the big letter
-% it extends from the top of \@IEEEPARstartHEIGHTTEXT in the current font
+% it extends from the top of a capital "T" in the current font
 % down to \@IEEEPARstartDROPDEPTH below the current baseline
-\settoheight{\@IEEEtrantmpdimenA}{\@IEEEPARstartHEIGHTTEXT}%
+\settoheight{\@IEEEtrantmpdimenA}{T}%
 \addtolength{\@IEEEtrantmpdimenA}{\@IEEEPARstartDROPDEPTH}%
 % extract the name of the current font in bold
 % and place it in \@IEEEPARstartFONTNAME
 \def\@IEEEPARstartGETFIRSTWORD##1 ##2\relax{##1}%
-{\@IEEEPARstartFONTSTYLE{\selectfont\edef\@IEEEPARstartFONTNAMESPACE{\fontname\font\space}%
-\xdef\@IEEEPARstartFONTNAME{\expandafter\@IEEEPARstartGETFIRSTWORD\@IEEEPARstartFONTNAMESPACE\relax}}}%
+{\bfseries%
+\edef\@IEEEPARstartFONTNAMESPACE{\fontname\font\space}%
+\xdef\@IEEEPARstartFONTNAME{\expandafter\@IEEEPARstartGETFIRSTWORD\@IEEEPARstartFONTNAMESPACE\relax}}%
 % define a font based on this name with a point size equal to the desired
 % height of the drop letter
 \font\@IEEEPARstartsubfont\@IEEEPARstartFONTNAME\space at \@IEEEtrantmpdimenA\relax%
 % save this value as a counter (integer) value (sp points)
 \@IEEEtrantmpcountA=\@IEEEtrantmpdimenA%
 % now get the height of the actual letter produced by this font size
-\settoheight{\@IEEEtrantmpdimenB}{\@IEEEPARstartsubfont\@IEEEPARstartCAPSTYLE{#1}}%
+\settoheight{\@IEEEtrantmpdimenB}{\@IEEEPARstartsubfont\MakeUppercase{#1}}%
 % If something bogus happens like the first argument is empty or the
 % current font is strange, do not allow a zero height.
 \ifdim\@IEEEtrantmpdimenB=0pt\relax%
-\typeout{** WARNING: IEEEPARstart drop letter has zero height! (line \the\inputlineno)}%
+\typeout{** WARNING: PARstart drop letter has zero height! (line \the\inputlineno)}%
 \typeout{ Forcing the drop letter font size to 10pt.}%
 \@IEEEtrantmpdimenB=10pt%
 \fi%
@@ -4265,30 +4201,23 @@
 % Now set \@IEEEtrantmpdimenA to the width of the big letter
 % We need to carry this out of the local calculation area to set the
 % hanging indent
-\settowidth{\global\@IEEEtrantmpdimenA}{\@IEEEPARstartfont
-\@IEEEPARstartCAPSTYLE{#1\@IEEEPARstartITLCORRECT}}}%
+\settowidth{\global\@IEEEtrantmpdimenA}{\@IEEEPARstartfont\MakeUppercase{#1}}}%
 % end of the isolated calculation environment
 % add in the extra clearance we want
-\advance\@IEEEtrantmpdimenA by \@IEEEPARstartSEP\relax%
-% add in the optional offset
-\advance\@IEEEtrantmpdimenA by \@IEEEPARstartHOFFSET\relax%
-% V1.7 don't allow negative offsets to produce negative hanging indents
-\@IEEEtrantmpdimenB\@IEEEtrantmpdimenA
-\ifnum\@IEEEtrantmpdimenB < 0 \@IEEEtrantmpdimenB 0pt\fi
+\advance\@IEEEtrantmpdimenA by \@IEEEPARstartSEP%
 % \@IEEEtrantmpdimenA has the width of the big letter plus the
 % separation space and \@IEEEPARstartfont is the font we need to use
 % Now, we make the letter and issue the hanging indent command
 % The letter is placed in a box of zero width and height so that other
 % text won't be displaced by it.
-\hangindent\@IEEEtrantmpdimenB\hangafter=-\@IEEEPARstartDROPLINES%
-\makebox[0pt][l]{\hspace{-\@IEEEtrantmpdimenA}%
-\raisebox{-\@IEEEPARstartDROPDEPTH}[0pt][0pt]{\hspace{\@IEEEPARstartHOFFSET}%
-\@IEEEPARstartfont\@IEEEPARstartCAPSTYLE{#1\@IEEEPARstartITLCORRECT}%
-\hspace{\@IEEEPARstartSEP}}}%
-{\@IEEEPARstartWORDFONTSTYLE{\@IEEEPARstartWORDCAPSTYLE{\selectfont#2}}}}
-
+\noindent\hangindent\@IEEEtrantmpdimenA\hangafter=-\@IEEEPARstartDROPLINES%
+\makebox[0pt][l]{\hspace{-\@IEEEtrantmpdimenA}\raisebox{-\@IEEEPARstartDROPDEPTH}[0pt][0pt]{\@IEEEPARstartfont\MakeUppercase{#1}}}\MakeUppercase{#2}}


+% V1.6 \CMPARstart is no longer needed as \PARstart now uses whatever
+% the current font family is.
+% \CMPARstart is provided here for backward compatability.
+\let\CMPARstart=\PARstart



@@ -4314,20 +4243,20 @@



-% IEEEbiography ENVIRONMENT
-% Allows user to enter biography leaving place for picture (adapts to font size)
+% BIOGRAPHY ENVIRONMENT
+% Allows user to enter BIOGRAPHY leaving place for picture (adapts to font size)
 % As of V1.5, a new optional argument allows you to have a real graphic!
 % V1.5 and later also fixes the "colliding biographies" which could happen when a
 % biography's text was shorter than the space for the photo.
 % MDS 7/2001
 % V1.6 prevent multiple biographies from making multiple TOC entries
-\newif\if@IEEEbiographyTOCentrynotmade
-\global\@IEEEbiographyTOCentrynotmadetrue
+\newif\if@biographyTOCentrynotmade
+\global\@biographyTOCentrynotmadetrue

 % biography counter so hyperref can jump directly to the biographies
 % and not just the previous section
-\newcounter{IEEEbiography}
-\setcounter{IEEEbiography}{0}
+\newcounter{biography}
+\setcounter{biography}{0}

 % photo area size
 \def\@IEEEBIOphotowidth{1.0in}    % width of the biography photo area
@@ -4339,7 +4268,7 @@
                                   % \baselineskip, rounded up
 \def\@IEEEBIOskipN{4\baselineskip}% nominal value of the vskip above the biography

-\newenvironment{IEEEbiography}[2][]{\normalfont\@IEEEcompsoconly{\sffamily}\footnotesize%
+\newenvironment{biography}[2][]{\normalfont\footnotesize%
 \unitlength 1in\parskip=0pt\par\parindent 1em\interlinepenalty500%
 % we need enough space to support the hanging indent
 % the nominal value of the spacer
@@ -4353,8 +4282,7 @@
 % nominal spacer can strech, not shrink use 1fil so user can out stretch with \vfill
 \vskip \@IEEEBIOskipN plus 1fil minus 0\baselineskip%
 % the default box for where the photo goes
-\def\@IEEEtempbiographybox{{\setlength{\fboxsep}{0pt}\framebox{%
-\begin{minipage}[b][\@IEEEBIOphotodepth][c]{\@IEEEBIOphotowidth}\centering PLACE\\ PHOTO\\ HERE \end{minipage}}}}%
+\def\@IEEEtempbiographybox{{\setlength{\fboxsep}{0pt}\framebox{\begin{minipage}[b][\@IEEEBIOphotodepth][c]{\@IEEEBIOphotowidth}\centering PLACE\\ PHOTO\\ HERE \end{minipage}}}}%
 %
 % detect if the optional argument was supplied, this requires the
 % \@ifmtarg command as defined in the appendix section above
@@ -4364,16 +4292,16 @@
 #1%
 \end{minipage}}}}% end if optional argument supplied
 % Make an entry into the table of contents only if we have not done so before
-\if@IEEEbiographyTOCentrynotmade%
+\if@biographyTOCentrynotmade%
 % link labels to the biography counter so hyperref will jump
 % to the biography, not the previous section
-\setcounter{IEEEbiography}{-1}%
-\refstepcounter{IEEEbiography}%
+\setcounter{biography}{-1}%
+\refstepcounter{biography}%
 \addcontentsline{toc}{section}{Biographies}%
-\global\@IEEEbiographyTOCentrynotmadefalse%
+\global\@biographyTOCentrynotmadefalse%
 \fi%
 % one more biography
-\refstepcounter{IEEEbiography}%
+\refstepcounter{biography}%
 % Make an entry for this name into the table of contents
 \addcontentsline{toc}{subsection}{#2}%
 % V1.6 properly handle if a new paragraph should occur while the
@@ -4393,8 +4321,7 @@
 % reference the top of the photo area to the top of a capital T
 \settoheight{\@IEEEtrantmpdimenB}{\mbox{T}}%
 % set the photo box, give it zero width and height so as not to disturb anything
-\noindent\makebox[0pt][l]{\hspace{-\@IEEEBIOhangwidth}\raisebox{\@IEEEtrantmpdimenB}[0pt][0pt]{%
-\raisebox{-\@IEEEBIOphotodepth}[0pt][0pt]{\@IEEEtempbiographybox}}}%
+\noindent\makebox[0pt][l]{\hspace{-\@IEEEBIOhangwidth}\raisebox{\@IEEEtrantmpdimenB}[0pt][0pt]{\raisebox{-\@IEEEBIOphotodepth}[0pt][0pt]{\@IEEEtempbiographybox}}}%
 % now place the author name and begin the bio text
 \noindent\textbf{#2\ }\@IEEEgobbleleadPARNLSP}{\relax\let\par=\@IEEEBIOORGparCMD\par%
 % 7/2001 V1.5 detect when the biography text is shorter than the photo area
@@ -4413,21 +4340,21 @@

 % V1.6
 % added biography without a photo environment
-\newenvironment{IEEEbiographynophoto}[1]{%
+\newenvironment{biographynophoto}[1]{%
 % Make an entry into the table of contents only if we have not done so before
-\if@IEEEbiographyTOCentrynotmade%
+\if@biographyTOCentrynotmade%
 % link labels to the biography counter so hyperref will jump
 % to the biography, not the previous section
-\setcounter{IEEEbiography}{-1}%
-\refstepcounter{IEEEbiography}%
+\setcounter{biography}{-1}%
+\refstepcounter{biography}%
 \addcontentsline{toc}{section}{Biographies}%
-\global\@IEEEbiographyTOCentrynotmadefalse%
+\global\@biographyTOCentrynotmadefalse%
 \fi%
 % one more biography
-\refstepcounter{IEEEbiography}%
+\refstepcounter{biography}%
 % Make an entry for this name into the table of contents
 \addcontentsline{toc}{subsection}{#1}%
-\normalfont\@IEEEcompsoconly{\sffamily}\footnotesize\interlinepenalty500%
+\normalfont\footnotesize\interlinepenalty500%
 \vskip 4\baselineskip plus 1fil minus 0\baselineskip%
 \parskip=0pt\par%
 \noindent\textbf{#1\ }\@IEEEgobbleleadPARNLSP}{\relax\par\normalfont}
@@ -4449,14 +4376,14 @@
 % SPECIAL PAPER NOTICE COMMANDS
 %
 % holds the special notice text
-\def\@IEEEspecialpapernotice{\relax}
+\def\@specialpapernotice{\relax}

 % for special papers, like invited papers, the user can do:
-% \IEEEspecialpapernotice{(Invited Paper)} before \maketitle
-\def\IEEEspecialpapernotice#1{\ifCLASSOPTIONconference%
-\def\@IEEEspecialpapernotice{{\sublargesize\textit{#1}\vspace*{1em}}}%
+% \specialpapernotice{(Invited Paper)} before \maketitle
+\def\specialpapernotice#1{\if@confmode%
+\def\@specialpapernotice{{\sublargesize\textit{#1}\vspace*{1em}}}%
 \else%
-\def\@IEEEspecialpapernotice{{\\*[1.5ex]\sublargesize\textit{#1}}\vspace*{-2ex}}%
+\def\@specialpapernotice{{\\*[1.5ex]\sublargesize\textit{#1}}\vspace*{-2ex}}%
 \fi}


@@ -4464,9 +4391,9 @@

 % PUBLISHER ID COMMANDS
 % to insert a publisher's ID footer
-% V1.6 \IEEEpubid has been changed so that the change in page size and style
-% occurs in \maketitle. \IEEEpubid must now be issued prior to \maketitle
-% use \IEEEpubidadjcol as before - in the second column of the title page
+% V1.6 \pubid has been changed so that the change in page size and style
+% occurs in \maketitle. \pubid must now be issued prior to \maketitle
+% use \pubidadjcol as before - in the second column of the title page
 % These changes allow \maketitle to take the reduced page height into
 % consideration when dynamically setting the space between the author
 % names and the maintext.
@@ -4475,8 +4402,8 @@
 % publisher's ID footer
 % IEEE uses about 1.3\baselineskip for journals,
 % dynamic title spacing will clean up the fraction
-\def\@IEEEpubidpullup{1.3\baselineskip}
-\ifCLASSOPTIONtechnote
+\def\@pubidpullup{1.3\baselineskip}
+\if@technote
 % for technotes it must be an integer of baselineskip as there can be no
 % dynamic title spacing for two column mode technotes (the title is in the
 % in first column) and we should maintain an integer number of lines in the
@@ -4485,42 +4412,35 @@
 % Information Theory") in which IEEE really pulls the text off the ID for
 % technotes - about 0.55in (or 4\baselineskip). We'll use 2\baselineskip
 % and call it even.
-\def\@IEEEpubidpullup{2\baselineskip}
-\fi
-
-% V1.7 compsoc does not use a pullup
-\ifCLASSOPTIONcompsoc
-\def\@IEEEpubidpullup{0pt}
+\def\@pubidpullup{2\baselineskip}
 \fi

 % holds the ID text
-\def\@IEEEpubid{\relax}
+\def\@pubid{\relax}

-% flag so \maketitle can tell if \IEEEpubid was called
+% flag so \maketitle can tell if \pubid was called
 \newif\if@IEEEusingpubid
 \global\@IEEEusingpubidfalse
 % issue this command in the page to have the ID at the bottom
 % V1.6 use before \maketitle
-\def\IEEEpubid#1{\def\@IEEEpubid{#1}\global\@IEEEusingpubidtrue}
+\def\pubid#1{\def\@pubid{#1} \global\@IEEEusingpubidtrue}


 % command which will pull up (shorten) the column it is executed in
 % to make room for the publisher ID. Place in the second column of
-% the title page when using \IEEEpubid
+% the title page when using \pubid
 % Is smart enough not to do anything when in single column text or
-% if the user hasn't called \IEEEpubid
+% if the user hasn't called \pubid
 % currently needed in for the second column of a page with the
 % publisher ID. If not needed in future releases, please provide this
 % command and define it as \relax for backward compatibility
 % v1.6b do not allow command to operate if the peer review option has been
-% selected because \IEEEpubidadjcol will not be on the cover page.
-% V1.7 do nothing if compsoc
-\def\IEEEpubidadjcol{\ifCLASSOPTIONcompsoc\else\ifCLASSOPTIONpeerreview\else
-\if@twocolumn\if@IEEEusingpubid\enlargethispage{-\@IEEEpubidpullup}\fi\fi\fi\fi}
+% selected because \pubidadjcol will not be on the cover page.
+\def\pubidadjcol{\if@peerreviewoption\else\if@twocolumn\if@IEEEusingpubid\enlargethispage{-\@pubidpullup}\fi\fi\fi}

 % Special thanks to Peter Wilson, Daniel Luecking, and the other
 % gurus at comp.text.tex, for helping me to understand how best to
-% implement the IEEEpubid command in LaTeX.
+% implement the pubid command in LaTeX.



@@ -4531,19 +4451,23 @@

 % flags to prevent multiple warning messages
 \newif\if@IEEEWARNthanks
-\newif\if@IEEEWARNIEEEPARstart
-\newif\if@IEEEWARNIEEEbiography
-\newif\if@IEEEWARNIEEEbiographynophoto
-\newif\if@IEEEWARNIEEEpubid
-\newif\if@IEEEWARNIEEEpubidadjcol
+\newif\if@IEEEWARNPARstart
+\newif\if@IEEEWARNCMPARstart
+\newif\if@IEEEWARNkeywords
+\newif\if@IEEEWARNbiography
+\newif\if@IEEEWARNbiographynophoto
+\newif\if@IEEEWARNpubid
+\newif\if@IEEEWARNpubidadjcol
 \newif\if@IEEEWARNIEEEmembership
 \newif\if@IEEEWARNIEEEaftertitletext
 \@IEEEWARNthankstrue
-\@IEEEWARNIEEEPARstarttrue
-\@IEEEWARNIEEEbiographytrue
-\@IEEEWARNIEEEbiographynophototrue
-\@IEEEWARNIEEEpubidtrue
-\@IEEEWARNIEEEpubidadjcoltrue
+\@IEEEWARNPARstarttrue
+\@IEEEWARNCMPARstarttrue
+\@IEEEWARNkeywordstrue
+\@IEEEWARNbiographytrue
+\@IEEEWARNbiographynophototrue
+\@IEEEWARNpubidtrue
+\@IEEEWARNpubidadjcoltrue
 \@IEEEWARNIEEEmembershiptrue
 \@IEEEWARNIEEEaftertitletexttrue

@@ -4553,45 +4477,49 @@
 % save commands which might be locked out
 % so that the user can later restore them if needed
 \let\@IEEESAVECMDthanks\thanks
-\let\@IEEESAVECMDIEEEPARstart\IEEEPARstart
-\let\@IEEESAVECMDIEEEbiography\IEEEbiography
-\let\@IEEESAVECMDendIEEEbiography\endIEEEbiography
-\let\@IEEESAVECMDIEEEbiographynophoto\IEEEbiographynophoto
-\let\@IEEESAVECMDendIEEEbiographynophoto\endIEEEbiographynophoto
-\let\@IEEESAVECMDIEEEpubid\IEEEpubid
-\let\@IEEESAVECMDIEEEpubidadjcol\IEEEpubidadjcol
+\let\@IEEESAVECMDPARstart\PARstart
+\let\@IEEESAVECMDCMPARstart\CMPARstart
+\let\@IEEESAVECMDkeywords\keywords
+\let\@IEEESAVECMDendkeywords\endkeywords
+\let\@IEEESAVECMDbiography\biography
+\let\@IEEESAVECMDendbiography\endbiography
+\let\@IEEESAVECMDbiographynophoto\biographynophoto
+\let\@IEEESAVECMDendbiographynophoto\endbiographynophoto
+\let\@IEEESAVECMDpubid\pubid
+\let\@IEEESAVECMDpubidadjcol\pubidadjcol
 \let\@IEEESAVECMDIEEEmembership\IEEEmembership
 \let\@IEEESAVECMDIEEEaftertitletext\IEEEaftertitletext


-% disable \IEEEPARstart when in draft mode
+% disable \PARstart when in draft mode
 % This may have originally been done because the pre-V1.6 drop letter
 % algorithm had problems with a non-unity baselinestretch
 % At any rate, it seems too formal to have a drop letter in a draft
 % paper.
-\ifCLASSOPTIONdraftcls
-\def\IEEEPARstart#1#2{#1#2\if@IEEEWARNIEEEPARstart\typeout{** ATTENTION: \noexpand\IEEEPARstart
- is disabled in draft mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEPARstartfalse}
+\if@draftclsmode
+\def\PARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** ATTENTION: \noexpand\PARstart is disabled in draft mode (line \the\inputlineno).}\fi\global\@IEEEWARNPARstartfalse}
+\def\CMPARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** ATTENTION: \noexpand\CMPARstart is disabled in draft mode (line \the\inputlineno).}\fi\global\@IEEEWARNCMPARstartfalse}
 \fi
 % and for technotes
-\ifCLASSOPTIONtechnote
-\def\IEEEPARstart#1#2{#1#2\if@IEEEWARNIEEEPARstart\typeout{** WARNING: \noexpand\IEEEPARstart
- is locked out for technotes (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEPARstartfalse}
+\if@technote
+\def\PARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** WARNING: \noexpand\PARstart is locked out for technotes (line \the\inputlineno).}\fi\global\@IEEEWARNPARstartfalse}
+\def\CMPARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** WARNING: \noexpand\CMPARstart is locked out for technotes (line \the\inputlineno).}\fi\global\@IEEEWARNCMPARstartfalse}
 \fi


 % lockout unneeded commands when in conference mode
-\ifCLASSOPTIONconference
-% when locked out, \thanks, \IEEEbiography, \IEEEbiographynophoto, \IEEEpubid,
+\if@confmode
+% when locked out, \thanks, \keywords, \biography, \biographynophoto, \pubid,
 % \IEEEmembership and \IEEEaftertitletext will all swallow their given text.
-% \IEEEPARstart will output a normal character instead
+% \PARstart and \CMPARstart will output a normal character instead
 % warn the user about these commands only once to prevent the console screen
 % from filling up with redundant messages
-\def\thanks#1{\if@IEEEWARNthanks\typeout{** WARNING: \noexpand\thanks
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNthanksfalse}
-\def\IEEEPARstart#1#2{#1#2\if@IEEEWARNIEEEPARstart\typeout{** WARNING: \noexpand\IEEEPARstart
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEPARstartfalse}
+\def\thanks#1{\if@IEEEWARNthanks\typeout{** WARNING: \noexpand\thanks is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNthanksfalse}
+\def\PARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** WARNING: \noexpand\PARstart is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNPARstartfalse}
+\def\CMPARstart#1#2{#1#2\if@IEEEWARNPARstart\typeout{** WARNING: \noexpand\CMPARstart is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNCMPARstartfalse}

+\renewenvironment{keywords}[1]{\if@IEEEWARNkeywords\typeout{** WARNING: \noexpand\keywords is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNkeywordsfalse%
+\setbox\@IEEEtranrubishbin\vbox\bgroup}{\egroup\relax}

 % LaTeX treats environments and commands with optional arguments differently.
 % the actual ("internal") command is stored as \\commandname
@@ -4603,25 +4531,19 @@
 % ever changes the way it names the internal names, the trick would break.
 % Instead let us just define a new environment so that the internal
 % name can be left undisturbed.
-\newenvironment{@IEEEbogusbiography}[2][]{\if@IEEEWARNIEEEbiography\typeout{** WARNING: \noexpand\IEEEbiography
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEbiographyfalse%
+\newenvironment{@IEEEbogusbiography}[2][]{\if@IEEEWARNbiography\typeout{** WARNING: \noexpand\biography is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNbiographyfalse%
 \setbox\@IEEEtranrubishbin\vbox\bgroup}{\egroup\relax}
 % and make biography point to our bogus biography
-\let\IEEEbiography=\@IEEEbogusbiography
-\let\endIEEEbiography=\end@IEEEbogusbiography
+\let\biography=\@IEEEbogusbiography
+\let\endbiography=\end@IEEEbogusbiography

-\renewenvironment{IEEEbiographynophoto}[1]{\if@IEEEWARNIEEEbiographynophoto\typeout{** WARNING: \noexpand\IEEEbiographynophoto
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEbiographynophotofalse%
+\renewenvironment{biographynophoto}[1]{\if@IEEEWARNbiographynophoto\typeout{** WARNING: \noexpand\biographynophoto is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNbiographynophotofalse%
 \setbox\@IEEEtranrubishbin\vbox\bgroup}{\egroup\relax}

-\def\IEEEpubid#1{\if@IEEEWARNIEEEpubid\typeout{** WARNING: \noexpand\IEEEpubid
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEpubidfalse}
-\def\IEEEpubidadjcol{\if@IEEEWARNIEEEpubidadjcol\typeout{** WARNING: \noexpand\IEEEpubidadjcol
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEpubidadjcolfalse}
-\def\IEEEmembership#1{\if@IEEEWARNIEEEmembership\typeout{** WARNING: \noexpand\IEEEmembership
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEmembershipfalse}
-\def\IEEEaftertitletext#1{\if@IEEEWARNIEEEaftertitletext\typeout{** WARNING: \noexpand\IEEEaftertitletext
- is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEaftertitletextfalse}
+\def\pubid#1{\if@IEEEWARNpubid\typeout{** WARNING: \noexpand\pubid is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNpubidfalse}
+\def\pubidadjcol{\if@IEEEWARNpubidadjcol\typeout{** WARNING: \noexpand\pubidadjcol is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNpubidadjcolfalse}
+\def\IEEEmembership#1{\if@IEEEWARNIEEEmembership\typeout{** WARNING: \noexpand\IEEEmembership is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEmembershipfalse}
+\def\IEEEaftertitletext#1{\if@IEEEWARNIEEEaftertitletext\typeout{** WARNING: \noexpand\IEEEaftertitletext is locked out when in conference mode (line \the\inputlineno).}\fi\global\@IEEEWARNIEEEaftertitletextfalse}
 \fi


@@ -4629,72 +4551,20 @@
 \def\IEEEoverridecommandlockouts{%
 \typeout{** ATTENTION: Overriding command lockouts (line \the\inputlineno).}%
 \let\thanks\@IEEESAVECMDthanks%
-\let\IEEEPARstart\@IEEESAVECMDIEEEPARstart%
-\let\IEEEbiography\@IEEESAVECMDIEEEbiography%
-\let\endIEEEbiography\@IEEESAVECMDendIEEEbiography%
-\let\IEEEbiographynophoto\@IEEESAVECMDIEEEbiographynophoto%
-\let\endIEEEbiographynophoto\@IEEESAVECMDendIEEEbiographynophoto%
-\let\IEEEpubid\@IEEESAVECMDIEEEpubid%
-\let\IEEEpubidadjcol\@IEEESAVECMDIEEEpubidadjcol%
+\let\PARstart\@IEEESAVECMDPARstart%
+\let\CMPARstart\@IEEESAVECMDCMPARstart%
+\let\keywords\@IEEESAVECMDkeywords%
+\let\endkeywords\@IEEESAVECMDendkeywords%
+\let\biography\@IEEESAVECMDbiography%
+\let\endbiography\@IEEESAVECMDendbiography%
+\let\biographynophoto\@IEEESAVECMDbiographynophoto%
+\let\endbiographynophoto\@IEEESAVECMDendbiographynophoto%
+\let\pubid\@IEEESAVECMDpubid%
+\let\pubidadjcol\@IEEESAVECMDpubidadjcol%
 \let\IEEEmembership\@IEEESAVECMDIEEEmembership%
 \let\IEEEaftertitletext\@IEEESAVECMDIEEEaftertitletext}


-
-% need a backslash character for typeout output
-{\catcode`\|=0 \catcode`\\=12
-|xdef|@IEEEbackslash{\}}
-
-
-% hook to allow easy disabling of all legacy warnings
-\def\@IEEElegacywarn#1#2{\typeout{** ATTENTION: \@IEEEbackslash #1 is deprecated (line \the\inputlineno).
-Use \@IEEEbackslash #2 instead.}}
-
-
-% provide for legacy commands
-\def\authorblockA{\@IEEElegacywarn{authorblockA}{IEEEauthorblockA}\IEEEauthorblockA}
-\def\authorblockN{\@IEEElegacywarn{authorblockN}{IEEEauthorblockN}\IEEEauthorblockN}
-\def\authorrefmark{\@IEEElegacywarn{authorrefmark}{IEEEauthorrefmark}\IEEEauthorrefmark}
-\def\PARstart{\@IEEElegacywarn{PARstart}{IEEEPARstart}\IEEEPARstart}
-\def\pubid{\@IEEElegacywarn{pubid}{IEEEpubid}\IEEEpubid}
-\def\pubidadjcol{\@IEEElegacywarn{pubidadjcol}{IEEEpubidadjcol}\IEEEpubidadjcol}
-\def\QED{\@IEEElegacywarn{QED}{IEEEQED}\IEEEQED}
-\def\QEDclosed{\@IEEElegacywarn{QEDclosed}{IEEEQEDclosed}\IEEEQEDclosed}
-\def\QEDopen{\@IEEElegacywarn{QEDopen}{IEEEQEDopen}\IEEEQEDopen}
-\def\specialpapernotice{\@IEEElegacywarn{specialpapernotice}{IEEEspecialpapernotice}\IEEEspecialpapernotice}
-
-
-
-% provide for legacy environments
-\def\biography{\@IEEElegacywarn{biography}{IEEEbiography}\IEEEbiography}
-\def\biographynophoto{\@IEEElegacywarn{biographynophoto}{IEEEbiographynophoto}\IEEEbiographynophoto}
-\def\keywords{\@IEEElegacywarn{keywords}{IEEEkeywords}\IEEEkeywords}
-\def\endbiography{\endIEEEbiography}
-\def\endbiographynophoto{\endIEEEbiographynophoto}
-\def\endkeywords{\endIEEEkeywords}
-
-
-% provide for legacy IED commands/lengths when possible
-\let\labelindent\IEEElabelindent
-\def\calcleftmargin{\@IEEElegacywarn{calcleftmargin}{IEEEcalcleftmargin}\IEEEcalcleftmargin}
-\def\setlabelwidth{\@IEEElegacywarn{setlabelwidth}{IEEEsetlabelwidth}\IEEEsetlabelwidth}
-\def\usemathlabelsep{\@IEEElegacywarn{usemathlabelsep}{IEEEusemathlabelsep}\IEEEusemathlabelsep}
-\def\iedlabeljustifyc{\@IEEElegacywarn{iedlabeljustifyc}{IEEEiedlabeljustifyc}\IEEEiedlabeljustifyc}
-\def\iedlabeljustifyl{\@IEEElegacywarn{iedlabeljustifyl}{IEEEiedlabeljustifyl}\IEEEiedlabeljustifyl}
-\def\iedlabeljustifyr{\@IEEElegacywarn{iedlabeljustifyr}{IEEEiedlabeljustifyr}\IEEEiedlabeljustifyr}
-
-
-
-% let \proof use the IEEEtran version even after amsthm is loaded
-% \proof is now deprecated in favor of \IEEEproof
-\AtBeginDocument{\def\proof{\@IEEElegacywarn{proof}{IEEEproof}\IEEEproof}\def\endproof{\endIEEEproof}}
-
-% V1.7 \overrideIEEEmargins is no longer supported.
-\def\overrideIEEEmargins{%
-\typeout{** WARNING: \string\overrideIEEEmargins \space no longer supported (line \the\inputlineno).}%
-\typeout{** Use the \string\CLASSINPUTinnersidemargin, \string\CLASSINPUToutersidemargin \space controls instead.}}
-
-
 \endinput

 %%%%%%%%%%%%%%%%%%%%%%%%%%%%% End of IEEEtran.cls  %%%%%%%%%%%%%%%%%%%%%%%%%%%%

 

Close Window
 
  The service has been written by
Heinrich Stamerjohanns