Java examples for java.lang:Math Calculation
Computes a fast approximation to Math.pow(a, b).
/*/* w w w .j av a 2 s . c om*/ * __ .__ .__ ._____. * _/ |_ _______ __|__| ____ | | |__\_ |__ ______ * \ __\/ _ \ \/ / |/ ___\| | | || __ \ / ___/ * | | ( <_> > <| \ \___| |_| || \_\ \\___ \ * |__| \____/__/\_ \__|\___ >____/__||___ /____ > * \/ \/ \/ \/ * * Copyright (c) 2006-2011 Karsten Schmidt * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * http://creativecommons.org/licenses/LGPL/2.1/ * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA */ //package com.java2s; public class Main { private static final float SHIFT23 = 1 << 23; private static final float INV_SHIFT23 = 1.0f / SHIFT23; /** * Computes a fast approximation to <code>Math.pow(a, b)</code>. Adapted * from http://www.dctsystems.co.uk/Software/power.html. * * @param a * a positive number * @param b * a number * @return a^b * */ public static final float fastPow(float a, float b) { float x = Float.floatToRawIntBits(a); x *= INV_SHIFT23; x -= 127; float y = x - (x >= 0 ? (int) x : (int) x - 1); b *= x + (y - y * y) * 0.346607f; y = b - (b >= 0 ? (int) b : (int) b - 1); y = (y - y * y) * 0.33971f; return Float.intBitsToFloat((int) ((b + 127 - y) * SHIFT23)); } }