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.kaplanmeier.figure; 022 023/** 024 * 025 * @author willishf@gmail.com 026 */ 027public class CensorStatus implements Comparable<CensorStatus> { 028 029 /** 030 * 031 */ 032 public String row; 033 /** 034 * 035 */ 036 public Double time; 037 /** 038 * 039 */ 040 public String censored; 041 /** 042 * 043 */ 044 public String group; 045 /** 046 * 047 */ 048 public Double value; 049 /** 050 * 051 */ 052 public Double zscore; 053 /** 054 * 055 */ 056 public Double weight = 1.0; // assume default weight 1.0 057 058 059 private Double percentage = null; //allow the percentage to be set externally for various weighted correction methods. 060 /** 061 * 062 */ 063 public Double nevents; 064 /** 065 * 066 */ 067 public Double ncens; 068 /** 069 * 070 */ 071 public Double nrisk; 072 073 /** 074 * 075 */ 076 public CensorStatus() { 077 } 078 079 /** 080 * 081 * @param group 082 * @param time 083 * @param censored 084 */ 085 public CensorStatus(String group, Double time, String censored) { 086 this.group = group; 087 this.time = time; 088 this.censored = censored; 089 } 090 091 /** 092 * 093 * @return 094 */ 095 public CensorStatus getCopy(){ 096 CensorStatus cs = new CensorStatus(); 097 cs.row = row; 098 cs.time = time; 099 cs.censored = censored; 100 cs.group = group; 101 cs.value = value; 102 cs.zscore = zscore; 103 return cs; 104 } 105 106 @Override 107 public String toString() { 108 return time + " " + censored + " " + group + " " + row; 109 } 110 111 @Override 112 public int compareTo(CensorStatus o) { 113 // System.out.println("Comparing " + this + " " + o); 114 if (time == null) { 115 return -1; 116 } 117 if (o.time == null) { 118 return 1; 119 } 120 121 if (time < o.time) { 122 return -1; 123 } else if (time > o.time) { 124 return 1; 125 } else { 126 if (censored.equals(o.censored)) { 127 return 0; 128 } 129 if ("0".equals(censored)) { 130 return -1; 131 } else { 132 return 1; 133 } 134 } 135 } 136 137 /** 138 * @return the percentage 139 */ 140 public Double getPercentage() { 141 return percentage; 142 } 143 144 /** 145 * @param percentage the percentage to set 146 */ 147 public void setPercentage(Double percentage) { 148 this.percentage = percentage; 149 } 150}