當前位置: 首頁>>代碼示例>>Java>>正文


Java MDShortArray類代碼示例

本文整理匯總了Java中ch.systemsx.cisd.base.mdarray.MDShortArray的典型用法代碼示例。如果您正苦於以下問題:Java MDShortArray類的具體用法?Java MDShortArray怎麽用?Java MDShortArray使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MDShortArray類屬於ch.systemsx.cisd.base.mdarray包,在下文中一共展示了MDShortArray類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: loadArray

import ch.systemsx.cisd.base.mdarray.MDShortArray; //導入依賴的package包/類
@Override
public VolatileShortArray loadArray(
		final int timepoint,
		final int setup,
		final int level,
		final int[] dimensions,
		final long[] min ) throws InterruptedException
{
	short[] data = null;
	final MDShortArray slice = reader.readMDArrayBlockWithOffset(
			dataset,
			new int[]{ dimensions[ 2 ], dimensions[ 1 ], dimensions[ 0 ] },
			new long[]{ min[ 2 ], min[ 1 ], min[ 0 ] } );

	data = slice.getAsFlatArray();

	if ( data == null )
	{
		System.out.println(
				"H5 short array loader failed loading min = " +
				Arrays.toString( min ) +
				", dimensions = " +
				Arrays.toString( dimensions ) );

		data = new short[ dimensions[ 0 ] * dimensions[ 1 ] * dimensions[ 2 ] ];
	}

	return new VolatileShortArray( data, true );
}
 
開發者ID:saalfeldlab,項目名稱:bigcat,代碼行數:30,代碼來源:H5ShortArrayLoader.java

示例2: loadUnsignedShort

import ch.systemsx.cisd.base.mdarray.MDShortArray; //導入依賴的package包/類
/**
 * Load an HDF5 uint16 dataset into a {@link CellImg} of {@link UnsignedShortType}.
 *
 * @param reader
 * @param dataset
 * @param cellDimensions
 */
static public CellImg< UnsignedShortType, ? > loadUnsignedShort(
		final IHDF5Reader reader,
		final String dataset,
		final int[] cellDimensions )
{
	final IHDF5ShortReader uint16Reader = reader.uint16();

	final long[] dimensions = reorder( reader.object().getDimensions( dataset ) );
	final int n = dimensions.length;

	final CellImg< UnsignedShortType, ? > target = new CellImgFactory< UnsignedShortType >( cellDimensions ).create( dimensions, new UnsignedShortType() );

	final long[] offset = new long[ n ];
	final long[] targetCellDimensions = new long[ n ];
	for ( int d = 0; d < n; )
	{
		cropCellDimensions( target, offset, cellDimensions, targetCellDimensions );
		final RandomAccessibleInterval< UnsignedShortType > targetBlock = Views.offsetInterval( target, offset, targetCellDimensions );
		final MDShortArray targetCell = uint16Reader.readMDArrayBlockWithOffset(
				dataset,
				Util.long2int( reorder( targetCellDimensions ) ),
				reorder( offset ) );

		int i = 0;
		for ( final UnsignedShortType t : Views.flatIterable( targetBlock ) )
			t.set( targetCell.get( i++ ) );

		for ( d = 0; d < n; ++d )
		{
			offset[ d ] += cellDimensions[ d ];
			if ( offset[ d ] < dimensions[ d ] )
				break;
			else
				offset[ d ] = 0;
		}
	}

	return target;
}
 
開發者ID:saalfeldlab,項目名稱:bigcat,代碼行數:47,代碼來源:H5Utils.java

示例3: saveUnsignedShort

import ch.systemsx.cisd.base.mdarray.MDShortArray; //導入依賴的package包/類
/**
 * Save a {@link RandomAccessibleInterval} of {@link ShortType} into an HDF5
 * uint16 dataset.
 *
 * @param source
 * @param writer
 * @param dataset
 * @param cellDimensions
 */
static public void saveUnsignedShort(
		final RandomAccessibleInterval< ShortType > source,
		final IHDF5Writer writer,
		final String dataset,
		final int[] cellDimensions )
{
	final int n = source.numDimensions();
	final long[] dimensions = Intervals.dimensionsAsLongArray( source );
	final IHDF5ShortWriter uint16Writer = writer.uint16();
	if ( !writer.exists( dataset ) )
		uint16Writer.createMDArray(
				dataset,
				reorder( dimensions ),
				reorder( cellDimensions ),
				HDF5IntStorageFeatures.INT_AUTO_SCALING_DEFLATE );

	final long[] offset = new long[ n ];
	final long[] sourceCellDimensions = new long[ n ];
	for ( int d = 0; d < n; )
	{
		cropCellDimensions( source, offset, cellDimensions, sourceCellDimensions );
		final RandomAccessibleInterval< ShortType > sourceBlock = Views.offsetInterval( source, offset, sourceCellDimensions );
		final MDShortArray targetCell = new MDShortArray( reorder( sourceCellDimensions ) );
		int i = 0;
		for ( final ShortType t : Views.flatIterable( sourceBlock ) )
			targetCell.set( t.get(), i++ );

		uint16Writer.writeMDArrayBlockWithOffset( dataset, targetCell, reorder( offset ) );

		for ( d = 0; d < n; ++d )
		{
			offset[ d ] += cellDimensions[ d ];
			if ( offset[ d ] < source.dimension( d ) )
				break;
			else
				offset[ d ] = 0;
		}
	}
}
 
開發者ID:saalfeldlab,項目名稱:bigcat,代碼行數:49,代碼來源:H5Utils.java

示例4: loadArrayLevel0

import ch.systemsx.cisd.base.mdarray.MDShortArray; //導入依賴的package包/類
@Override
	public VolatileLabelMultisetArray loadArrayLevel0(
			final int[] dimensions,
			final long[] min ) throws InterruptedException
	{
		short[] data = null;

		final MDShortArray block = reader.readMDArrayBlockWithOffset(
				dataset,
				new int[]{ dimensions[ 2 ], dimensions[ 1 ], dimensions[ 0 ] },
				new long[]{ min[ 2 ], min[ 1 ], min[ 0 ] } );

		data = block.getAsFlatArray();

		if ( data == null )
		{
			System.out.println(
					"H5 short label multiset array loader failed loading min = " +
					Arrays.toString( min ) +
					", dimensions = " +
					Arrays.toString( dimensions ) );

			data = new short[ dimensions[ 0 ] * dimensions[ 1 ] * dimensions[ 2 ] ];
		}

		final int[] offsets = new int[ dimensions[ 2 ] * dimensions[ 1 ] * dimensions[ 0 ] ];
		final LongMappedAccessData listData = LongMappedAccessData.factory.createStorage( 32 );
		final LabelMultisetEntryList list = new LabelMultisetEntryList( listData, 0 );
		final LabelMultisetEntry entry = new LabelMultisetEntry( 0, 1 );
		int nextListOffset = 0;
		final TLongIntHashMap idOffsetHash = new TLongIntHashMap(
				Constants.DEFAULT_CAPACITY,
				Constants.DEFAULT_LOAD_FACTOR,
				-1,
				-1);
A:		for ( int i = 0; i < data.length; ++i )
		{
			final long id = data[ i ] & 0xffffL;

//			does the list [id x 1] already exist?
			final int offset = idOffsetHash.get( id );
			if ( offset == idOffsetHash.getNoEntryValue() )
			{
				list.createListAt( listData, nextListOffset );
				entry.setId( id );
				list.add( entry );
				offsets[ i ] = nextListOffset;
				idOffsetHash.put( id, nextListOffset );
				nextListOffset += list.getSizeInBytes();
			}
			else
			{
				offsets[ i ] = offset;
				continue A;
			}
		}
//		System.out.println( listData.size() );

		return new VolatileLabelMultisetArray( offsets, listData, true );
	}
 
開發者ID:saalfeldlab,項目名稱:bigcat,代碼行數:61,代碼來源:H5ShortLabelMultisetArrayLoader.java


注:本文中的ch.systemsx.cisd.base.mdarray.MDShortArray類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。