com.github.jessemull.microflexinteger.math.MathOperationShift Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of microflex-integer Show documentation
Show all versions of microflex-integer Show documentation
Microplate library for parsing wet lab data.
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/* -------------------------------- Package --------------------------------- */
package com.github.jessemull.microflexinteger.math;
/* ------------------------------ Dependencies ------------------------------ */
import java.util.List;
import com.github.jessemull.microflexinteger.plate.Plate;
import com.github.jessemull.microflexinteger.plate.Stack;
import com.github.jessemull.microflexinteger.plate.Well;
import com.github.jessemull.microflexinteger.plate.WellSet;
/**
* This class performs mathematical shift operations for integer plate stacks,
* plates, wells and well sets. To create a custom shift operation extend this
* class and override the calculate methods using the appropriate operation.
* Shift operations can also be performed on a subset of data using a beginning
* index and subset length.
*
* MicroFlex currently supports the following shift mathematical operations
* for integer values:
*
*
* Operations
*
* Left Shift
*
*
* Right Shift (Arithmetic/Signed)
*
*
* Right Shift (Logical/Unsigned)
*
*
*
* @author Jesse L. Mull
* @update Updated Oct 18, 2016
* @address http://www.jessemull.com
* @email [email protected]
*/
public abstract class MathOperationShift {
/* ---------------------------- Constructors ---------------------------- */
/**
* Creates a new math operation.
*/
public MathOperationShift() {}
/* ----------------------------- Well Methods --------------------------- */
/**
* Returns the result of the mathematical operation.
* @param Well the well
* @param int number of bits to shift
* @return result of the operation
*/
public List wells(Well well, int n) {
if(well == null) {
throw new NullPointerException("Well is null.");
}
return calculate(well.data(), n);
}
/**
* Returns the result of the mathematical operation using the values between
* the indices.
* @param Well the well
* @param int number of bits to shift
* @param int beginning index of the subset
* @param int length of the subset
* @return result of the operation
*/
public List wells(Well well, int n, int begin, int length) {
if(well == null) {
throw new NullPointerException("Well is null.");
}
return calculate(well.data(), n, begin, length);
}
/* ---------------------------- Plate Methods --------------------------- */
/**
* Returns the result of the mathematical operation.
* @param Plate the plate
* @param int number of bits to shift
* @return result of the operation
*/
public Plate plates(Plate plate, int n) {
if(plate == null) {
throw new NullPointerException("Plate is null.");
}
Plate result = new Plate(plate.rows(), plate.columns());
for(Well well : plate) {
result.addWells(new Well(well.row(), well.column(),
this.calculate(well.data(), n)));
}
return result;
}
/**
* Returns the result of the mathematical operation using the values between
* the indices.
* @param Plate the plate
* @param int number of bits to shift
* @param int beginning index of the subset
* @param int length of the subset
* @return result of the operation
*/
public Plate plates(Plate plate, int n, int begin, int length) {
if(plate == null) {
throw new NullPointerException("Plate is null.");
}
Plate result = new Plate(plate.rows(), plate.columns());
for(Well well : plate) {
result.addWells(new Well(well.row(), well.column(),
this.calculate(well.data(), n, begin, length)));
}
return result;
}
/* ----------------------------- Set Methods ---------------------------- */
/**
* Returns the result of the mathematical operation.
* @param WellSet well the well set
* @param int number of bits to shift
* @return result of the operation
*/
public WellSet sets(WellSet set, int n) {
if(set == null) {
throw new NullPointerException("Well set is null.");
}
WellSet result = new WellSet();
for(Well well : set) {
result.add(new Well(well.row(), well.column(),
this.calculate(well.data(), n)));
}
return result;
}
/**
* Returns the result of the mathematical operation using the values between
* the indices.
* @param WellSet the first plate
* @param int number of bits to shift
* @param int beginning index of the subset
* @param int length of the subset
* @return result of the operation
*/
public WellSet sets(WellSet set, int n, int begin, int length) {
if(set == null) {
throw new NullPointerException("Well set is null.");
}
WellSet result = new WellSet();
for(Well well : set) {
result.add(new Well(well.row(), well.column(),
this.calculate(well.data(), n, begin, length)));
}
return result;
}
/* ---------------------------- Stack Methods --------------------------- */
/**
* Returns the result of the mathematical operation.
* @param Stack the stack
* @param int number of bits to shift
* @return the result of the operation
*/
public Stack stacks(Stack stack, int n) {
if(stack == null) {
throw new NullPointerException("Stack is null.");
}
Stack result = new Stack(stack.rows(), stack.columns());
for(Plate plate : stack) {
result.add(this.plates(plate, n));
}
return result;
}
/**
* Returns the result of the mathematical operation.
* @param Stack the stack
* @param int number of bits to shift
* @param int beginning index of the sub set
* @param int length of the subset
* @return the result of the operation
*/
public Stack stacks(Stack stack, int n, int begin, int length) {
if(stack == null) {
throw new NullPointerException("Stack is null.");
}
Stack result = new Stack(stack.rows(), stack.columns());
for(Plate plate : stack) {
result.add(this.plates(plate, n, begin, length));
}
return result;
}
/*------------------------ List Operation Methods ------------------------*/
/**
* Performs the mathematical operation for the two lists.
* @param List the first list
* @param int number of bits to shift
* @return result of the mathematical operation
*/
public abstract List calculate(List list, int n);
/**
* Performs the mathematical operation for the two lists using the values
* between the indices.
* @param List the first list
* @param int number of bits to shift
* @return result of the mathematical operation
*/
public abstract List calculate(List list, int n, int begin, int length);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy