All Downloads are FREE. Search and download functionalities are using the official Maven repository.

android.hardware.camera2.utils.HashCodeHelpers Maven / Gradle / Ivy

Go to download

A library jar that provides APIs for Applications written for the Google Android Platform.

There is a newer version: 14-robolectric-10818077
Show newest version
/*
 * Copyright (C) 2014 The Android Open Source Project
 *
 * 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.
 */

package android.hardware.camera2.utils;

/**
 * Provide hashing functions using the Modified Bernstein hash
 */
public final class HashCodeHelpers {

    /**
     * Hash every element uniformly using the Modified Bernstein hash.
     *
     * 

Useful to implement a {@link Object#hashCode} for uniformly distributed data.

* * @param array a non-{@code null} array of integers * * @return the numeric hash code */ public static int hashCode(int[] array) { if (array == null) { return 0; } /* * Note that we use 31 here instead of 33 since it's preferred in Effective Java * and used elsewhere in the runtime (e.g. Arrays#hashCode) * * That being said 33 and 31 are nearly identical in terms of their usefulness * according to http://svn.apache.org/repos/asf/apr/apr/trunk/tables/apr_hash.c */ int h = 1; for (int x : array) { // Strength reduction; in case the compiler has illusions about divisions being faster h = ((h << 5) - h) ^ x; // (h * 31) XOR x } return h; } /** * Hash every element uniformly using the Modified Bernstein hash. * *

Useful to implement a {@link Object#hashCode} for uniformly distributed data.

* * @param array a non-{@code null} array of floats * * @return the numeric hash code */ public static int hashCode(float[] array) { if (array == null) { return 0; } int h = 1; for (float f : array) { int x = Float.floatToIntBits(f); h = ((h << 5) - h) ^ x; // (h * 31) XOR x } return h; } /** * Hash every element uniformly using the Modified Bernstein hash. * *

Useful to implement a {@link Object#hashCode} for uniformly distributed data.

* * @param array a non-{@code null} array of objects * * @return the numeric hash code */ public static int hashCode(T[] array) { if (array == null) { return 0; } int h = 1; for (T o : array) { int x = (o == null) ? 0 : o.hashCode(); h = ((h << 5) - h) ^ x; // (h * 31) XOR x } return h; } public static int hashCode(T a) { return (a == null) ? 0 : a.hashCode(); } public static int hashCode(T a, T b) { int h = hashCode(a); int x = (b == null) ? 0 : b.hashCode(); h = ((h << 5) - h) ^ x; // (h * 31) XOR x return h; } public static int hashCode(T a, T b, T c) { int h = hashCode(a, b); int x = (c == null) ? 0 : c.hashCode(); h = ((h << 5) - h) ^ x; // (h * 31) XOR x return h; } public static int hashCode(T a, T b, T c, T d) { int h = hashCode(a, b, c); int x = (d == null) ? 0 : d.hashCode(); h = ((h << 5) - h) ^ x; // (h * 31) XOR x return h; } public static int hashCode(int x) { return hashCode(new int[] { x } ); } public static int hashCode(int x, int y) { return hashCode(new int[] { x, y } ); } public static int hashCode(int x, int y, int z) { return hashCode(new int[] { x, y, z } ); } public static int hashCode(int x, int y, int z, int w) { return hashCode(new int[] { x, y, z, w } ); } public static int hashCode(int x, int y, int z, int w, int t) { return hashCode(new int[] { x, y, z, w, t } ); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy