001/*
002 *                    BioJava development code
003 *
004 * This code may be freely distributed and modified under the
005 * terms of the GNU Lesser General Public Licence.  This should
006 * be distributed with the code.  If you do not have a copy,
007 * see:
008 *
009 *      http://www.gnu.org/copyleft/lesser.html
010 *
011 * Copyright for this code is held jointly by the individual
012 * authors.  These should be listed in @author doc comments.
013 *
014 * For more information on the BioJava project and its aims,
015 * or to join the biojava-l mailing list, visit the home page
016 * at:
017 *
018 *      http://www.biojava.org/
019 *
020 */
021package org.biojava.nbio.survival.cox.comparators;
022
023import org.biojava.nbio.survival.cox.CoxInfo;
024import org.biojava.nbio.survival.cox.CoxVariables;
025
026import java.util.Comparator;
027
028/**
029 *
030 * @author Scooter Willis <willishf at gmail dot com>
031 */
032public class CoxVariablesOverallModelFitComparator implements Comparator<CoxVariables> {
033
034        String variables = "";
035
036        /**
037         * Variables are stored as a string representation of an ArrayList
038         * [META_GENE] or [trtg, META_GENE] add variables used in cox regression to an array and then do toString.
039         * @param variables
040         */
041        public CoxVariablesOverallModelFitComparator(String variables) {
042                this.variables = variables;
043        }
044
045        @Override
046        public int compare(CoxVariables coxVariables1, CoxVariables coxVariables2) {
047                CoxInfo ci1 = coxVariables1.getCoxInfo(variables);
048                CoxInfo ci2 = coxVariables2.getCoxInfo(variables);
049
050                if (ci1.getWaldTestInfo().getPvalue() < ci2.getWaldTestInfo().getPvalue()) {
051                        return -1;
052                } else if (ci1.getWaldTestInfo().getPvalue() > ci2.getWaldTestInfo().getPvalue()) {
053                        return 1;
054                } else {
055                        return 0;
056                }
057                //ascending order
058                // return coxVariables1.compareTo(coxVariables2);
059        }
060}