- /**
- *
- */
- @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()
- }
- }
来源: http://www.phpxs.com/code/1005983/