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

net.maizegenetics.analysis.tree.SubsetTreePlugin.kt Maven / Gradle / Ivy

Go to download

TASSEL is a software package to evaluate traits associations, evolutionary patterns, and linkage disequilibrium.

There is a newer version: 5.2.94
Show newest version
package net.maizegenetics.analysis.tree

import net.maizegenetics.analysis.filter.FilterTaxaBuilderPlugin
import net.maizegenetics.plugindef.AbstractPlugin
import net.maizegenetics.plugindef.DataSet
import net.maizegenetics.plugindef.Datum
import net.maizegenetics.plugindef.PluginParameter
import net.maizegenetics.taxa.TaxaList
import net.maizegenetics.taxa.tree.Tree
import net.maizegenetics.taxa.tree.subsetTree
import org.apache.log4j.Logger
import java.awt.Frame
import javax.swing.ImageIcon

private val myLogger = Logger.getLogger(SubsetTreePlugin::class.java)

class SubsetTreePlugin(parentFrame: Frame? = null, isInteractive: Boolean = false) : AbstractPlugin(parentFrame, isInteractive) {

    private var nameList = PluginParameter.Builder("nameList", null, TaxaList::class.java)
            .description("List of names to include. This can be a comma separated list of names (no spaces unless surrounded by quotes), file (.txt) with list of names to include, or a taxa list file (.json or .json.gz).")
            .required(true)
            .build()

    override fun preProcessParameters(input: DataSet?) {
        val temp = input?.getDataOfType(Tree::class.java)
        val numTrees = temp?.size ?: 0
        if (numTrees != 1) {
            throw IllegalArgumentException("SubsetTreePlugin: processData: must input 1 tree")
        }
    }

    override fun processData(input: DataSet?): DataSet? {
        val tree = input!!.getDataOfType(Tree::class.java).get(0).data as Tree
        return DataSet(Datum("Subset Tree", subsetTree(tree, nameList()), null), this)
    }

    /**
     * List of names to include. This can be a comma separated
     * list of names (no spaces unless surrounded by quotes),
     * file (.txt) with list of names to include, or a taxa
     * list file (.json or .json.gz).
     *
     * @return Name List
     */
    fun nameList(): TaxaList {
        return nameList.value()
    }

    /**
     * Set Name List. List of names to include. This can be
     * a comma separated list of names (no spaces unless surrounded
     * by quotes), file (.txt) with list of names to include,
     * or a taxa list file (.json or .json.gz).
     *
     * @param value Name List
     *
     * @return this plugin
     */
    fun nameList(value: TaxaList): SubsetTreePlugin {
        nameList = PluginParameter(nameList, value)
        return this
    }

    override fun getToolTipText(): String {
        return "Subset Tree"
    }

    override fun getButtonName(): String {
        return "Subset Tree"
    }

    override fun getIcon(): ImageIcon? {
        val imageURL = FilterTaxaBuilderPlugin::class.java.getResource("/net/maizegenetics/analysis/images/FilterNew.gif")
        return imageURL?.let { ImageIcon(it) }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy