Class BitType
- All Implemented Interfaces:
Comparable<BitType>,BooleanType<BitType>,NativeType<BitType>,ComplexType<BitType>,IntegerType<BitType>,NumericType<BitType>,RealType<BitType>,Add<BitType>,Div<BitType>,Mul<BitType>,MulFloatingPoint,SetOne,SetZero,Sub<BitType>,ValueEquals<BitType>,Type<BitType>
- Author:
- Stephan Preibisch, Stephan Saalfeld
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected LongAccessprotected intprotected final NativeImg<?, ? extends LongAccess> -
Constructor Summary
ConstructorsConstructorDescriptionBitType()BitType(boolean value) BitType(LongAccess access) BitType(NativeImg<?, ? extends LongAccess> bitStorage) -
Method Summary
Modifier and TypeMethodDescriptionvoidvoidintcopy()NativeImg<BitType, ? extends LongAccess> createSuitableNativeImg(NativeImgFactory<BitType> storageFactory, long[] dim) TheNativeTypecreates theNativeImgused for storing image data; based on the given storage strategy and its size.Creates a newTypevariable which can only store one value.voiddec()voiddecIndex()Decrement the index into the current data array.voiddecIndex(int decrement) Decrease the index into the current data array bydecrementsteps.voidCreates a newNativeTypewhich stores in the same physical array.booleanget()intGet the number of entities in the storage array required to store one pixel value.intgetIndex()Get the current index into the current data array.intlongdoubledoublevoidinc()voidincIndex()Increment the index into the current data array.voidincIndex(int increment) Increases the index into the current data array byincrementsteps.voidmul(double c) voidmul(float c) voidvoidnot()voidvoidset(boolean value) voidSets the value of anotherType.voidvoidsetInteger(int f) voidsetInteger(long f) voidsetOne()voidsetZero()voidtoString()voidThis method is used by an accessor (e.g., aCursor) to request an update of the current data array.voidupdateIndex(int index) Set the index into the current data array.booleanvoidMethods inherited from class net.imglib2.type.numeric.integer.AbstractIntegerType
getMinIncrement, getRealDouble, getRealFloat, hashCode, setReal, setRealMethods inherited from class net.imglib2.type.numeric.real.AbstractRealType
equals, getImaginaryDouble, getImaginaryFloat, getPhaseDouble, getPhaseFloat, getPowerDouble, getPowerFloat, setImaginary, setImaginaryMethods inherited from class net.imglib2.type.numeric.complex.AbstractComplexType
complexConjugate, setComplexNumber, setComplexNumberMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface net.imglib2.type.numeric.ComplexType
complexConjugate, getImaginaryDouble, getImaginaryFloat, getPhaseDouble, getPhaseFloat, getPowerDouble, getPowerFloat, getRealDouble, getRealFloat, setComplexNumber, setComplexNumber, setImaginary, setImaginary, setReal, setRealMethods inherited from interface net.imglib2.type.numeric.RealType
getMinIncrement
-
Field Details
-
i
protected int i -
img
-
dataAccess
-
-
Constructor Details
-
BitType
-
BitType
public BitType(boolean value) -
BitType
-
BitType
public BitType()
-
-
Method Details
-
createSuitableNativeImg
public NativeImg<BitType,? extends LongAccess> createSuitableNativeImg(NativeImgFactory<BitType> storageFactory, long[] dim) Description copied from interface:NativeTypeTheNativeTypecreates theNativeImgused for storing image data; based on the given storage strategy and its size. It basically only decides here which BasicType it uses (float, int, byte, bit, ...) and how many entities per pixel it needs (e.g. 2 floats per pixel for a complex number). This enables the separation of containers and the basic types.- Specified by:
createSuitableNativeImgin interfaceNativeType<BitType>- Parameters:
storageFactory- which storage strategy is useddim- the dimensions- Returns:
- the instantiated
NativeImgwhere only theTypeknows the BasicType it contains.
-
updateContainer
Description copied from interface:NativeTypeThis method is used by an accessor (e.g., aCursor) to request an update of the current data array.As an example consider a
CellCursormoving on aCellImg. The cursor maintains aNativeTypewhich provides access to the image data. When the cursor moves from one cell to the next, the underlying data array of theNativeTypemust be switched to the data array of the new cell.To achieve this, the
CellCursorcallsupdateContainer()with itself as the argument.updateContainer()in turn will callNativeImg.update(Object)on it's container, passing along the reference to the cursor. In this example, the container would be aCellImg. While theNativeTypedoes not know about the type of the cursor, the container does.CellImgknows that it is passed aCellCursorinstance, which can be used to figure out the current cell and the underlying data array, which is then returned to theNativeType.The idea behind this concept is maybe not obvious. The
NativeTypeknows which basic type is used (float, int, byte, ...). However, it does not know how the data is stored (ArrayImg,CellImg, ...). This prevents the need for multiple implementations ofNativeType.- Specified by:
updateContainerin interfaceNativeType<BitType>- Parameters:
c- reference to an accessor which can be passed on to the container (which will know what to do with it).
-
duplicateTypeOnSameNativeImg
Description copied from interface:NativeTypeCreates a newNativeTypewhich stores in the same physical array. This is only used internally.- Specified by:
duplicateTypeOnSameNativeImgin interfaceNativeType<BitType>- Returns:
- a new
NativeTypeinstance working on the sameNativeImg
-
get
public boolean get()- Specified by:
getin interfaceBooleanType<BitType>
-
set
public void set(boolean value) - Specified by:
setin interfaceBooleanType<BitType>
-
getInteger
public int getInteger()- Specified by:
getIntegerin interfaceIntegerType<BitType>
-
getIntegerLong
public long getIntegerLong()- Specified by:
getIntegerLongin interfaceIntegerType<BitType>
-
getBigInteger
- Specified by:
getBigIntegerin interfaceIntegerType<BitType>
-
setInteger
public void setInteger(int f) - Specified by:
setIntegerin interfaceIntegerType<BitType>
-
setInteger
public void setInteger(long f) - Specified by:
setIntegerin interfaceIntegerType<BitType>
-
setBigInteger
- Specified by:
setBigIntegerin interfaceIntegerType<BitType>
-
getMaxValue
public double getMaxValue()- Specified by:
getMaxValuein interfaceRealType<BitType>
-
getMinValue
public double getMinValue()- Specified by:
getMinValuein interfaceRealType<BitType>
-
set
Description copied from interface:TypeSets the value of anotherType. -
and
- Specified by:
andin interfaceBooleanType<BitType>
-
or
- Specified by:
orin interfaceBooleanType<BitType>
-
xor
- Specified by:
xorin interfaceBooleanType<BitType>
-
not
public void not()- Specified by:
notin interfaceBooleanType<BitType>
-
add
-
div
-
mul
-
sub
-
mul
public void mul(float c) - Specified by:
mulin interfaceMulFloatingPoint- Overrides:
mulin classAbstractRealType<BitType>
-
mul
public void mul(double c) - Specified by:
mulin interfaceMulFloatingPoint- Overrides:
mulin classAbstractRealType<BitType>
-
setOne
public void setOne()- Specified by:
setOnein interfaceSetOne- Overrides:
setOnein classAbstractIntegerType<BitType>
-
setZero
public void setZero()- Specified by:
setZeroin interfaceSetZero- Overrides:
setZeroin classAbstractIntegerType<BitType>
-
inc
public void inc() -
dec
public void dec() -
compareTo
- Specified by:
compareToin interfaceComparable<BitType>- Overrides:
compareToin classAbstractIntegerType<BitType>
-
createVariable
Description copied from interface:TypeCreates a newTypevariable which can only store one value.- Specified by:
createVariablein interfaceType<BitType>- Returns:
- a new
Typevariable
-
copy
Description copied from interface:Type -
toString
- Overrides:
toStringin classAbstractIntegerType<BitType>
-
getEntitiesPerPixel
Description copied from interface:NativeTypeGet the number of entities in the storage array required to store one pixel value. A pixel value may be spread over several or less than one entity. For example, a complex number may require 2 entries of a float[] array to store one pixel. Or a 12-bit type might need 12/64th entries of a long[] array.- Specified by:
getEntitiesPerPixelin interfaceNativeType<BitType>- Returns:
- the number of storage type entities required to store one pixel value.
-
updateIndex
public void updateIndex(int index) Description copied from interface:NativeTypeSet the index into the current data array.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
updateIndexin interfaceNativeType<BitType>- Parameters:
index- the new array index
-
getIndex
public int getIndex()Description copied from interface:NativeTypeGet the current index into the current data array.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
getIndexin interfaceNativeType<BitType>- Returns:
- the current index into the underlying data array
-
incIndex
public void incIndex()Description copied from interface:NativeTypeIncrement the index into the current data array.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
incIndexin interfaceNativeType<BitType>
-
incIndex
public void incIndex(int increment) Description copied from interface:NativeTypeIncreases the index into the current data array byincrementsteps.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
incIndexin interfaceNativeType<BitType>- Parameters:
increment- how many steps
-
decIndex
public void decIndex()Description copied from interface:NativeTypeDecrement the index into the current data array.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
decIndexin interfaceNativeType<BitType>
-
decIndex
public void decIndex(int decrement) Description copied from interface:NativeTypeDecrease the index into the current data array bydecrementsteps.This is used by accessors (e.g., a
Cursor) to position theNativeTypein the container.- Specified by:
decIndexin interfaceNativeType<BitType>- Parameters:
decrement- how many steps
-
getBitsPerPixel
public int getBitsPerPixel()- Specified by:
getBitsPerPixelin interfaceRealType<BitType>
-
valueEquals
- Specified by:
valueEqualsin interfaceValueEquals<BitType>
-