2004-04-26 16:06:51 -04:00
|
|
|
<?xml version="1.0"?>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
Copyright 2003-2004 The Apache Software Foundation
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
-->
|
|
|
|
|
|
|
|
<?xml-stylesheet type="text/xsl" href="./xdoc.xsl"?>
|
2005-02-26 08:11:52 -05:00
|
|
|
<!-- $Revision$ $Date$ -->
|
2004-04-26 16:06:51 -04:00
|
|
|
<document url="stat.html">
|
|
|
|
<properties>
|
|
|
|
<title>The Commons Math User Guide - Statistics</title>
|
|
|
|
</properties>
|
|
|
|
<body>
|
|
|
|
<section name="7 Complex Numbers">
|
|
|
|
<subsection name="7.1 Overview" href="overview">
|
|
|
|
<p>
|
|
|
|
The complex packages provides a complex number type as well as complex
|
|
|
|
versions of common transcendental functions and complex number
|
|
|
|
formatting.
|
|
|
|
</p>
|
|
|
|
</subsection>
|
|
|
|
<subsection name="7.2 Complex Numbers" href="complex">
|
|
|
|
<p>
|
|
|
|
<a href="../apidocs/org/apache/commons/math/complex/Complex.html">
|
|
|
|
org.apache.commons.math.complex.Complex</a> provides a complex number
|
|
|
|
type that forms the basis for the complex functionality found in
|
|
|
|
commons-math.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
To create a complex number, simply call the constructor passing in two
|
|
|
|
floating-point arguments, the first being the real part of the
|
|
|
|
complex number and the second being the imaginary part:
|
|
|
|
<source>Complex c = new Complex(1.0, 3.0); // 1 + 3i</source>
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
The <code>Complex</code> class provides many unary and binary
|
|
|
|
complex number operations. These operations provide the means to add,
|
|
|
|
subtract, multiple and, divide complex numbers along with other
|
|
|
|
complex number functions similar to the real number functions found in
|
|
|
|
<code>java.math.BigDecimal</code>:
|
|
|
|
<source>Complex lhs = new Complex(1.0, 3.0);
|
|
|
|
Complex rhs = new Complex(2.0, 5.0);
|
|
|
|
|
|
|
|
Complex answer = lhs.add(rhs); // add two complex numbers
|
|
|
|
answer = lhs.subtract(rhs); // subtract two complex numbers
|
|
|
|
answer = lhs.abs(); // absolute value
|
|
|
|
answer = lhs.conjugate(rhs); // complex conjugate</source>
|
|
|
|
</p>
|
|
|
|
</subsection>
|
|
|
|
<subsection name="7.3 Complex Transcendental Functions" href="function">
|
|
|
|
<p>
|
2004-11-07 20:03:43 -05:00
|
|
|
<a href="../apidocs/org/apache/commons/math/complex/ComplexUtils.html">
|
2004-04-26 16:06:51 -04:00
|
|
|
org.apache.commons.math.complex.ComplexMath</a> provides
|
|
|
|
implementations of serveral transcendental functions involving complex
|
|
|
|
number arguments. These operations provide the means to compute the
|
|
|
|
log, sine, tangent and, other complex values similar to the real
|
|
|
|
number functions found in <code>java.lang.Math</code>:
|
|
|
|
<source>Complex first = new Complex(1.0, 3.0);
|
|
|
|
Complex second = new Complex(2.0, 5.0);
|
|
|
|
|
|
|
|
Complex answer = ComplexMath.log(first); // natural logarithm.
|
|
|
|
answer = ComplexMath.cos(first); // cosine
|
|
|
|
answer = ComplexMath.pow(first, second); // first raised to the power of second</source>
|
|
|
|
</p>
|
|
|
|
</subsection>
|
2004-06-01 09:47:17 -04:00
|
|
|
<subsection name="7.4 Complex Formatting and Parsing" href="formatting">
|
|
|
|
<p>
|
|
|
|
<code>Complex</code> instances can be converted to and from strings
|
|
|
|
using the<a href="../apidocs/org/apache/commons/math/complex/ComplexFormat.html">
|
|
|
|
org.apache.commons.math.complex.ComplexFormat</a> class.
|
|
|
|
<code>ComplexFormat</code> is a <code>java.text.Format</code>
|
|
|
|
extension and, as such, is used like other formatting objects (e.g.
|
2004-06-23 12:26:18 -04:00
|
|
|
<code>java.text.SimpleDateFormat</code>):
|
2004-06-01 09:47:17 -04:00
|
|
|
<source>ComplexFormat format = new ComplexFormat(); // default format
|
|
|
|
Complex c = new Complex(1.1111, 2.2222);
|
|
|
|
String s = format.format(c); // s contains "1.11 + 2.22i"</source>
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
To customize the formatting output, one or two
|
|
|
|
<code>java.text.NumberFormat</code> instances can be used to construct
|
|
|
|
a <code>ComplexFormat</code>. These number formats control the
|
|
|
|
formatting of the real and imaginary values of the complex number:
|
|
|
|
<source>NumberFormat nf = NumberFormat.getInstance();
|
|
|
|
nf.setMinimumFractionDigits(3);
|
|
|
|
nf.setMaximumFractionDigits(3);
|
|
|
|
|
|
|
|
// create complex format with custom number format
|
|
|
|
// when one number format is used, both real and
|
|
|
|
// imaginary parts are formatted the same
|
|
|
|
ComplexFormat cf = new ComplexFormat(nf);
|
|
|
|
Complex c = new Complex(1.11, 2.2222);
|
|
|
|
String s = format.format(c); // s contains "1.110 + 2.222i"
|
|
|
|
|
|
|
|
NumberFormat nf2 = NumberFormat.getInstance();
|
|
|
|
nf.setMinimumFractionDigits(1);
|
|
|
|
nf.setMaximumFractionDigits(1);
|
|
|
|
|
|
|
|
// create complex format with custom number formats
|
|
|
|
cf = new ComplexFormat(nf, nf2);
|
|
|
|
s = format.format(c); // s contains "1.110 + 2.2i"</source>
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Another formatting customization provided by
|
|
|
|
<code>ComplexFormat</code> is the text used for the imaginary
|
|
|
|
designation. By default, the imaginary notation is "i" but, it can be
|
|
|
|
manipulated using the <code>setImaginaryCharacter</code> method.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Formatting inverse operation, parsing, can also be performed by
|
|
|
|
<code>ComplexFormat</code>. Parse a complex number from a string,
|
|
|
|
simply call the <code>parse</code> method:
|
|
|
|
<source>ComplexFormat cf = new ComplexFormat();
|
|
|
|
Complex c = cf.parse("1.110 + 2.222i");</source>
|
|
|
|
</p>
|
2004-04-26 16:06:51 -04:00
|
|
|
</subsection>
|
|
|
|
</section>
|
|
|
|
</body>
|
|
|
|
</document>
|