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

com.bulletphysics.linearmath.MiscUtil Maven / Gradle / Ivy

/*
 * Java port of Bullet (c) 2008 Martin Dvorak 
 *
 * Bullet Continuous Collision Detection and Physics Library
 * Copyright (c) 2003-2008 Erwin Coumans  http://www.bulletphysics.com/
 *
 * This software is provided 'as-is', without any express or implied warranty.
 * In no event will the authors be held liable for any damages arising from
 * the use of this software.
 * 
 * Permission is granted to anyone to use this software for any purpose, 
 * including commercial applications, and to alter it and redistribute it
 * freely, subject to the following restrictions:
 * 
 * 1. The origin of this software must not be misrepresented; you must not
 *    claim that you wrote the original software. If you use this software
 *    in a product, an acknowledgment in the product documentation would be
 *    appreciated but is not required.
 * 2. Altered source versions must be plainly marked as such, and must not be
 *    misrepresented as being the original software.
 * 3. This notice may not be removed or altered from any source distribution.
 */

package com.bulletphysics.linearmath;

import java.util.Comparator;
import com.bulletphysics.util.FloatArrayList;
import com.bulletphysics.util.IntArrayList;
import com.bulletphysics.util.ObjectArrayList;

/**
 * Miscellaneous utility functions.
 * 
 * @author jezek2
 */
public class MiscUtil {

	public static int getListCapacityForHash(ObjectArrayList list) {
		return getListCapacityForHash(list.size());
	}
	
	public static int getListCapacityForHash(int size) {
		int n = 2;
		while (n < size) {
			n <<= 1;
		}
		return n;
	}

	/**
	 * Ensures valid index in provided list by filling list with provided values
	 * until the index is valid.
	 */
	public static  void ensureIndex(ObjectArrayList list, int index, T value) {
		while (list.size() <= index) {
			list.add(value);
		}
	}
	
	/**
	 * Resizes list to exact size, filling with given value when expanding.
	 */
	public static void resize(IntArrayList list, int size, int value) {
		while (list.size() < size) {
			list.add(value);
		}
		
		while (list.size() > size) {
			list.remove(list.size() - 1);
		}
	}
	
	/**
	 * Resizes list to exact size, filling with given value when expanding.
	 */
	public static void resize(FloatArrayList list, int size, float value) {
		while (list.size() < size) {
			list.add(value);
		}
		
		while (list.size() > size) {
			list.remove(list.size() - 1);
		}
	}
	
	/**
	 * Resizes list to exact size, filling with new instances of given class type
	 * when expanding.
	 */
	public static  void resize(ObjectArrayList list, int size, Class valueCls) {
		try {
			while (list.size() < size) {
				list.add(valueCls != null? valueCls.newInstance() : null);
			}

			while (list.size() > size) {
				list.removeQuick(list.size() - 1);
			}
		}
		catch (IllegalAccessException e) {
			throw new IllegalStateException(e);
		}
		catch (InstantiationException e) {
			throw new IllegalStateException(e);
		}
	}
	
	/**
	 * Searches object in array.
	 * 
	 * @return first index of match, or -1 when not found
	 */
	public static  int indexOf(T[] array, T obj) {
		for (int i=0; i void downHeap(ObjectArrayList pArr, int k, int n, Comparator comparator) {
		/*  PRE: a[k+1..N] is a heap */
		/* POST:  a[k..N]  is a heap */

		T temp = pArr.getQuick(k - 1);
		/* k has child(s) */
		while (k <= n / 2) {
			int child = 2 * k;

			if ((child < n) && comparator.compare(pArr.getQuick(child - 1), pArr.getQuick(child)) < 0) {
				child++;
			}
			/* pick larger child */
			if (comparator.compare(temp, pArr.getQuick(child - 1)) < 0) {
				/* move child up */
				pArr.setQuick(k - 1, pArr.getQuick(child - 1));
				k = child;
			}
			else {
				break;
			}
		}
		pArr.setQuick(k - 1, temp);
	}

	/**
	 * Sorts list using heap sort.

* * Implementation from: http://www.csse.monash.edu.au/~lloyd/tildeAlgDS/Sort/Heap/ */ public static void heapSort(ObjectArrayList list, Comparator comparator) { /* sort a[0..N-1], N.B. 0 to N-1 */ int k; int n = list.size(); for (k = n / 2; k > 0; k--) { downHeap(list, k, n, comparator); } /* a[1..N] is now a heap */ while (n >= 1) { swap(list, 0, n - 1); /* largest of a[0..n-1] */ n = n - 1; /* restore a[1..i-1] heap */ downHeap(list, 1, n, comparator); } } private static void swap(ObjectArrayList list, int index0, int index1) { T temp = list.getQuick(index0); list.setQuick(index0, list.getQuick(index1)); list.setQuick(index1, temp); } /** * Sorts list using quick sort.

*/ public static void quickSort(ObjectArrayList list, Comparator comparator) { // don't sort 0 or 1 elements if (list.size() > 1) { quickSortInternal(list, comparator, 0, list.size() - 1); } } private static void quickSortInternal(ObjectArrayList list, Comparator comparator, int lo, int hi) { // lo is the lower index, hi is the upper index // of the region of array a that is to be sorted int i = lo, j = hi; T x = list.getQuick((lo + hi) / 2); // partition do { while (comparator.compare(list.getQuick(i), x) < 0) i++; while (comparator.compare(x, list.getQuick(j)) < 0) j--; if (i <= j) { swap(list, i, j); i++; j--; } } while (i <= j); // recursion if (lo < j) { quickSortInternal(list, comparator, lo, j); } if (i < hi) { quickSortInternal(list, comparator, i, hi); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy