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; 022 023 024import java.text.DecimalFormat; 025 026/** 027 * 028 * @author Scooter Willis 029 */ 030public class CoxCoefficient { 031 032 String name; 033 double coeff; //beta 034 double stdError; //se 035 double robustStdError; //nse 036 double z; 037 double hazardRatio; //exp(beta) 038 double hazardRatioLoCI; 039 double hazardRatioHiCI; 040 double pvalue; 041 double mean; 042 double standardDeviation; 043 044 /** 045 * 046 */ 047 public CoxCoefficient() { 048 } 049 050 @Override 051 public String toString() { 052 return name + " " + coeff + " " + pvalue + " " + hazardRatio + " " + hazardRatioLoCI + " " + hazardRatioHiCI; 053 } 054 055 /** 056 * 057 * @return 058 */ 059 public String getHRText() { 060 return fmt(hazardRatio, 2, 0) + " CI(" + fmt(hazardRatioLoCI, 2, 0) + "-" + fmt(hazardRatioHiCI, 2, 0) + ")"; 061 } 062 063 /** 064 * @return the name 065 */ 066 public String getName() { 067 return name; 068 } 069 070 /** 071 * @return the coeff 072 */ 073 public double getCoeff() { 074 return coeff; 075 } 076 077 /** 078 * @return the stdError 079 */ 080 public double getStdError() { 081 return stdError; 082 } 083 084 /** 085 * @return the robustStdError 086 */ 087 public double getRobustStdError() { 088 return robustStdError; 089 } 090 091 /** 092 * @return the z 093 */ 094 public double getZ() { 095 return z; 096 } 097 098 /** 099 * @return the hazardRatio 100 */ 101 public double getHazardRatio() { 102 return hazardRatio; 103 } 104 105 /** 106 * @return the hazardRatioLoCI 107 */ 108 public double getHazardRatioLoCI() { 109 return hazardRatioLoCI; 110 } 111 112 /** 113 * @return the hazardRatioHiCI 114 */ 115 public double getHazardRatioHiCI() { 116 return hazardRatioHiCI; 117 } 118 119 /** 120 * @return the pvalue 121 */ 122 public double getPvalue() { 123 return pvalue; 124 } 125 126 /** 127 * @return the mean 128 */ 129 public double getMean() { 130 return mean; 131 } 132 133 /** 134 * @return the standardDeviation 135 */ 136 public double getStandardDeviation() { 137 return standardDeviation; 138 } 139 140 /** 141 * @param name the name to set 142 */ 143 public void setName(String name) { 144 this.name = name; 145 } 146 147 /** 148 * @param coeff the coeff to set 149 */ 150 public void setCoeff(double coeff) { 151 this.coeff = coeff; 152 } 153 154 /** 155 * @param stdError the stdError to set 156 */ 157 public void setStdError(double stdError) { 158 this.stdError = stdError; 159 } 160 161 /** 162 * @param robustStdError the robustStdError to set 163 */ 164 public void setRobustStdError(double robustStdError) { 165 this.robustStdError = robustStdError; 166 } 167 168 /** 169 * @param z the z to set 170 */ 171 public void setZ(double z) { 172 this.z = z; 173 } 174 175 /** 176 * @param hazardRatio the hazardRatio to set 177 */ 178 public void setHazardRatio(double hazardRatio) { 179 this.hazardRatio = hazardRatio; 180 } 181 182 /** 183 * @param hazardRatioLoCI the hazardRatioLoCI to set 184 */ 185 public void setHazardRatioLoCI(double hazardRatioLoCI) { 186 this.hazardRatioLoCI = hazardRatioLoCI; 187 } 188 189 /** 190 * @param hazardRatioHiCI the hazardRatioHiCI to set 191 */ 192 public void setHazardRatioHiCI(double hazardRatioHiCI) { 193 this.hazardRatioHiCI = hazardRatioHiCI; 194 } 195 196 /** 197 * @param pvalue the pvalue to set 198 */ 199 public void setPvalue(double pvalue) { 200 this.pvalue = pvalue; 201 } 202 203 /** 204 * @param mean the mean to set 205 */ 206 public void setMean(double mean) { 207 this.mean = mean; 208 } 209 210 /** 211 * @param standardDeviation the standardDeviation to set 212 */ 213 public void setStandardDeviation(double standardDeviation) { 214 this.standardDeviation = standardDeviation; 215 } 216 217 /** 218 * 219 * @param d 220 * @param precision 221 * @param pad 222 * @return 223 */ 224 public static String fmt(Double d, int precision, int pad) { 225 String value = ""; 226 DecimalFormat dfe = new DecimalFormat("0.00E0"); 227 String dpad = "0."; 228 double p = 1.0; 229 for (int i = 0; i < (precision); i++) { 230 dpad = dpad + "0"; 231 p = p / 10.0; 232 } 233 DecimalFormat df = new DecimalFormat(dpad); 234 if (Math.abs(d) >= p) { 235 value = df.format(d); 236 } else { 237 value = dfe.format(d); 238 } 239 int length = value.length(); 240 int extra = pad - length; 241 if (extra > 0) { 242 for (int i = 0; i < extra; i++) { 243 value = " " + value; 244 } 245 } 246 return value; 247 } 248}