当前位置: 首页>>代码示例>>Java>>正文


Java NumericType类代码示例

本文整理汇总了Java中net.imglib2.type.numeric.NumericType的典型用法代码示例。如果您正苦于以下问题:Java NumericType类的具体用法?Java NumericType怎么用?Java NumericType使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


NumericType类属于net.imglib2.type.numeric包,在下文中一共展示了NumericType类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: transferN

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
/** Copy img into iimg, offset by 1 in every dimension. */
static private final <R extends NumericType<R>, T extends NumericType<T>> void transferN(
		final Img<R> img,
		final Img<T> iimg,
		final Converter<R, T> converter)
{
	// Copy img to iimg, with an offset of 1 in every dimension
	final long[] min = new long[img.numDimensions()];
	final long[] max = new long[min.length];
	for (int i=0; i<min.length; ++i) {
		min[i] = 1;
		max[i] = img.dimension(i);
	}
	final Cursor<R> c1 = img.cursor();
	final RandomAccess<T> r = Views.zeroMin(Views.interval(iimg, min, max)).randomAccess();
	while (c1.hasNext()) {
		c1.fwd();
		r.setPosition(c1);
		converter.convert(c1.get(), r.get());
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:22,代码来源:FastIntegralImg.java

示例2: integrateN

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
/** In place; assumes iimg already contains the information of the image to integrate. */
static private final <T extends NumericType<T>> void integrateN(
		final Img<T> iimg,
		final T sum)
{
	final RandomAccess<T> r2 = iimg.randomAccess();
	final int numDimensions = iimg.numDimensions();
	// Integrate iimg by summing over all possible kinds of rows
	final int[] rowDims = new int[numDimensions -1];
	for (int rowDimension = 0; rowDimension < numDimensions; ++rowDimension) {
		// Reset position
		for (int i=0; i<numDimensions; ++i) {
			r2.setPosition(1L, i);
		}
		
		// Prepare the set of dimensions to iterate over
		for (int i=0, k=0; i<rowDims.length; ++i, ++k) {
			if (i == rowDimension) ++k;
			rowDims[i] = k;
		}

		// Iterate over all dimensions other than rowDimension
		integrateRows(rowDimension, iimg, r2, sum, rowDims);
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:26,代码来源:FastIntegralImg.java

示例3: process

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
@SuppressWarnings({ "unchecked", "rawtypes" })
static private final <N extends NumericType<N>>
					Img<N> process(final Img<N> img, final float[] matrix,
					final Mode mode, final OutOfBoundsFactory<N,Img<N>> oobf) throws Exception {
	if (matrix.length < 12) {
		throw new IllegalArgumentException("Affine transform in 2D requires a matrix array of 12 elements.");
	}
	final Type<?> type = img.firstElement().createVariable();
	if (ARGBType.class.isAssignableFrom(type.getClass())) { // type instanceof RGBALegacyType fails to compile
		return (Img)processRGBA((Img)img, matrix, mode, (OutOfBoundsFactory)oobf);
	} else if (type instanceof RealType<?>) {
		return processReal((Img)img, matrix, mode, (OutOfBoundsFactory)oobf);
	} else {
		throw new Exception("Affine transform: cannot handle type " + type.getClass());
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:17,代码来源:AbstractAffine3D.java

示例4: process

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
@SuppressWarnings({ "unchecked", "rawtypes" })
static private final <N extends NumericType<N>> Img<N> process(final Img<N> img, long[] dim, final Mode mode) throws Exception {
	// Pad dim array with missing dimensions
	if (dim.length != img.numDimensions()) {
		long[] d = new long[img.numDimensions()];
		int i = 0;
		for (; i<dim.length; i++) d[i] = dim[i];
		for (; i<img.numDimensions(); i++) d[i] = img.dimension(i);
		dim = d;
	}
	final Type<?> type = img.firstElement().createVariable();
	if (ARGBType.class.isAssignableFrom(type.getClass())) { // type instanceof RGBALegacyType fails to compile
		return (Img)processRGBA((Img)img, dim, mode);
	} else if (type instanceof RealType<?>) {
		return processReal((Img)img, dim, mode);
	} else {
		throw new Exception("Affine transform: cannot handle type " + type.getClass());
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:20,代码来源:Resample.java

示例5: copyInterpolatedGeneric

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
public static <T extends NumericType< T > > void copyInterpolatedGeneric( RandomAccessible< T > from, IterableInterval< T > to, double[] offset, double scale, InterpolatorFactory< T, RandomAccessible< T > > interpolatorFactory )
{
	final int n = to.numDimensions();
	final double[] fromPosition = new double[ n ];
	Cursor< T > cursor = to.localizingCursor();
	RealRandomAccess< T > interpolator =  interpolatorFactory.create( from );
	while ( cursor.hasNext() )
	{
		final T t = cursor.next();
		for ( int d = 0; d < n; ++d )
		{
			fromPosition[ d ] = scale * cursor.getDoublePosition( d ) + offset[ d ];
		}
		interpolator.setPosition( fromPosition );
		t.set( interpolator.get() );
	}
}
 
开发者ID:imglib,项目名称:imglib2-tests,代码行数:18,代码来源:OpenAndDisplayInterpolated.java

示例6: mapInterval

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
public final static <T extends NumericType<T>> void mapInterval(
		final KernelTransformFloatSeparable xfm,
		final Img<T> src, final Img<T> tgt )
{
	NLinearInterpolatorFactory<T> interp = new NLinearInterpolatorFactory<T>();
	RealRandomAccess<T> sara = Views.interpolate( Views.extendZero(src), interp ).realRandomAccess();
	
	Cursor<T> tc = tgt.cursor();
	float[] pos = new float[src.numDimensions()]; 
	while( tc.hasNext() ){
		tc.fwd();
		tc.localize(pos);
		float[] srcPt  = xfm.transformPoint( pos );
		sara.setPosition( srcPt );
		tc.get().set( sara.get() );
		
	}
}
 
开发者ID:bogovicj,项目名称:hhmi-exp,代码行数:19,代码来源:SimCrack.java

示例7: createZeroExtended

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
/**
 * @param source
 *            Source to be wrapped.
 * @param stepSize
 *            Strides for each dimension
 * @return BlockedInterval wrapped around zero extended source.
 */
public static < U extends NumericType< U > > BlockedInterval< U > createZeroExtended(
		RandomAccessibleInterval< U > source,
		long[] stepSize )
{
	U value = source.randomAccess().get().copy();
	value.setZero();
	return createValueExtended( source, stepSize, value );
}
 
开发者ID:saalfeldlab,项目名称:bigcat,代码行数:16,代码来源:BlockedInterval.java

示例8: copyToImageStack

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
public static < T extends NumericType<T> > RandomAccessibleInterval<T> copyToImageStack( 
		final RandomAccessible< T > raible,
		final Interval itvl,
		final ImgFactory<T> factory,
		final int nThreads )
{
	// create the image plus image
	final T t = raible.randomAccess().get().copy();
	Img< T > target = factory.create( itvl, t );
	return copyToImageStack( raible, itvl, target, nThreads );
}
 
开发者ID:saalfeldlab,项目名称:bigwarp,代码行数:12,代码来源:BigWarpExporter.java

示例9: copyToImageStack

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
public static < T extends NumericType< T > & NativeType< T > > ImagePlus copyToImageStack( final RealRandomAccessible< T > rai, final Interval itvl )
{
	final long[] dimensions = new long[ itvl.numDimensions() ];
	itvl.dimensions( dimensions );

	// create the image plus image
	final T t = rai.realRandomAccess().get();
	final ImagePlusImgFactory< T > factory = new ImagePlusImgFactory< T >();
	final ImagePlusImg< T, ? > target = factory.create( itvl, t );

	double k = 0;
	final long N = dimensions[ 0 ] * dimensions[ 1 ] * dimensions[ 2 ];

	final net.imglib2.Cursor< T > c = target.cursor();
	final RealRandomAccess< T > ra = rai.realRandomAccess();
	while ( c.hasNext() )
	{
		c.fwd();
		ra.setPosition( c );
		c.get().set( ra.get() );

		if ( k % 10000 == 0 )
		{
			IJ.showProgress( k / N );
		}
		k++;
	}

	IJ.showProgress( 1.1 );
	try
	{
		return target.getImagePlus();
	}
	catch ( final ImgLibException e )
	{
		e.printStackTrace();
	}

	return null;
}
 
开发者ID:saalfeldlab,项目名称:bigwarp,代码行数:41,代码来源:BigWarpRealExporter.java

示例10: process

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
@SuppressWarnings({ "rawtypes", "unchecked" })
private static final <R extends NumericType<R>> Img<R> process(final IterableInterval<R> img) {
	if (img instanceof Img) {
		return ((Img<R>)img).copy();
	}

	if (img.firstElement() instanceof NativeType<?>) {
		return copyAsArrayImg((IterableInterval)img);
	}
	
	throw new IllegalArgumentException("Could not duplicate image of class " + img.getClass() + " with type " + img.firstElement().getClass());
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:13,代码来源:Duplicate.java

示例11: computeSmallestType

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
/**
 * Determine the smallest type that will correctly store the sums.
 * For {@link Img} whose type has integer precision, the largest type is {@link LongType}.
 * For {@link Img} whose type has floating-point precision, the largest type is {@link DoubleType}.
 * 
 * @param img The input {@link Img}.
 * @return
 */
static public final <R extends RealType<R>, T extends NativeType<T> & NumericType<T>> T computeSmallestType(final Img<R> img) {
	final R type = img.firstElement();
	final long maxSum = (long) (img.size() * (Math.pow(2, type.getBitsPerPixel()) -1));
	T smallest = chooseSmallestType(type, maxSum);
	if (null != smallest) return smallest;
	// Else, slow way: sum all values and determine the smallest type
	final RealSum sum = new RealSum();
	for (final R r : img) sum.add(r.getRealDouble());
	smallest = chooseSmallestType(type, sum.getSum());
	if (null != smallest) return smallest;
	throw new UnsupportedOperationException("Target image is too large!");
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:21,代码来源:FastIntegralImg.java

示例12: chooseSmallestType

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
@SuppressWarnings("unchecked")
static private final <R extends RealType<R>, T extends NativeType<T> & NumericType<T>> T chooseSmallestType(final R srcType, final double maxSum) {
	if (IntegerType.class.isAssignableFrom(srcType.getClass())) {
		if (maxSum < Math.pow(2, 8)) return (T)(Object) new UnsignedByteType();
		if (maxSum < Math.pow(2, 16)) return (T)(Object) new UnsignedShortType();
		if (maxSum < Math.pow(2, 32)) return (T)(Object) new UnsignedIntType();
		if (maxSum < Math.pow(2, 64)) return (T)(Object) new LongType();
	} else {
		if (maxSum <= Float.MAX_VALUE) return (T)(Object) new FloatType();
		if (maxSum <= Double.MAX_VALUE) return (T)(Object) new DoubleType();
	}
	return null;
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:14,代码来源:FastIntegralImg.java

示例13: populate1

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
static private final <R extends NumericType<R>, T extends NumericType<T>> void populate1(final Img<R> img, final Img<T> iimg, final Converter<R, T> converter, final T sum) {
	final RandomAccess<R> r1 = img.randomAccess();
	final RandomAccess<T> r2 = iimg.randomAccess();
	sum.setZero();
	r2.move(1L, 0);
	for (long pos = 0; pos < img.dimension(0); ++pos) {
		converter.convert(r1.get(), r2.get());
		sum.add(r2.get());
		r2.get().set(sum);
		r1.move(1L, 0);
		r2.move(1L, 0);
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:14,代码来源:FastIntegralImg.java

示例14: populate2

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
/** The offsets of 1,1 are due to the integral image being +1 larger in every dimension.
 * 
 * @param img
 * @param iimg
 * @param converter
 * @param sum
 */
static private final <R extends NumericType<R>, T extends NumericType<T>> void populate2(final Img<R> img, final Img<T> iimg, final Converter<R, T> converter, final T sum) {
	final RandomAccess<R> r1 = img.randomAccess();
	final RandomAccess<T> r2 = iimg.randomAccess();
	final T tmp = sum.createVariable();
	// Position r2 at 1,1
	r2.fwd(0);
	r2.fwd(1);
	// Integrate rows
	for (long pos1 = 0; pos1 < img.dimension(1); ++pos1) { // for every row
		sum.setZero();
		r1.setPosition(0L, 0);
		r2.setPosition(1L, 0);
		for (long pos0 = 0; pos0 < img.dimension(0); ++pos0) { // for every element in row
			converter.convert(r1.get(), tmp);
			sum.add(tmp);
			r2.get().set(sum);
			r1.fwd(0);
			r2.fwd(0);
		}
		r1.fwd(1);
		r2.fwd(1);
	}
	// Integrate columns
	r2.setPosition(1L, 0);
	for (long pos0 = 0; pos0 < img.dimension(0); ++pos0) {
		sum.setZero();
		r2.setPosition(1L, 1);
		for (long pos1 = 0; pos1 < img.dimension(1); ++pos1) {
			sum.add(r2.get());
			r2.get().set(sum);
			r2.fwd(1);
		}
		r2.fwd(0);
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:43,代码来源:FastIntegralImg.java

示例15: integrateRows

import net.imglib2.type.numeric.NumericType; //导入依赖的package包/类
static private final <T extends NumericType<T>> void integrateRows(
		final int rowDimension,
		final Interval iimg,
		final RandomAccess<T> r2,
		final T sum,
		final int[] rowDims) {
	long nRows = 1;
	for (int i=0; i<rowDims.length; ++i) nRows *= iimg.dimension(rowDims[i]) -1;
	
	while (0 != nRows) {
		// Integrate an interval over rowDimension
		integrateRow(rowDimension, iimg, r2, sum);
		--nRows;
		
		for (int i=0; i<rowDims.length; ++i) {
			// Advance to the next interval to integrate
			r2.fwd(rowDims[i]);
			// If beyond bounds in the d dimension
			if (r2.getLongPosition(rowDims[i]) == iimg.dimension(rowDims[i])) {
				// Reset the d dimension
				r2.setPosition(1L, rowDims[i]);
				// Advance the next dimension
				continue;
			}
			// Else integrate the next interval
			break;
		}
	}
}
 
开发者ID:imglib,项目名称:imglib2-script,代码行数:30,代码来源:FastIntegralImg.java


注:本文中的net.imglib2.type.numeric.NumericType类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。