You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
135 lines
3.9 KiB
135 lines
3.9 KiB
/*
|
|
* Copyright 2021 Google LLC
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
// This file is automatically generated. Do not modify it.
|
|
|
|
package com.google.ux.material.libmonet.utils;
|
|
|
|
/** Utility methods for mathematical operations. */
|
|
public class MathUtils {
|
|
private MathUtils() {}
|
|
|
|
/**
|
|
* The signum function.
|
|
*
|
|
* @return 1 if num > 0, -1 if num < 0, and 0 if num = 0
|
|
*/
|
|
public static int signum(double num) {
|
|
if (num < 0) {
|
|
return -1;
|
|
} else if (num == 0) {
|
|
return 0;
|
|
} else {
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* The linear interpolation function.
|
|
*
|
|
* @return start if amount = 0 and stop if amount = 1
|
|
*/
|
|
public static double lerp(double start, double stop, double amount) {
|
|
return (1.0 - amount) * start + amount * stop;
|
|
}
|
|
|
|
/**
|
|
* Clamps an integer between two integers.
|
|
*
|
|
* @return input when min <= input <= max, and either min or max otherwise.
|
|
*/
|
|
public static int clampInt(int min, int max, int input) {
|
|
if (input < min) {
|
|
return min;
|
|
} else if (input > max) {
|
|
return max;
|
|
}
|
|
|
|
return input;
|
|
}
|
|
|
|
/**
|
|
* Clamps an integer between two floating-point numbers.
|
|
*
|
|
* @return input when min <= input <= max, and either min or max otherwise.
|
|
*/
|
|
public static double clampDouble(double min, double max, double input) {
|
|
if (input < min) {
|
|
return min;
|
|
} else if (input > max) {
|
|
return max;
|
|
}
|
|
|
|
return input;
|
|
}
|
|
|
|
/**
|
|
* Sanitizes a degree measure as an integer.
|
|
*
|
|
* @return a degree measure between 0 (inclusive) and 360 (exclusive).
|
|
*/
|
|
public static int sanitizeDegreesInt(int degrees) {
|
|
degrees = degrees % 360;
|
|
if (degrees < 0) {
|
|
degrees = degrees + 360;
|
|
}
|
|
return degrees;
|
|
}
|
|
|
|
/**
|
|
* Sanitizes a degree measure as a floating-point number.
|
|
*
|
|
* @return a degree measure between 0.0 (inclusive) and 360.0 (exclusive).
|
|
*/
|
|
public static double sanitizeDegreesDouble(double degrees) {
|
|
degrees = degrees % 360.0;
|
|
if (degrees < 0) {
|
|
degrees = degrees + 360.0;
|
|
}
|
|
return degrees;
|
|
}
|
|
|
|
/**
|
|
* Sign of direction change needed to travel from one angle to another.
|
|
*
|
|
* <p>For angles that are 180 degrees apart from each other, both directions have the same travel
|
|
* distance, so either direction is shortest. The value 1.0 is returned in this case.
|
|
*
|
|
* @param from The angle travel starts from, in degrees.
|
|
* @param to The angle travel ends at, in degrees.
|
|
* @return -1 if decreasing from leads to the shortest travel distance, 1 if increasing from leads
|
|
* to the shortest travel distance.
|
|
*/
|
|
public static double rotationDirection(double from, double to) {
|
|
double increasingDifference = sanitizeDegreesDouble(to - from);
|
|
return increasingDifference <= 180.0 ? 1.0 : -1.0;
|
|
}
|
|
|
|
/** Distance of two points on a circle, represented using degrees. */
|
|
public static double differenceDegrees(double a, double b) {
|
|
return 180.0 - Math.abs(Math.abs(a - b) - 180.0);
|
|
}
|
|
|
|
/** Multiplies a 1x3 row vector with a 3x3 matrix. */
|
|
public static double[] matrixMultiply(double[] row, double[][] matrix) {
|
|
double a = row[0] * matrix[0][0] + row[1] * matrix[0][1] + row[2] * matrix[0][2];
|
|
double b = row[0] * matrix[1][0] + row[1] * matrix[1][1] + row[2] * matrix[1][2];
|
|
double c = row[0] * matrix[2][0] + row[1] * matrix[2][1] + row[2] * matrix[2][2];
|
|
return new double[] {a, b, c};
|
|
}
|
|
}
|
|
|