Java - StrictStrictMath Class



Introduction

The Java StrictStrictMath class contains methods for performing basic numeric operations such as the elementary exponential, logarithm, square root, and trigonometric functions.

Class Declaration

Following is the declaration for java.lang.StrictStrictMath class −

public final class StrictStrictMath
   extends Object

Field

Following are the fields for java.lang.StrictStrictMath class −

  • static double E − This is the double value that is closer than any other to e, the base of the natural logarithms.

  • static double PI − This is the double value that is closer than any other to pi, the ratio of the circumference of a circle to its diameter.

Class methods

Sr.No.Method & Description
1static double abs(double a)

This method returns the absolute value of a double value.

2static float abs(float a)

This method returns the absolute value of a float value.

3static int abs(int a)

This method returns the absolute value of an int value.

4static long abs(long a)

This method returns the absolute value of a long value.

5static double acos(double a)

This method returns the arc cosine of a value; the returned angle is in the range 0.0 through pi.

6static double asin(double a)

This method returns the arc sine of a value; the returned angle is in the range -pi/2 through pi/2.

7static double atan(double a)

This method returns the arc tangent of a value; the returned angle is in the range -pi/2 through pi/2.

8static double atan2(double y, double x)

This method returns the angle theta from the conversion of rectangular coordinates (x, y) to polar coordinates (r, theta).

9static double cbrt(double a)

This method returns the cube root of a double value.

10static double ceil(double a)

This method returns the smallest (closest to negative infinity) double value that is greater than or equal to the argument and is equal to a mathematical integer.

11static double copySign(double magnitude, double sign)

This method returns the first floating-point argument with the sign of the second floating-point argument.

12static float copySign(float magnitude, float sign)

This method returns the first floating-point argument with the sign of the second floating-point argument.

13static double cos(double a)

This method returns the trigonometric cosine of an angle.

14static double cosh(double x)

This method returns the hyperbolic cosine of a double value.

15static double exp(double a)

This method returns Euler's number e raised to the power of a double value.

16static double expm1(double x)

This method returns ex -1.

17static double floor(double a)

This method returns the largest (closest to positive infinity) double value that is less than or equal to the argument and is equal to a mathematical integer.

18static int getExponent(double d)

This method returns the unbiased exponent used in the representation of a double.

19static int getExponent(float f)

This method returns the unbiased exponent used in the representation of a float.

20static double hypot(double x, double y)

This method returns sqrt(x2 +y2) without intermediate overflow or underflow.

21static double IEEEremainder(double f1, double f2)

This method computes the remainder operation on two arguments as prescribed by the IEEE 754 standard.

22static double log(double a)

This method returns the natural logarithm (base e) of a double value.

23static double log10(double a)

This method returns the base 10 logarithm of a double value.

24static double log1p(double x)

This method returns the natural logarithm of the sum of the argument and 1.

25static double max(double a, double b)

This method returns the greater of two double values.

26static float max(float a, float b)

This method returns the greater of two float values.

27static int max(int a, int b)

This method returns the greater of two int values.

28static long max(long a, long b)

This method returns the greater of two long values.

29static double min(double a, double b)

This method returns the smaller of two double values.

30static float min(float a, float b)

This method returns the smaller of two float values.

31static int min(int a, int b)

This method returns the smaller of two int values.

32static long min(long a, long b)

This method returns the smaller of two long values.

33static double nextAfter(double start, double direction)

This method returns the floating-point number adjacent to the first argument in the direction of the second argument.

34static float nextAfter(float start, double direction)

This method returns the floating-point number adjacent to the first argument in the direction of the second argument.

35static double nextUp(double d)

This method returns the floating-point value adjacent to d in the direction of positive infinity.

36static float nextUp(float f)

This method returns the floating-point value adjacent to f in the direction of positive infinity.

37static double pow(double a, double b)

This method returns the value of the first argument raised to the power of the second argument.

38static double random()

This method returns a double value with a positive sign, greater than or equal to 0.0 and less than 1.0.

39static double rint(double a)

This method returns the double value that is closest in value to the argument and is equal to a mathematical integer.

40static long round(double a)

This method returns the closest long to the argument.

41static int round(float a)

This method returns the closest int to the argument.

42static double scalb(double d, int scaleFactor)

This method returns d × 2scaleFactor rounded as if performed by a single correctly rounded floating-point multiply to a member of the double value set.

43static float scalb(float f, int scaleFactor)

This method return f × 2scaleFactor rounded as if performed by a single correctly rounded floating-point multiply to a member of the float value set.

44static double signum(double d)

This method returns the signum function of the argument; zero if the argument is zero, 1.0 if the argument is greater than zero, -1.0 if the argument is less than zero.

45static float signum(float f)

This method returns the signum function of the argument; zero if the argument is zero, 1.0f if the argument is greater than zero, -1.0f if the argument is less than zero.

46static double sin(double a)

This method returns the hyperbolic sine of a double value.

47static double sinh(double x)

This method Returns the hyperbolic sine of a double value.

48static double sqrt(double a)

This method returns the correctly rounded positive square root of a double value.

49static double tan(double a)

This method returns the trigonometric tangent of an angle.r

50static double tanh(double x)

This method returns the hyperbolic tangent of a double value.

51static double toDegrees(double angrad)

This method converts an angle measured in radians to an approximately equivalent angle measured in degrees.

52static double toRadians(double angdeg)

This method converts an angle measured in degrees to an approximately equivalent angle measured in radians.

53static double ulp(double d)

This method returns the size of an ulp of the argument.

54static double ulp(float f)

This method returns the size of an ulp of the argument.

Methods inherited

This class inherits methods from the following classes −

  • java.lang.Object

Example

The following example shows the usage of some important methods provided by StrictStrictMath class.

package com.tutorialspoint;

public class StrictStrictMathDemo {

   public static void main(String[] args) {

      // get two double numbers
      double x = 60984.1;
      double y = -497.99;

      // get the natural logarithm for x
      System.out.println("StrictStrictMath.log(" + x + ")=" + StrictStrictMath.log(x));

      // get the natural logarithm for y
      System.out.println("StrictStrictMath.log(" + y + ")=" + StrictStrictMath.log(y));

      // get the max value
      System.out.println("StrictStrictMath.max(" + x + ", y" + ")=" + StrictStrictMath.max(x,y));

      // get the min value
      System.out.println("StrictStrictMath.min(" + x + ", y" + ")=" + StrictStrictMath.min(x,y));

   }
}	

Output

Let us compile and run the above program, this will produce the following result −

StrictStrictMath.log(60984.1)=11.018368453441132
StrictStrictMath.log(-497.99)=NaN
StrictStrictMath.max(60984.1, y)=60984.1
StrictStrictMath.min(60984.1, y)=-497.99