public class ForwWTFull extends ForwardWT
| Modifier and Type | Field and Description | 
|---|---|
| private int | cb0xThe horizontal coordinate of the code-block partition origin on the
        reference grid | 
| private int | cb0yThe vertical coordinate of the code-block partition on the reference
        grid | 
| private CBlkSizeSpec | cblksThe code-block size specifications | 
| (package private) SubbandAn[] | currentSubbandThe subband being dealt with in each component | 
| private DataBlk[] | decomposedCompsBlock storing the full band decomposition for each component. | 
| private IntegerSpec | dlsThe number of decomposition levels specification | 
| private AnWTFilterSpec | filtersWavelet filters for all components and tiles | 
| private boolean | intDataBoolean to know if one are currently dealing with int or float
        data. | 
| private int[] | lastmThe vertical index of the last code-block "sent" in the current subband
 in each component. | 
| private int[] | lastnThe horizontal index of the last code-block "sent" in the current
 subband in each component. | 
| (package private) Point | ncblksCache object to avoid excessive allocation/deallocation. | 
| private PrecinctSizeSpec | pssThe precinct partition specifications | 
| private BlkImgDataSrc | srcThe source of image data | 
| private SubbandAn[][] | subbTreesThe subband trees for each component, in each tile. | 
OPT_PREFIX, WT_DECOMP_DYADICimgdatasrc, tIdxWT_IMPL_FULL, WT_IMPL_LINE| Constructor and Description | 
|---|
| ForwWTFull(BlkImgDataSrc src,
          J2KImageWriteParamJava wp,
          int pox,
          int poy)Initializes this object with the given source of image data and with
 all the decompositon parameters | 
| Modifier and Type | Method and Description | 
|---|---|
| SubbandAn | getAnSubbandTree(int t,
                int c)Returns a reference to the subband tree structure representing the
 subband decomposition for the specified tile-component of the source. | 
| int | getCbULX()Returns the horizontal offset of the code-block partition. | 
| int | getCbULY()Returns the vertical offset of the code-block partition. | 
| int | getDataType(int t,
           int c)Return the data type of this CBlkWTDataSrc. | 
| int | getDecomp(int t,
         int c)Returns the wavelet tree decomposition. | 
| int | getDecompLevels(int t,
               int c)Returns the number of decomposition levels that are applied to the LL
 band, in the specified tile-component. | 
| int | getFixedPoint(int c)Returns the position of the fixed point in the specified
 component. | 
| AnWTFilter[] | getHorAnWaveletFilters(int t,
                      int c)Returns the horizontal analysis wavelet filters used in each level, for
 the specified component and tile. | 
| int | getImplementationType(int c)Returns the implementation type of this wavelet transform, WT_IMPL_FULL
 (full-page based transform). | 
| CBlkWTData | getNextCodeBlock(int c,
                CBlkWTData cblk)Returns the next code-block in the current tile for the specified
 component, as a copy (see below). | 
| CBlkWTData | getNextInternCodeBlock(int c,
                      CBlkWTData cblk)Returns the next code-block in the current tile for the specified
 component. | 
| private SubbandAn | getNextSubband(int c)Returns the next subband that will be used to get the next code-block
 to return by the getNext[Intern]CodeBlock method. | 
| AnWTFilter[] | getVertAnWaveletFilters(int t,
                       int c)Returns the vertical analysis wavelet filters used in each level, for
 the specified component and tile. | 
| private void | initSubbandsFields(int t,
                  int c,
                  Subband sb)Initialises subbands fields, such as number of code-blocks and
 code-blocks dimension, in the subband tree. | 
| boolean | isReversible(int t,
            int c)Returns the reversibility of the wavelet transform for the specified
 component and tile. | 
| void | nextTile()Advances to the next tile, in standard scan-line order (by rows then
 columns). | 
| void | setTile(int x,
       int y)Changes the current tile, given the new coordinates. | 
| private void | wavelet2DDecomposition(DataBlk band,
                      SubbandAn subband,
                      int c)Performs the 2D forward wavelet transform on a subband of the initial
 band. | 
| private void | waveletTreeDecomposition(DataBlk band,
                        SubbandAn subband,
                        int c)Performs the forward wavelet transform on the whole band. | 
createInstance, getParameterInfogetCompImgHeight, getCompImgWidth, getCompSubsX, getCompSubsY, getCompULX, getCompULY, getImgHeight, getImgULX, getImgULY, getImgWidth, getNomRangeBits, getNomTileHeight, getNomTileWidth, getNumComps, getNumTiles, getNumTiles, getTile, getTileCompHeight, getTileCompWidth, getTileHeight, getTileIdx, getTilePartULX, getTilePartULY, getTileWidthclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitgetCompImgHeight, getCompImgWidth, getCompSubsX, getCompSubsY, getCompULX, getCompULY, getImgHeight, getImgULX, getImgULY, getImgWidth, getNomRangeBits, getNomTileHeight, getNomTileWidth, getNumComps, getNumTiles, getNumTiles, getTile, getTileCompHeight, getTileCompWidth, getTileHeight, getTileIdx, getTilePartULX, getTilePartULY, getTileWidthprivate boolean intData
private SubbandAn[][] subbTrees
The subband tree for a component in the current tile is created on the first call to getSubbandTree() for that component, in the current tile. Before that the element in 'subbTrees' is null.
private BlkImgDataSrc src
private int cb0x
private int cb0y
private IntegerSpec dls
private AnWTFilterSpec filters
private CBlkSizeSpec cblks
private PrecinctSizeSpec pss
private DataBlk[] decomposedComps
private int[] lastn
private int[] lastm
SubbandAn[] currentSubband
Point ncblks
public ForwWTFull(BlkImgDataSrc src, J2KImageWriteParamJava wp, int pox, int poy)
src - From where the image data should be obtained.wp - The writing parameterspox - The horizontal coordinate of the cell and code-block
 partition origin with respect to the canvas origin, on the reference
 grid.poy - The vertical coordinate of the cell and code-block partition
 origin with respect to the canvas origin, on the reference grid.ForwardWTpublic int getImplementationType(int c)
c - The index of the component.public int getDecompLevels(int t,
                  int c)
t - The tile indexc - The index of the component.public int getDecomp(int t,
            int c)
t - The tile-indexc - The index of the component.public AnWTFilter[] getHorAnWaveletFilters(int t, int c)
The returned filters are applicable only to the specified component and in the current tile.
The resolution level of a subband is the resolution level to which a subband contributes, which is different from its decomposition level.
t - The index of the tile for which to return the filters.c - The index of the component for which to return the filters.public AnWTFilter[] getVertAnWaveletFilters(int t, int c)
The returned filters are applicable only to the specified component and in the current tile.
The resolution level of a subband is the resolution level to which a subband contributes, which is different from its decomposition level.
t - The index of the tile for which to return the filters.c - The index of the component for which to return the filters.public boolean isReversible(int t,
                   int c)
t - The index of the tile.c - The index of the component.public int getCbULX()
public int getCbULY()
public int getFixedPoint(int c)
c - The index of the component.public CBlkWTData getNextInternCodeBlock(int c, CBlkWTData cblk)
When changing the current tile (through 'setTile()' or 'nextTile()') this method will always return the first code-block, as if this method was never called before for the new current tile.
The data returned by this method is the data in the internal buffer of this object, and thus can not be modified by the caller. The 'offset' and 'scanw' of the returned data have, in general, some non-zero value. The 'magbits' of the returned data is not set by this method and should be ignored. See the 'CBlkWTData' class.
The 'ulx' and 'uly' members of the returned 'CBlkWTData' object contain the coordinates of the top-left corner of the block, with respect to the tile, not the subband.
c - The component for which to return the next code-block.cblk - If non-null this object will be used to return the new
 code-block. If null a new one will be allocated and returned.CBlkWTDatapublic CBlkWTData getNextCodeBlock(int c, CBlkWTData cblk)
When changing the current tile (through 'setTile()' or 'nextTile()') this method will always return the first code-block, as if this method was never called before for the new current tile.
The data returned by this method is always a copy of the internal data of this object, and it can be modified "in place" without any problems after being returned. The 'offset' of the returned data is 0, and the 'scanw' is the same as the code-block width. The 'magbits' of the returned data is not set by this method and should be ignored. See the 'CBlkWTData' class.
The 'ulx' and 'uly' members of the returned 'CBlkWTData' object contain the coordinates of the top-left corner of the block, with respect to the tile, not the subband.
c - The component for which to return the next code-block.cblk - If non-null this object will be used to return the new
 code-block. If null a new one will be allocated and returned. If the
 "data" array of the object is non-null it will be reused, if possible,
 to return the data.CBlkWTDatapublic int getDataType(int t,
              int c)
t - The index of the tile for which to return the data type.c - The index of the component for which to return the data type.private SubbandAn getNextSubband(int c)
c - The componentprivate void waveletTreeDecomposition(DataBlk band, SubbandAn subband, int c)
band - The band containing the float data to decomposesubband - The structure containing the coordinates of the current
 subband in the whole band to decompose.c - The index of the current component to decomposeprivate void wavelet2DDecomposition(DataBlk band, SubbandAn subband, int c)
band - The band containing the float data to decomposesubband - The structure containing the coordinates of the subband
 in the whole band to decompose.c - The index of the current component to decomposepublic void setTile(int x,
           int y)
This method resets the 'subbTrees' array, and recalculates the values of the 'reversible' array. It also resets the decomposed component buffers.
setTile in interface ImgDatasetTile in class ImgDataAdapterx - The horizontal coordinate of the tile.y - The vertical coordinate of the new tile.public void nextTile()
This method resets the 'subbTrees' array, and recalculates the values of the 'reversible' array. It also resets the decomposed component buffers.
nextTile in interface ImgDatanextTile in class ImgDataAdapterpublic SubbandAn getAnSubbandTree(int t, int c)
private void initSubbandsFields(int t,
                      int c,
                      Subband sb)
t - The tile index of the subbandc - The component indexsb - The subband tree to be initialised.Copyright © 2015 Open Microscopy Environment