Conjugate

From APL Wiki
Revision as of 21:56, 10 September 2022 by Adám Brudzewsky (talk | contribs) (Text replacement - "<source" to "<syntaxhighlight")
Jump to navigation Jump to search
+

Conjugate (+) is a monadic scalar function which negates the imaginary component of a complex argument. Because many APLs do not have a dedicated Identity function, but also do not support complex numbers, Conjugate is often used to return the argument unchanged. This usage is discouraged in modern APLs in favor of the Identity function (usually <syntaxhighlight lang=apl inline>⊢</source>). Conjugate shares the glyph <syntaxhighlight lang=apl inline>+</source> with Add.

Examples

Conjugate leaves real numbers unchanged but negates the imaginary part of complex numbers. <syntaxhighlight lang=apl>

     + 0 2 ¯1.1 1E300 ¯200

0 2 ¯1.1 1E300 ¯200

     + 2J3 ¯4J¯3 ¯12 1.5J1.5

2J¯3 ¯4J3 ¯12 1.5J¯1.5 </source>

As identity function

In early APLs Conjugate was frequently used to return the argument unchanged, for example to display a shy result or break up stranding: <syntaxhighlight lang=apl>

     +a←2 3

2 3

     *∘2⍣3 +a

256 6561 </source> Sometimes the name "Identity" was even used for <syntaxhighlight lang=apl inline>+</source>. Although this usage is becoming rare among new APLers, it may still affect the behavior of Conjugate. For instance, in Dyalog APL, Conjugate will allow a non-numeric argument and return it unchanged even though other monadic scalar functions give a DOMAIN ERROR: <syntaxhighlight lang=apl>

     + ⎕NULL

[Null]

     - ⎕NULL

DOMAIN ERROR

     -⎕NULL
     ∧

</source>

Properties

Like Negate, Conjugate is its own Inverse.

The conjugate of a number is proportional to (that is, a real multiple of) its Reciprocal. Specifically, since for any complex number <syntaxhighlight lang=apl inline>z</source>, <syntaxhighlight lang=apl inline>z×+z</source> <syntaxhighlight lang=apl inline>(+z)×z</source> is a real number (the square of the Magnitude of <syntaxhighlight lang=apl inline>z</source>), we have <syntaxhighlight lang=apl inline>z×((+z)÷z×+z)</source> <syntaxhighlight lang=apl inline>1</source>, so by definition <syntaxhighlight lang=apl inline>(+z)÷z×+z</source> is <syntaxhighlight lang=apl inline>÷z</source>. If <syntaxhighlight lang=apl inline>z</source> is a unit complex number (for instance the result of Signum), then <syntaxhighlight lang=apl inline>+z</source> <syntaxhighlight lang=apl inline>÷z</source>.

Hypercomplex numbers

The conjugate of a hypercomplex number (a quaternion or octonion) negates all imaginary components, that is, every component but the real part. Somewhat surprisingly, this maintains the property that <syntaxhighlight lang=apl inline>z×+z</source> <syntaxhighlight lang=apl inline>(+z)×z</source> is a real number. Therefore the conjugate can be used to define the reciprocal of a complex number using only real division (dividing a hypercomplex number by a real number divides each component by that numer).

Numerical precision

Like Negate, Conjugate almost never suffers issues with numerical precision. This is because negating a component of a complex number is exact in all common number systems.

See also

External links

Mathematics

Documentation


APL built-ins [edit]
Primitives (Timeline) Functions
Scalar
Monadic ConjugateNegateSignumReciprocalMagnitudeExponentialNatural LogarithmFloorCeilingFactorialNotPi TimesRollTypeImaginarySquare Root
Dyadic AddSubtractTimesDivideResiduePowerLogarithmMinimumMaximumBinomialComparison functionsBoolean functions (And, Or, Nand, Nor) ∙ GCDLCMCircularComplexRoot
Non-Scalar
Structural ShapeReshapeTallyDepthRavelEnlistTableCatenateReverseRotateTransposeRazeMixSplitEncloseNestCut (K)PairLinkPartitioned EnclosePartition
Selection FirstPickTakeDropUniqueIdentityStopSelectReplicateExpandSet functions (IntersectionUnionWithout) ∙ Bracket indexingIndexCartesian ProductSort
Selector Index generatorGradeIndex OfInterval IndexIndicesDealPrefix and suffix vectors
Computational MatchNot MatchMembershipFindNub SieveEncodeDecodeMatrix InverseMatrix DivideFormatExecuteMaterialiseRange
Operators Monadic EachCommuteConstantReplicateExpandReduceWindowed ReduceScanOuter ProductKeyI-BeamSpawnFunction axis
Dyadic BindCompositions (Compose, Reverse Compose, Beside, Withe, Atop, Over) ∙ Inner ProductDeterminantPowerAtUnderRankDepthVariantStencilCutDirect definition (operator)
Quad names Index originComparison toleranceMigration levelAtomic vector