1 USING: help.markup help.syntax math math.private math.functions
5 ARTICLE: "complex-numbers-zero" "Embedding of real numbers in complex numbers"
6 "Constructing a complex number with an imaginary component equal to an integer zero simply returns the real number corresponding to the real component:"
7 { $example "USING: math prettyprint ;" "C{ 1 2 } C{ 3 -2 } + ." "4" }
8 "Constructing a complex number with an imaginary component equal to floating point zero will still output a new complex number, however:"
9 { $example "USING: math prettyprint ;" "C{ 0.0 2.0 } C{ 0.0 1.0 } * ." "C{ -2.0 0.0 }" }
10 "Unlike math, where all real numbers are also complex numbers, Factor only considers a number to be a complex number if its imaginary part is non-zero. However, complex number operations are fully supported for real numbers; they are treated as having an imaginary part of zero." ;
12 ARTICLE: "complex-numbers" "Complex numbers"
13 { $subsection complex }
14 "Complex numbers arise as solutions to quadratic equations whose graph does not intersect the " { $emphasis "x" } " axis. Their literal syntax is covered in " { $link "syntax-complex-numbers" } "."
16 "Complex numbers can be taken apart:"
17 { $subsection real-part }
18 { $subsection imaginary-part }
20 "Complex numbers can be constructed from real numbers:"
22 { $subsection "complex-numbers-zero" }
23 { $see-also "syntax-complex-numbers" } ;
25 { $class-description "The class of complex numbers with non-zero imaginary part." } ;
27 ABOUT: "complex-numbers"
30 { $values { "x" "a complex number" } { "y" "a complex number" } { "xr" "real part of " { $snippet "x" } } { "xi" "imaginary part of " { $snippet "x" } } { "yr" "real part of " { $snippet "y" } } { "yi" "imaginary part of " { $snippet "y" } } }
31 { $description "Extracts real and imaginary components of two numbers at once." } ;
34 { $values { "x" "a complex number" } { "y" "a complex number" } { "r" "a real number" } { "i" "a real number" } { "m" "a real number" } }
36 "Complex division kernel. If we use the notation from " { $link 2>rect } ", this word computes:"
44 HELP: <complex> ( x y -- z )
45 { $values { "x" "a real number" } { "y" "a real number" } { "z" "a complex number" } }
46 { $description "Low-level complex number constructor. User code should call " { $link rect> } " instead." } ;