给标准Java库的Math类的方法穿了件外衣

/**
 *
 */
@Typed
package org.lucifer.util

import static java.lang.Math.*
/**
 * @author Lucifer
 *
 */
final class MathExt {

	private MathExt() {
	}

	static double cot(double a) {
		return cos(a) / sin(a)
	}

	static double sec(double a) {
		return 1 / cos(a)
	}

	static double csc(double a) {
		return 1 / sin(a)
	}

	static double arcsin(double a) {
		return asin(a)
	}

	static double arccos(double a) {
		return acos(a)
	}

	static double arctan(double a) {
		return atan(a)
	}

	static double arccot(double a) {
		return arctan(1 / a)
	}

	static double arcsec(double a) {
		return arccos(1 / a)
	}

	static double arccsc(double a) {
		return arcsin(1 / a)
	}

	/**
	 * 正矢函数
	 * @param a
	 * @return
	 */
	static double versin(double a) {
		return 1 - cos(a)
	}

	/**
	 * 正矢函数
	 * @param a
	 * @return
	 */
	static double vercosin(double a) {
		return 1 + cos(a)
	}

	/**
	 * 余矢函数
	 * @param a
	 * @return
	 */
	static double coversin(double a) {
		return 1 - sin(a)
	}

	/**
	 * 余矢函数
	 * @param a
	 * @return
	 */
	static double covercosin(double a) {
		return 1 + sin(a)
	}

	/**
	 * 半正矢函数
	 * @param a
	 * @return
	 */
	static double haversin(double a) {
		return (1 - cos(a)) / 2
	}

	/**
	 * 半正矢函数
	 * @param a
	 * @return
	 */
	static double havercosin(double a) {
		return (1 + cos(a)) / 2
	}

	/**
	 * 半余矢函数
	 * @param a
	 * @return
	 */
	static double hacoversin(double a) {
		return (1 - sin(a)) / 2
	}

	/**
	 * 半余矢函数
	 * @param a
	 * @return
	 */
	static double hacovercosin(double a) {
		return (1 + sin(a)) / 2
	}

	/**
	 * 外正割函数
	 * @param a
	 * @return
	 */
	static double exsec(double a) {
		return sec(a) - 1
	}

	/**
	 * 外余割函数
	 * @param a
	 * @return
	 */
	static double excsc(double a) {
		return csc(a) - 1
	}

	static double log2(double a) {
		return logN(2, a)
	}

	/**
	 * bNum为底zNum的对数。
	 * @param bNum 底数。
	 * @param zNum 真数。
	 * @return 对数值。
	 */
	static double logN(double bNum, double zNum) {
		return log(zNum) / log(bNum)
	}

	/**
	 * 对num进行四舍五入操作。
	 * @param num 要进行舍入操作的数。
	 * @param bit 要保留小数的精确位数。
	 * @return 舍入后的结果。
	 */
	static double round(double num, int bit) {
		def tmp = pow(10, bit)
		return round(num * tmp) / tmp
	}

	static double max(double[] args) {
		return args.toList().max()
	}

	static int max(int[] args) {
		return args.toList().max()
	}

	static double min(double[] args) {
		return args.toList().min()
	}

	static int min(int[] args) {
		return args.toList().min()
	}
}

编程技巧