What is the rationale for requiring \DeclareMathOperator to be in the preamble?
Why are users not allowed to restrict the scope of an operator definition to a particular chapter or environment, like \newcommand?
I guess there are two components to an answer to your "why" question.
Most immediately, there's an \@onlypreamble qualifier for many setup-type macros of the amsmath package to make sure they won't work if invoked outside the preamble. The macro \DeclareMathOperator is defined in the file amsopn.sty, which is loaded by amsmath.sty; note the instruction \@onlypreamble\DeclareMathOperator at ca line 57 of amsopn.sty.
You might then ask, so why is the \@onlypreamble qualifier imposed? I wasn't involved in the design or creation of the amsmath package, but I'd say a reasonable guess is that the creators were adhering to the spirit of the LaTeX2e format, which strongly encourages separating matters of content from matters of visual display of the content. The latter matters are supposed to be taken care of in the preamble.
To address your related concern, i.e., having various chapters that may require different definitions of one and the same operator-type macro. For concreteness, let's say the operator is called \det. The creators of the amsmath package either didn't envisage a use case such as the one you've set forth here or, quite possibly, they may have believed that it's better to define all possible variants of \det -- say, \detA and \detB -- in the preamble and then execute a \let of \det to either \detA or \detB at the start of each chapter.
\@onlypreamble any commands that we could get rid of, freed up enough memory that you could (just about) typeset a hello world document without running out of memory.
– David Carlisle
May 07 '14 at 08:22
amsmath package. :-)
– Mico
May 07 '14 at 08:31
In the case of \DeclareMathOperator, contrarily to the LaTeX issues raised in this question: Why does LaTeX make \DeclareMathSymbol and \DeclareSymbolFont preamble-only?, the user is provided with a simple possibility to circumvent the only-preamble restriction: it is to use the \operatorname or \operatornamewithlimits command, also provided by amsmath (or more precisely amsopn where \DeclareMathOperator is defined and made preamble only).
\documentclass{article}
\usepackage{amsmath}
\begin{document}
\texttt{\textbackslash COS has meaning: \meaning\COS}
\texttt{\textbackslash cos has meaning: \meaning\cos}
\begin{large}
\newcommand{\COS}{\operatorname{COS}}
In this environment the math operator \verb|\COS| is defined: $\COS(x)=\cos(x)$.
\texttt{\textbackslash COS has meaning: \meaning\COS}
\end{large}
\texttt{\textbackslash COS now has meaning: \meaning\COS}
\end{document}
As an aside, there is an issue with \DeclareMathOperator and Unicode engines (if the minus sign is made a Unicode math character), which is fixed under lualatex by loading package lualatex-math
amsopn.sty, not amsopn.dtx which mentions indeed: For backwards compatibility we keep this old command name for the time being.
–
May 07 '14 at 10:00
\DeclareMathOperatordoesn't necessarily involve loading new symbol, I wonder if we can find a satisfactory explanation for mere math operators! – n.r. May 07 '14 at 06:32\newcommandany any place, you can as well\catcode`\\=\active, but I will call you names for doing so. Yours, Journal Typesetter. – yo' May 07 '14 at 06:49\newcommandfreely inside thedocumentenvironment? – n.r. May 07 '14 at 07:01\DeclareMathOperator, as I explain in my just posted answer. – May 07 '14 at 07:33