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

de.dfki.lt.signalproc.util.BlockwiseDoubleDataSource Maven / Gradle / Ivy

The newest version!
/**
 * Copyright 2004-2006 DFKI GmbH.
 * All Rights Reserved.  Use is subject to license terms.
 * 
 * Permission is hereby granted, free of charge, to use and distribute
 * this software and its documentation without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of this work, and to
 * permit persons to whom this work is furnished to do so, subject to
 * the following conditions:
 * 
 * 1. The code must retain the above copyright notice, this list of
 *    conditions and the following disclaimer.
 * 2. Any modifications must be clearly marked as such.
 * 3. Original authors' names are not deleted.
 * 4. The authors' names are not used to endorse or promote products
 *    derived from this software without specific prior written
 *    permission.
 *
 * DFKI GMBH AND THE CONTRIBUTORS TO THIS WORK DISCLAIM ALL WARRANTIES WITH
 * REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL DFKI GMBH NOR THE
 * CONTRIBUTORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
 * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
 * THIS SOFTWARE.
 */

package de.dfki.lt.signalproc.util;

// TODO: Auto-generated Javadoc
/**
 * The Class BlockwiseDoubleDataSource.
 *
 * @author Marc Schröder
 */
public class BlockwiseDoubleDataSource extends BufferedDoubleDataSource {
    
    /** The block size. */
    protected int blockSize;
    
    /**
     * Instantiates a new blockwise double data source.
     *
     * @param inputSource the input source
     * @param blockSize the block size
     */
    public BlockwiseDoubleDataSource(DoubleDataSource inputSource, int blockSize) {
        super(inputSource);
        this.blockSize = blockSize;
    }

    /**
     * Attempt to get more data from the input source. If less than this can be read,
     * the possible amount will be read, but canReadMore() will return false afterwards.
     * @param minLength the amount of data to get from the input source
     * @return true if the requested amount could be read, false if none or less data could be read.
     */
    protected boolean readIntoBuffer(int minLength)
    {
        if (bufferSpaceLeft()= minLength;
        
    }

    /**
     * Provide the size of the next block. This implementation returns the fixed
     * blocksize given in the constructor.
     * Subclasses may want to override this method.
     *
     * @return the block size
     */
    protected int getBlockSize() { return blockSize; }

    /**
     * Prepare a block of data for output. This method is called before readBlock() is called.
     * This implementation does nothing.
     * Subclasses will want to override this method.
     *
     */
    protected void prepareBlock() {}
    
    /**
     * Read a block of data. This method is called after prepareBlock() is called. 
     * This implementation simply reads getBlockSize()
     * data from the inputSource given in the constructor.
     * Subclasses will want to override this method.
     *
     * @param target the target
     * @param pos the pos
     * @return number of values written into target from position pos
     */
    protected int readBlock(double[] target, int pos)
    {
        return inputSource.getData(target, pos, getBlockSize());
    }
    

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy