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

org.snpeff.geneSets.algorithm.RankSumPValueGreedyAlgorithm Maven / Gradle / Ivy

The newest version!
package org.snpeff.geneSets.algorithm;

import org.apfloat.Apfloat;
import org.snpeff.geneSets.GeneSet;
import org.snpeff.geneSets.GeneSetsRanked;
import org.snpeff.geneSets.Result;
import org.snpeff.probablility.RankSumNoReplacementPdf;

public class RankSumPValueGreedyAlgorithm extends EnrichmentAlgorithmGreedyVariableSize {

	public RankSumPValueGreedyAlgorithm(GeneSetsRanked geneSets, int numberToSelect) {
		super(geneSets, numberToSelect);
	}

	/**
	 * Create a new gene set using all gene sets and calculate pValue
	 * @param geneSetList
	 * @return
	 */
	@Override
	Apfloat pValue(GeneSet geneSet) {
		long rankSum = geneSet.rankSum(); // Make sure rankSum is calculated
		Apfloat pValue = RankSumNoReplacementPdf.get().cdf(((GeneSetsRanked) geneSets).getMaxRank(), geneSet.getRankedGenesCount(), rankSum);
		return pValue;
	}

	/**
	 * Stop criteria
	 * @param result
	 * @return
	 */
	@Override
	protected boolean stopCriteria(Result result) {
		boolean stop = super.stopCriteria(result);
		if (stop) return true;

		// No rank sum? => stop
		GeneSet geneSet = result.getLatestGeneSet();
		if (geneSet.rankSum() <= 0) return true;

		return false;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy