⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 angle.java

📁 JAVA 数学程序库 提供常规的数值计算程序包
💻 JAVA
字号:
package jmathlib.toolbox.general;

import jmathlib.core.tokens.*;
import jmathlib.core.tokens.numbertokens.*;
import jmathlib.core.functions.ExternalFunction;

public class angle extends ExternalFunction
{
	public OperandToken evaluate(Token[] operands)
	{

        if (getNArgIn(operands) != 1 )
			throwMathLibException("angle: number of arguments !=1");
        
        if (!(operands[0] instanceof DoubleNumberToken))
            throwMathLibException("angle: only works on numbers");

		// get data from arguments
        double[][] a_r     = ((DoubleNumberToken)operands[0]).getValuesRe();
		double[][] a_i     = ((DoubleNumberToken)operands[0]).getValuesIm();
		int        dy      = ((DoubleNumberToken)operands[0]).getSizeY();
        int        dx      = ((DoubleNumberToken)operands[0]).getSizeX();
        double[][] ret     = new double[dy][dx];

        for (int y=0; y<dy ; y++)
        {
            for (int x=0; x<dx ; x++)
            {
                if ((a_r[y][x]<0) && (a_i[y][x]>=0))
                {
                    ret[y][x] = Math.atan( a_i[y][x] / a_r[y][x]) + Math.PI;
                }
                else if ((a_r[y][x]<0) && (a_i[y][x]<0))
                {
                    ret[y][x] = Math.atan( a_i[y][x] / a_r[y][x]) - Math.PI;
                }
                else
                {
                    ret[y][x] = Math.atan( a_i[y][x] / a_r[y][x]);
                }
            }
        }   

        return new DoubleNumberToken(ret);
        
	} // end eval
}

/*
@GROUP
general
@SYNTAX
angle(complex)
@DOC
Returns the angle of a complex number
@EXAMPLES
<programlisting>
angle(2i) = pi/2
real(1 + i) = pi/4
</programlisting>
@SEE
real, conj, imag, abs
*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -