Java Double Number From toDoubles(byte[] value, int offset, int num)

Here you can find the source of toDoubles(byte[] value, int offset, int num)

Description

to Doubles

License

Apache License

Declaration

public static double[] toDoubles(byte[] value, int offset, int num) 

Method Source Code

//package com.java2s;
/**/*ww w  .j  a v  a 2s.c  o m*/
 * 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.
 */

public class Main {
    public static double[] toDoubles(byte[] value, int offset, int num) {
        double[] values = new double[num];
        int idx = 0;
        for (int i = offset; i < offset + (num * 8); i += 8) {
            values[idx++] = getDouble(value, i);
        }
        return values;
    }

    public static double[] toDoubles(byte[] value, int offset) {
        int length = getInt(value, offset);
        return toDoubles(value, offset + 4, length);
    }

    public static double getDouble(final byte[] b, final int offset) {
        return Double.longBitsToDouble(getLong(b, offset));
    }

    public static int getInt(final byte[] b, final int offset) {
        return (b[offset + 0] & 0xFF) << 24 | (b[offset + 1] & 0xFF) << 16 | (b[offset + 2] & 0xFF) << 8
                | (b[offset + 3] & 0xFF) << 0;
    }

    public static long getLong(final byte[] b, final int offset) {
        return (b[offset + 0] & 0xFFL) << 56 | (b[offset + 1] & 0xFFL) << 48 | (b[offset + 2] & 0xFFL) << 40
                | (b[offset + 3] & 0xFFL) << 32 | (b[offset + 4] & 0xFFL) << 24 | (b[offset + 5] & 0xFFL) << 16
                | (b[offset + 6] & 0xFFL) << 8 | (b[offset + 7] & 0xFFL) << 0;
    }
}

Related

  1. toDoublePow2(long m, int n)
  2. toDoublePrecision(long fixedPrecisionOrdinate)
  3. toDoublePrimitiveArray(final Double[] wrappedArray)
  4. toDoubleQuotes(String str)
  5. toDoubles(byte[] bytes)
  6. toDoubles(Double[] values)
  7. toDoubles(int[][] intPts)
  8. toDoubles(Object[] extraArgs)
  9. toDoubleScore(Float score)