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

net.maizegenetics.taxa.TaxaListBuilder Maven / Gradle / Ivy

package net.maizegenetics.taxa;

import cern.colt.GenericSorting;
import cern.colt.Swapper;
import cern.colt.function.IntComparator;
import ch.systemsx.cisd.hdf5.IHDF5Reader;
import ch.systemsx.cisd.hdf5.IHDF5Writer;
import net.maizegenetics.dna.snp.GenotypeTable;
import net.maizegenetics.dna.snp.genotypecall.GenotypeCallTableBuilder;
import net.maizegenetics.util.HDF5Utils;

import java.util.*;

/**
 * A builder for creating immutable {@link TaxaList} instances.
 * Example:
   {@code
 *   TaxaListBuilder tlb=new TaxaListBuilder();
 *   for (int i = 0; i < 10; i++) {
 *      Taxon at= new Taxon.Builder("Z"+i+":Line:mays:Zea")
 *           .inbreedF(0.99f)
 *           .parents("B73","B97")
 *           .pedigree("(B73xB97)S6I1")
 *           .build();
 *       tlb.add(at);
 *       }
 *   TaxaList tl=tlb.build();}
*

* If building from HDF5:
 *   {@code
 *   TaxaList tl=new TaxaListBuilder().buildFromHDF5Genotypes(testMutFile);
 *   }
* * @author Ed Buckler */ public class TaxaListBuilder { //TODO need to move union and intersection utils to the builder private List myTaxaList; private final HashMap tempLookup; private boolean buildNoIndex = false; public TaxaListBuilder() { myTaxaList = new ArrayList<>(); tempLookup = new HashMap<>(); } public static TaxaList getInstance(int numTaxa) { TaxaListBuilder builder = new TaxaListBuilder(); for (int i = 0; i < numTaxa; i++) { builder.add(new Taxon("Taxa_" + i)); } return builder.build(); } public TaxaListBuilder add(Taxon taxon) { if (tempLookup.containsKey(taxon)) { throw new IllegalStateException("Taxon [" + taxon.getName() + "] already exists in the list. Duplicated taxa not allowed."); } myTaxaList.add(taxon); tempLookup.put(taxon, myTaxaList.size() - 1); return this; } public TaxaListBuilder add(String taxon) { Taxon obj = new Taxon(taxon); return add(obj); } public boolean contains(Taxon taxon) { return tempLookup.containsKey(taxon); } public TaxaListBuilder addOrMerge(Taxon taxon) { if (tempLookup.containsKey(taxon)) { int indexOfOrig = tempLookup.get(taxon); Taxon orgTaxon = myTaxaList.get(indexOfOrig); Taxon.Builder tb = new Taxon.Builder(orgTaxon); for (Map.Entry entry : taxon.getAnnotation().getAllAnnotationEntries()) { if (!orgTaxon.getAnnotation().isAnnotatedWithValue(entry.getKey(), entry.getValue())) tb.addAnno(entry.getKey(), entry.getValue()); } taxon = tb.build(); myTaxaList.set(indexOfOrig, taxon); tempLookup.put(taxon, indexOfOrig); } else { myTaxaList.add(taxon); tempLookup.put(taxon, myTaxaList.size() - 1); } return this; } public TaxaListBuilder addAll(Collection taxa) { for (Taxon taxon : taxa) { add(taxon); } return this; } public TaxaListBuilder addAll(GenotypeTable a) { for (Taxon taxon : a.taxa()) { add(taxon); } return this; } public TaxaListBuilder addAll(String[] taxa) { for (int i = 0, n = taxa.length; i < n; i++) { add(taxa[i]); } return this; } public TaxaListBuilder addAll(List taxa) { for (int i = 0, n = taxa.size(); i < n; i++) { add(new Taxon.Builder(taxa.get(i)).build()); } return this; } public TaxaListBuilder addAll(Taxon[] taxa) { for (Taxon taxon : taxa) { add(taxon); } return this; } public TaxaListBuilder addAll(TaxaListBuilder builder) { for (Taxon current : builder.myTaxaList) { add(current); } return this; } public TaxaListBuilder noIndex() { buildNoIndex = true; return this; } public TaxaList build() { if (buildNoIndex) { return new TaxaNoIndexList(getImmutableList()); } else { return new TaxaArrayList(getImmutableList()); } } /** * Builds TaxaList with annotations from an HDF5 file. The list of Taxa come from the those taxa that have been genotyped * (in /Genotypes/ path), while the annotations come from the /Taxa/ path. Frequently these two lists are * identical, but sometimes this can Genotypes can have a subset of the taxa in /Taxa/ * * @param reader * * @return */ public TaxaList buildFromHDF5Genotypes(IHDF5Reader reader) { if (!HDF5Utils.isTaxaLocked(reader)) { throw new IllegalStateException("The Taxa module of this HDF5 file hasn't been locked, and therefore can't be opened for reading. This could occur if the file was created using the -ko (keep open) option when running the plugin ProductionSNPCallerPluginV2. Please check your file, close if appropriate, and try again."); } myTaxaList.clear(); for (String taxonName : HDF5Utils.getAllTaxaNames(reader)) { if (!HDF5Utils.doTaxonCallsExist(reader, taxonName)) continue; //if no calls exist skip it myTaxaList.add(HDF5Utils.getTaxon(reader, taxonName)); } return build(); } /** * Builds TaxaList with annotations from an HDF5 file. The list of Taxa and annotations come from the /Taxa/ path. * This maybe a super set of what is present in the /Genotypes/ or /TBT/ paths. * * @param reader * * @return */ public TaxaList buildFromHDF5(IHDF5Reader reader) { myTaxaList.clear(); for (String taxonName : HDF5Utils.getAllTaxaNames(reader)) { myTaxaList.add(HDF5Utils.getTaxon(reader, taxonName)); } return build(); } public static void createHDF5TaxaList(IHDF5Writer writer, TaxaList exportList) { HDF5Utils.createHDF5TaxaModule(writer); for (Taxon taxon : exportList) { HDF5Utils.addTaxon(writer, taxon); } } //Default package private method to hand the list to the instance List getImmutableList() { return Collections.unmodifiableList(myTaxaList); } public TaxaListBuilder sortTaxaAlphabetically(GenotypeCallTableBuilder genotypes) { int numTaxa = myTaxaList.size(); if (numTaxa != genotypes.getTaxaCount()) { throw new IllegalArgumentException("TaxaListBuilder: sortTaxaAlphabetically: taxa list size: " + numTaxa + " doesn't match genotypes num taxa: " + genotypes.getTaxaCount()); } genotypes.reorderTaxa(sortAlphabetically()); return this; } public TaxaListBuilder sortTaxaAlphabetically() { sortAlphabetically(); return this; } public int[] sortAlphabetically() { int numTaxa = myTaxaList.size(); final int indicesOfSortByTaxa[] = new int[numTaxa]; for (int i = 0; i < indicesOfSortByTaxa.length; i++) { indicesOfSortByTaxa[i] = i; } Swapper swapTaxa = new Swapper() { @Override public void swap(int a, int b) { int temp = indicesOfSortByTaxa[a]; indicesOfSortByTaxa[a] = indicesOfSortByTaxa[b]; indicesOfSortByTaxa[b] = temp; } }; IntComparator compTaxa = new IntComparator() { @Override public int compare(int a, int b) { return myTaxaList.get(indicesOfSortByTaxa[a]).compareTo(myTaxaList.get(indicesOfSortByTaxa[b])); } }; GenericSorting.quickSort(0, indicesOfSortByTaxa.length, compTaxa, swapTaxa); List temp = new ArrayList<>(numTaxa); for (int t = 0; t < numTaxa; t++) { temp.add(myTaxaList.get(indicesOfSortByTaxa[t])); } myTaxaList = temp; return indicesOfSortByTaxa; } public int numberOfTaxa() { return myTaxaList.size(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy