001/* This class is based on the original FATCAT implementation by 002 * <pre> 003 * Yuzhen Ye & Adam Godzik (2003) 004 * Flexible structure alignment by chaining aligned fragment pairs allowing twists. 005 * Bioinformatics vol.19 suppl. 2. ii246-ii255. 006 * https://www.ncbi.nlm.nih.gov/pubmed/14534198 007 * </pre> 008 * 009 * Thanks to Yuzhen Ye and A. Godzik for granting permission to freely use and redistribute this code. 010 * 011 * This code may be freely distributed and modified under the 012 * terms of the GNU Lesser General Public Licence. This should 013 * be distributed with the code. If you do not have a copy, 014 * see: 015 * 016 * http://www.gnu.org/copyleft/lesser.html 017 * 018 * Copyright for this code is held jointly by the individual 019 * authors. These should be listed in @author doc comments. 020 * 021 * 022 * Created on Jun 17, 2009 023 * Created by Andreas Prlic - RCSB PDB 024 * 025 */ 026 027package org.biojava.nbio.structure.align.fatcat.calc; 028 029import org.biojava.nbio.structure.align.ce.ConfigStrucAligParams; 030 031import java.io.StringWriter; 032import java.lang.reflect.Method; 033import java.util.ArrayList; 034import java.util.List; 035 036 037public class FatCatParameters implements ConfigStrucAligParams 038{ 039 040 public static final int DEFAULT_FRAGLEN = 8; 041 042 int fragLen ; // the length of the fragments to consider... 043 int fragLenSq ; 044 Double rmsdCut; // cutoff for AFP detection. 045 double disCut; // for AFPs connection, to be tuned, 4.0 046 double afpDisCut; 047 double afpDisCut0; 048 double disSmooth; // for smooth calculation of twist penalty calculation 049 int misCut; 050 int maxGap; 051 int maxGapFrag; 052 double disFilter; 053 double badRmsd; 054 int maxTra; // the maximum number of Twists that are allowed... 055 double gapCreate; 056 double gapExtend; 057 double misScore; 058 double torsionPenalty; 059 double maxPenalty; 060 double resScore; 061 double fragScore; 062 int sparse; 063 boolean optimizeAlignment; //whether to do post-processing to improve the alignment 064 public FatCatParameters(){ 065 reset(); 066 } 067 068 069 @Override 070 public void reset(){ 071 // Note: Update FatCatUserArgumentProcessor.FatCatStartupParams after 072 // modifying user-exposed values 073 fragLen = DEFAULT_FRAGLEN; 074 fragLenSq = fragLen * fragLen; 075 rmsdCut = 3.0; //cutoff for AFP detection 076 disCut = 5.0; //for AFPs connection, to be tuned, 4.0 077 afpDisCut = fragLenSq * disCut * disCut; 078 afpDisCut0 = fragLenSq * disCut; 079 disSmooth = 4.0; //for smoothly calculation of twist penalty calculation 080 misCut = 2 * fragLen; //structural-dismilar ranges allowed between AFPs 081 maxGap = 40; //try-1 30 082 maxGapFrag = fragLen + maxGap; 083 disFilter = 2.0 * rmsdCut; //for single AFP denifition to be tuned! //two CA-dis is 3.6 084 badRmsd = 4.0; //very important paramerter for twists detection 085 maxTra = 5; 086 gapCreate = -5.0; 087 gapExtend = -0.5; 088 misScore = gapExtend; //comparable to gapExtend 089 torsionPenalty = 5 * gapCreate; //to be tuned 090 maxPenalty = 1 * gapCreate; //to be tuned 091 resScore = 3.0; //on average, the score for each well-matched residue pair 092 fragScore = resScore * fragLen; //the score for each well-matched fragment 093 sparse = 0; 094 optimizeAlignment = true; //No effect at the moment 095 } 096 097 098 public Integer getFragLen() 099 { 100 return fragLen; 101 } 102 103 104 public void setFragLen(Integer fragLen) 105 { 106 this.fragLen = fragLen; 107 } 108 109 110 public int getFragLenSq() 111 { 112 return fragLenSq; 113 } 114 115 116 public void setFragLenSq(int fragLenSq) 117 { 118 this.fragLenSq = fragLenSq; 119 } 120 121 122 /** The cutoff to be used during AFP detection 123 * 124 * @return rmsdCut parameter 125 */ 126 public Double getRmsdCut() 127 { 128 return rmsdCut; 129 } 130 131 /** The cutoff to be used during AFP detection 132 * 133 * @param rmsdCut 134 */ 135 public void setRmsdCut(Double rmsdCut) 136 { 137 this.rmsdCut = rmsdCut; 138 } 139 140 /** Get the distance cutoff used during AFP chain connectivity checks 141 * 142 * @return distance Cutoff 143 */ 144 public Double getDisCut() 145 { 146 return disCut; 147 } 148 149 150 public void setDisCut(Double disCut) 151 { 152 this.disCut = disCut; 153 } 154 155 156 public double getAfpDisCut() 157 { 158 return afpDisCut; 159 } 160 161 162 public void setAfpDisCut(double afpDisCut) 163 { 164 this.afpDisCut = afpDisCut; 165 } 166 167 168 public double getAfpDisCut0() 169 { 170 return afpDisCut0; 171 } 172 173 174 public void setAfpDisCut0(double afpDisCut0) 175 { 176 this.afpDisCut0 = afpDisCut0; 177 } 178 179 180 public double getDisSmooth() 181 { 182 return disSmooth; 183 } 184 185 186 public void setDisSmooth(double disSmooth) 187 { 188 this.disSmooth = disSmooth; 189 } 190 191 192 public int getMisCut() 193 { 194 return misCut; 195 } 196 197 198 public void setMisCut(int misCut) 199 { 200 this.misCut = misCut; 201 } 202 203 204 public int getMaxGap() 205 { 206 return maxGap; 207 } 208 209 210 public void setMaxGap(int maxGap) 211 { 212 this.maxGap = maxGap; 213 } 214 215 216 public int getMaxGapFrag() 217 { 218 return maxGapFrag; 219 } 220 221 222 public void setMaxGapFrag(int maxGapFrag) 223 { 224 this.maxGapFrag = maxGapFrag; 225 } 226 227 228 public double getDisFilter() 229 { 230 return disFilter; 231 } 232 233 234 public void setDisFilter(double disFilter) 235 { 236 this.disFilter = disFilter; 237 } 238 239 240 public double getBadRmsd() 241 { 242 return badRmsd; 243 } 244 245 246 public void setBadRmsd(double badRmsd) 247 { 248 this.badRmsd = badRmsd; 249 } 250 251 252 /** get the maximum number of Twists that are allowed... 253 * 254 * @return max nr of allowed twists 255 */ 256 public Integer getMaxTra() 257 { 258 return maxTra; 259 } 260 261 /** set the maximum number of Twists that are allowed... 262 * 263 * @param maxTra 264 */ 265 public void setMaxTra(Integer maxTra) 266 { 267 this.maxTra = maxTra; 268 } 269 270 271 public double getGapCreate() 272 { 273 return gapCreate; 274 } 275 276 277 public void setGapCreate(double gapCreate) 278 { 279 this.gapCreate = gapCreate; 280 } 281 282 283 public double getGapExtend() 284 { 285 return gapExtend; 286 } 287 288 289 public void setGapExtend(double gapExtend) 290 { 291 this.gapExtend = gapExtend; 292 } 293 294 295 public double getMisScore() 296 { 297 return misScore; 298 } 299 300 301 public void setMisScore(double misScore) 302 { 303 this.misScore = misScore; 304 } 305 306 307 public double getTorsionPenalty() 308 { 309 return torsionPenalty; 310 } 311 312 313 public void setTorsionPenalty(double torsionPenalty) 314 { 315 this.torsionPenalty = torsionPenalty; 316 } 317 318 319 public double getMaxPenalty() 320 { 321 return maxPenalty; 322 } 323 324 325 public void setMaxPenalty(double maxPenalty) 326 { 327 this.maxPenalty = maxPenalty; 328 } 329 330 331 public double getResScore() 332 { 333 return resScore; 334 } 335 336 337 public void setResScore(double resScore) 338 { 339 this.resScore = resScore; 340 } 341 342 343 public double getFragScore() 344 { 345 return fragScore; 346 } 347 348 349 public void setFragScore(double fragScore) 350 { 351 this.fragScore = fragScore; 352 } 353 354 355 public int getSparse() 356 { 357 return sparse; 358 } 359 360 361 public void setSparse(int sparse) 362 { 363 this.sparse = sparse; 364 } 365 366 367 @Override 368 public List<String> getUserConfigHelp() { 369 List<String> params = new ArrayList<>(); 370 String fragLen = "The length of the fragments."; 371 String rmsdCutHelp = "The RMSD cutoff to be used during AFP detection."; 372 String disCutHelp = "The distance cutoff used when calculate the connectivity of AFP pairs"; 373 String twistHelp ="The number of twists that are allowed to be introduced. If set to 0 alignments are run in RIGID mode."; 374 params.add(fragLen); 375 params.add(rmsdCutHelp); 376 params.add(disCutHelp); 377 params.add(twistHelp); 378 return params; 379 380 } 381 382 383 @Override 384 public List<String> getUserConfigParameterNames() { 385 List<String> params = new ArrayList<>(); 386 params.add("Fragment Length"); 387 params.add("RMSD Cutoff"); 388 params.add("AFP Distance Cutoff"); 389 params.add("Maximum Nr. of twists"); 390 return params; 391 } 392 393 394 @Override 395 public List<String> getUserConfigParameters() { 396 List<String> params = new ArrayList<>(); 397 params.add("FragLen"); 398 params.add("RmsdCut"); 399 params.add("DisCut"); 400 params.add("MaxTra"); 401 return params; 402 } 403 404 405 @Override 406 @SuppressWarnings({ "rawtypes" }) 407 public List<Class> getUserConfigTypes() { 408 409 List<Class> params = new ArrayList<>(); 410 params.add(Integer.class); 411 params.add(Double.class); 412 params.add(Double.class); 413 params.add(Integer.class); 414 return params; 415 } 416 417 418 @Override 419 public String toString(){ 420 StringWriter writer = new StringWriter(); 421 writer.append("["); 422 if ( maxTra == 0) 423 writer.append("Mode: rigid, "); 424 else 425 writer.append("Mode: flexible, "); 426 List<String> params = getUserConfigParameters(); 427 428 for ( String s : params){ 429 writer.append(s); 430 writer.append(": "); 431 Object val = getValue(s); 432 writer.append(val.toString()); 433 writer.append(", "); 434 } 435 writer.append("]"); 436 return writer.toString(); 437 } 438 439 private Object getValue(String name){ 440 441 try { 442 String methodName = "get" + name; 443 444 Class<?> paramC = this.getClass(); 445 446 Method m =paramC.getMethod(methodName,(Class[])null); 447 448 Object value = m.invoke(this); 449 450 return value; 451 } catch (Exception e){ 452 e.printStackTrace(); 453 return null; 454 } 455 456 457 } 458 459 /** 460 * Whether the alignment algorithm should try its best to optimize the alignment, 461 * or we are happy with a quick and dirty result. 462 * NB: Not implemented in jFatCat 463 * 464 * @return optimizeAlignment 465 */ 466 public boolean isOptimizeAlignment() { 467 return optimizeAlignment; 468 } 469 470 /** 471 * Whether the alignment algorithm should try its best to optimize the alignment, 472 * or we are happy with a quick and dirty result. 473 * NB: Not implemented in jFatCat 474 * 475 * @param optimizeAlignment 476 */ 477 public void setOptimizeAlignment(boolean optimizeAlignment) { 478 this.optimizeAlignment = optimizeAlignment; 479 } 480}