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

test.it.unimi.dsi.fastutil.objects.ObjectBigArraysTest Maven / Gradle / Ivy

The newest version!
package it.unimi.dsi.fastutil.objects;

import static org.junit.Assert.*;
import static it.unimi.dsi.fastutil.objects.ObjectBigArrays.set;
import static it.unimi.dsi.fastutil.objects.ObjectBigArrays.get;

import java.util.Arrays;

import org.junit.Test;

public class ObjectBigArraysTest {

	@SuppressWarnings({ "unchecked", "boxing" })
	@Test
	public void testQuickSort() {
		Integer[] s = new Integer[] { 2, 1, 5, 2, 1, 0, 9, 1, 4, 2, 4, 6, 8, 9, 10, 12, 1, 7 };

		Arrays.sort( s );
		Integer[][] sorted = ObjectBigArrays.wrap( s.clone() );

		Integer[][] a = ObjectBigArrays.wrap( s.clone()  );

		ObjectBigArrays.quickSort( a );
		assertArrayEquals( sorted, a );

		ObjectBigArrays.quickSort( a );
		assertArrayEquals( sorted, a );
		
		a = ObjectBigArrays.wrap( s.clone()  );
		
		ObjectBigArrays.quickSort( a, ObjectComparators.NATURAL_COMPARATOR );
		assertArrayEquals( sorted, a );

		ObjectBigArrays.quickSort( a, ObjectComparators.NATURAL_COMPARATOR );
		assertArrayEquals( sorted, a );
		
	}

	@SuppressWarnings("boxing")
	private void testCopy( int n ) {
		Object[][] a = ObjectBigArrays.newBigArray( n );
		for ( int i = 0; i < n; i++ ) set( a, i, i );
		ObjectBigArrays.copy( a, 0, a, 1, n - 2 );
		assertEquals( 0, a[ 0 ][ 0 ] );
		for ( int i = 0; i < n - 2; i++ ) assertEquals( i,  get( a, i + 1 ) );
		for ( int i = 0; i < n; i++ ) set( a, i, i );
		ObjectBigArrays.copy( a, 1, a, 0, n - 1 );
		for ( int i = 0; i < n - 1; i++ ) assertEquals( i + 1, get( a, i ) );
		for ( int i = 0; i < n; i++ ) set( a, i, i );
		Integer[] b = new Integer[ n ];
		for ( int i = 0; i < n; i++ ) b[ i ] = i;
		assertArrayEquals( a, ObjectBigArrays.wrap( b ) );
	}
	
	@Test
	public void testCopy10() {
		testCopy( 10 );
	}

	@Test
	public void testCopy1000() {
		testCopy( 1000 );
	}

	@Test
	public void testCopy1000000() {
		testCopy( 1000000 );
	}

	@SuppressWarnings({ "boxing", "unchecked" })
	@Test
	public void testBinarySearch() {
		Integer[] a = new Integer[] { 25, 32, 1, 3, 2, 0, 40, 7, 13, 12, 11, 10, -1, -6, -18, 2000 };
		
		Arrays.sort( a );
		Integer[][] b = ObjectBigArrays.wrap( a.clone() );

		for( int i = -1; i < 20; i++ ) { 
			assertEquals( "" + i, Arrays.binarySearch( a, i ), ObjectBigArrays.binarySearch( b, i ) );
			assertEquals( "" + i, Arrays.binarySearch( a, i ), ObjectBigArrays.binarySearch( b, i, ObjectComparators.NATURAL_COMPARATOR ) );
		}
	
		for( int i = -1; i < 20; i++ ) {
			assertEquals( Arrays.binarySearch( a, 5, 13, i ), ObjectBigArrays.binarySearch( b, 5, 13, i ) );
			assertEquals( Arrays.binarySearch( a, 5, 13, i ), ObjectBigArrays.binarySearch( b, 5, 13, i, ObjectComparators.NATURAL_COMPARATOR ) );
		}
	}

	@SuppressWarnings("boxing")
	@Test
	public void testTrim() {
		Integer[] a = new Integer[] { 2, 1, 5, 2, 1, 0, 9, 1, 4, 2, 4, 6, 8, 9, 10, 12, 1, 7 };
		Integer[][] b = ObjectBigArrays.wrap( a.clone() );

		for( int i = a.length; i-- != 0; ) {
			Integer[][] t = ObjectBigArrays.trim( b, i );
			final long l = ObjectBigArrays.length( t );
			assertEquals( i, l );
			for( int p = 0; p < l; p++ ) assertEquals( a[ p ], ObjectBigArrays.get( t, p ) );
			
		}
	}

	@SuppressWarnings("boxing")
	@Test
	public void testEquals() {
		Integer[] a = new Integer[] { 2, 1, 5, 2, 1, 0, 9, 1, 4, 2, 4, 6, 8, 9, 10, 12, 1, 7 };
		Integer[][] b = ObjectBigArrays.wrap( a.clone() );
		Integer[][] c = ObjectBigArrays.wrap( a.clone() );

		assertTrue( ObjectBigArrays.equals( b, c ) );
		b[ 0 ][ 0 ] = 0;
		assertFalse( ObjectBigArrays.equals( b, c ) );
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy