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

com.github.jessemull.microflexinteger.plate.Well Maven / Gradle / Ivy

There is a newer version: 1.0.1
Show newest version
/**
 * 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.plate;

/* ------------------------------ Dependencies ------------------------------ */

import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

import com.github.jessemull.microflexinteger.plate.WellPrecursor;
import com.github.jessemull.microflexinteger.util.IntegerUtil;

/**
 * This class represents a well in a microplate. It contains the the logic to 
 * convert row letters to integers and vice-versa, enforces the correct format 
 * for well IDs and holds a list of data set values. The well object does not 
 * check for wells outside a specified range. This logic is housed within the 
 * plate object.
 * 
 * All the classes in the microplate library are designed to be flexible in
 * order to accommodate data in a variety of formats. The well object constructor
 * accepts well IDs in each of the following formats:
 * 
 * 
 *    
 *    
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 *    
 *       
 *       
 *       
 *    
 * 
Row
Column
Input
IntegerIntegerRow = 1 Column = 2
StringIntegerRow = "1" Column = 2
StringIntegerRow = "A" Column = 2
IntegerStringRow = 1 Column = "2"
StringStringRow = "A" Column = "2"
StringStringRow = "1" Column = "2"
StringString"A2" Input must be [A-Za-z]+[0-9]+
* * The Well class also implements both hash code and equals functions in order to * prevent duplicate wells within a single plate object. * * The well constructor is passed a flag holding the numerical data type. Once * set, the numerical data type cannot be changed. This well type supports storage * of integer values only. The MicroFlex library supports wells containing all * primitive numerical types for input and output as well as two immutable types: * BigDecimal and BigInteger. * * @author Jesse L. Mull * @update Updated Oct 18, 2016 * @address http://www.jessemull.com * @email [email protected] */ public class Well extends WellPrecursor implements Iterable { /*---------------------------- Private Fields ----------------------------*/ private List data = new ArrayList(); /* ---------------------------- Constructors ---------------------------- */ /** * Creates a new Well object from row and column integers. * @param int the well row * @param int the well column */ public Well(int row, int column) { super(WellPrecursor.INTEGER, row, column); } /** * Creates a new Well object using the numerical type flag, row number, * column number and data set. * @param Collection the data set * @param int the well row * @param int the well column */ public Well(int row, int column, Collection data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row number, * column number and data set. * @param Integer[] the data set * @param int the well row * @param int the well column */ public Well(int row, int column, Integer[] data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row string and * column number. * @param String the well row * @param int the well column */ public Well(String row, int column) { super(WellPrecursor.INTEGER, row, column); } /** * Creates a new Well object using the numerical type flag, row string, * column number and data set. * @param String the well row * @param int the well column * @param Collection the data set */ public Well(String row, int column, Collection data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row string, * column number and data set. * @param String the well row * @param int the well column * @param Integer[] the data set */ public Well(String row, int column, Integer[] data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row number and * column string. * @param int the well row * @param String the well column * @throws IllegalArgumentException invalid column value */ public Well(int row, String column) { super(WellPrecursor.INTEGER, row, column); } /** * Creates a new Well object using the numerical type flag, row number and * column string. * @param int the well row * @param String the well column * @param Collection the data set * @throws IllegalArgumentException invalid column value */ public Well(int row, String column, Collection data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row number and * column string. * @param int the well row * @param String the well column * @param Integer[] the data set * @throws IllegalArgumentException invalid column value */ public Well(int row, String column, Integer[] data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row and column * strings. * @param String the well row * @param String the well column * @throws IllegalArgumentException invalid column value */ public Well(String row, String column) { super(WellPrecursor.INTEGER, row, column); } /** * Creates a new Well object using the numerical type flag, row string, * column string and data set. * @param String the well row * @param String the well column * @param Collection the data set * @throws IllegalArgumentException invalid column value */ public Well(String row, String column, Collection data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag, row and column * strings. * @param String the well row * @param String the well column * @param Integer[] the data set * @throws IllegalArgumentException invalid column value */ public Well(String row, String column, Integer[] data) { super(WellPrecursor.INTEGER, row, column); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object from a string holding the column and row values. * The string must be in the format [a-ZA-Z]+[0-9]+ * @param String the well index */ public Well(String wellID) { super(WellPrecursor.INTEGER, wellID); } /** * Creates a new Well object using the numerical type flag and a string * holding the column and row values. The string must be in the format * [a-ZA-Z]+[0-9]+ * @param String the well index * @param Collection the data set */ public Well(String wellID, Collection data) { super(WellPrecursor.INTEGER, wellID); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Creates a new Well object using the numerical type flag and a string * holding the column and row values. The string must be in the format * [a-ZA-Z]+[0-9]+ * @param String the well index * @param Integer[] the data set */ public Well(String wellID, Integer[] data) { super(WellPrecursor.INTEGER, wellID); for(Integer number : data) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Clones a double well without invoking clone. * @param WellPrecursor the well to clone */ public Well(Well well) { super(well); this.data = new ArrayList(well.data()); } /* -------------------- Methods for data set output --------------------- */ /** * Returns the data set. * @return the data set */ public List data() { return this.data; } /** * Returns the well data set as a list of doubles. Overflow results in an * arithmetic exception. * @return the data set */ public List toDouble() { return IntegerUtil.toDoubleList(this.data); } /** * Returns the well data set as an array of doubles. Overflow results in an * arithmetic exception. * @return the data set */ public double[] toDoubleArray() { return IntegerUtil.toDoubleArray(this.data); } /** * Returns the well data set as a list of bytes. Overflow results in an * arithmetic exception. * @return the data set */ public List toByte() { return IntegerUtil.toByteList(this.data); } /** * Returns the well data set as an array of bytes. Overflow results in an * arithmetic exception. * @return the data set */ public byte[] toByteArray() { return IntegerUtil.toByteArray(this.data); } /** * Returns the well data set as a list of shorts. Overflow results in an * arithmetic exception. * @return the data set */ public List toShort() { return IntegerUtil.toShortList(this.data); } /** * Returns the well data set as an array of shorts. Overflow results in an * arithmetic exception. * @return the data set */ public short[] toShortArray() { return IntegerUtil.toShortArray(this.data); } /** * Returns the well data set as an array of shorts. Overflow results in an * arithmetic exception. * @return the data set */ public List toInt() { return this.data; } /** * Returns the well data set as an array of integers. Overflow results in an * arithmetic exception. * @return the data set */ public int[] toIntArray() { return IntegerUtil.toIntegerArray(this.data); } /** * Returns the well data set as a list of longs. Overflow results in an * arithmetic exception. * @return the data set */ public List toLong() { return IntegerUtil.toLongList(this.data); } /** * Returns the well data set as an array of longs. Overflow results in an * arithmetic exception. * @return the data set */ public long[] toLongArray() { return IntegerUtil.toLongArray(this.data); } /** * Returns the well data set as a list of floats. Overflow results in an * arithmetic exception. * @return the data set */ public List toFloat() { return IntegerUtil.toFloatList(this.data); } /** * Returns the well data set as an array of floats. Overflow results in an * arithmetic exception. * @return the data set */ public float[] toFloatArray() { return IntegerUtil.toFloatArray(this.data); } /** * Returns the well data set as a list of big decimals. * @return the data set */ public List toBigDecimal() { return IntegerUtil.toBigDecimalList(this.data); } /** * Returns the well data set as a list of big decimals. * @return the data set */ public BigDecimal[] toBigDecimalArray() { return IntegerUtil.toBigDecimalArray(this.data); } /** * Returns the well data set as a list of big integers. * @return the data set */ public List toBigInteger() { return IntegerUtil.toBigIntList(this.data); } /** * Returns the well data set as an array of big integers. * @return the data set */ public BigInteger[] toBigIntegerArray() { return IntegerUtil.toBigIntArray(this.data); } /* ---------------------- Methods for adding data ----------------------- */ /** * Adds a single data point to a well. * @param Integer the value to add */ public void add(Integer datum) { this.data.add(IntegerUtil.toInteger(datum)); } /** * Adds a collection of numbers to the data set. * @param Collection the data to add */ public void add(Collection collection) { for(Integer number : collection) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Adds an array of numbers to the data set. * @param Integer[] the data to add */ public void add(Integer[] array) { for(Integer number : array) { this.data.add(IntegerUtil.toInteger(number)); } } /** * Adds the data from another well. * @param WellPrecursor the well with data set to add */ public void add(Well well) { for(Integer db : well) { this.data.add(db); } } /** * Adds the data from each well in the well set. * @param WellSet the well set to add */ public void add(WellSet set) { for(WellPrecursor well : set) { for(Object obj : well.data()) { this.add(IntegerUtil.toInteger(obj)); } } } /* --------------------- Methods for replacing data --------------------- */ /** * Clears the data set and adds the number. * @param Integer replacement datum */ public void replaceData(Integer datum) { this.data.clear(); this.data.add(IntegerUtil.toInteger(datum)); } /** * Clears the data set and adds the collection. * @param Collection replacement data */ public void replaceData(Collection collection) { this.data.clear(); this.add(collection); } /** * Clears the data set and adds the array. * @param Integer[] replacement data */ public void replaceData(Integer[] array) { this.data.clear(); this.add(array); } /** * Clears the data set and adds the well data set. * @param WellPrecursor well with replacement data */ public void replaceData(Well well) { this.data.clear(); this.add(well); } /** * Clears the data set and adds the data from each well in the set. * @param WellSet set of wells with replacement data */ public void replaceData(WellSet set) { this.data.clear(); this.add(set); } /* --------------------- Methods for removing data ---------------------- */ /** * Removes the value from the data set. * @param Integer datum for removal */ public void remove(Integer number) { List list = new ArrayList(); list.add(number); this.data.removeAll(list); } /** * Removes all the values in the collection from the data set. * @param Collection data for removal */ public void remove(Collection collection) { List list = new ArrayList(collection); this.data.removeAll(list); } /** * Removes all the values in the array from the data set. * @param Integer[] data for removal */ public void remove(Integer[] array) { this.data.removeAll(Arrays.asList(array)); } /** * Removes all the well values from the data set. * @param WellPrecursor well with data for removal */ public void removeWell(Well well) { this.data.removeAll(well.data()); } /** * Removes the well values for each well from the data set. * @param WellSet wells with replacement data */ public void removeSet(WellSet set) { for(WellPrecursor well : set) { this.data.removeAll(well.data()); } } /** * Removes all values within the indices. * @param int beginning index * @param int number of values to remove */ public void removeRange(int begin, int end) { if(begin > end) { throw new IndexOutOfBoundsException("The starting index must be less than the ending index."); } if(begin < 0) { throw new IllegalArgumentException("Indices must be positive values."); } if(end > this.data().size()) { throw new IndexOutOfBoundsException("Ending index does not exist."); } List removed = new ArrayList(this.data().subList(0, begin)); removed.addAll(this.data().subList(end, this.size())); this.data = removed; } /* -------------------- Methods for retaining data ---------------------- */ /** * Retains the values in the data set. * @param Integer datum for retention */ public void retain(Integer number) { if(this.data.contains(number)) { this.data.clear(); this.data.add(IntegerUtil.toInteger(number)); } else { throw new IllegalArgumentException(number + " does not exist in the well data set."); } } /** * Retains all the values in the collection. * @param Collection data for retention */ public void retain(Collection collection) { this.data.retainAll(collection); } /** * Retains all the values in the array. * @param Integer[] data for retention */ public void retain(Integer[] array) { this.data.retainAll(Arrays.asList(array)); } /** * Retains all the values in the well. * @param WellPrecursor well with data for retention */ public void retainWell(Well well) { this.data.retainAll(well.data()); } /** * Retains all the values in each well. * @param WellSet wells with retention data */ public void retainSet(WellSet set) { for(WellPrecursor well : set) { this.data.retainAll(well.data()); } } /** * Retains all values within the indices. * @param int beginning index * @param int number of values to remove */ public void retainRange(int begin, int end) { if(begin > end) { throw new IndexOutOfBoundsException("The starting index must be less than the ending index."); } if(begin < 0) { throw new IllegalArgumentException("Indices must be positive values."); } if(end > this.data().size()) { throw new IndexOutOfBoundsException("Ending index does not exist."); } this.data = this.data.subList(begin, end); } /* ------------------- Methods for plate parameters --------------------- */ /** * Returns the size of the well data set. * @return the number of values in the data set */ public int size() { return this.data.size(); } /** * Clears the well data. */ public void clear() { this.data.clear(); } /** * Returns true if the well data set is empty and false otherwise. * @return true if the data set is empty */ public boolean isEmpty() { return this.data.isEmpty(); } /** * Returns a new well containing the values within the indices. * @param int beginning index * @param int number of values to remove * @return the new well */ public Well subList(int begin, int length) { Well well = new Well(this.row(), this.column()); well.add(this.data().subList(begin, begin + length)); return well; } /** * Returns true if the well data set contains the value. * @param Integer the input value * @return true if the data set contains the value */ public boolean contains(Integer number) { return this.data.contains(IntegerUtil.toInteger(number)); } /** * Returns the index of the first occurrence of the specified element in * this list, or -1 if this list does not contain the element. * @param Integer the input value * @return the index */ public int indexOf(Integer number) { return this.data.indexOf(number); } /** * Returns the value at the specified index. * @param int the index * @return the value at the index */ public Integer get(int index) { return this.data.get(index); } /** * Returns the index of the last occurrence of the specified element in this * list, or -1 if this list does not contain the element. * @param int the index * @return the index of the last occurrence */ public double lastIndexOf(Integer number) { return this.data.lastIndexOf(number); } /** * Returns an iterator for the well data set. * @return the iterator */ public Iterator iterator() { return this.data.iterator(); } /** * Wells are equivalent if the row, column and ALPHA_BASE * fields are equivalent. * @param Object the object * @return true if equal, false otherwise */ public boolean equals(Object object) { if (object instanceof Well == false) { return false; } if (this == object) { return true; } Well well = (Well) object; return this.row() == well.row() && this.column() == well.column() && this.alphaBase() == well.alphaBase(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy