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 * Author: Daniel Asarnow 021 * Date: 2012-6-23 022 */ 023 024package org.biojava.nbio.structure.cath; 025 026/** The categories found within CATH. 027 * 028 * The CATH node types are: 029 * 'C' (class), 'A' (architecture), 'T' (topology), 'H' (homologous superfamily), 030 * 'S' (sequence family, S35), 'O' (orthologous sequence family, S60), 031 * 'L' ("like" sequence family, S95), 'I' (identical, S100) and 032 * 'D' (domain, S100 count). 033 * 034 * @author Daniel Asarnow 035 */ 036public enum CathCategory { 037 Class, 038 Architecture, 039 Topolgy, 040 Homology, 041 SequenceFamily, 042 OrthologousSequenceFamily, 043 LikeSequenceFamily, 044 IdenticalSequenceFamily, 045 DomainCounter; 046 047 static final String lut = "CATHSOLID"; 048 049 public static CathCategory fromString(String type) { 050 if ( "C".equals(type) ) { 051 return Class; 052 } else if ( "A".equals(type) ) { 053 return Architecture; 054 } else if ( "T".equals(type) ) { 055 return Topolgy; 056 } else if ( "H".equals(type) ) { 057 return Homology; 058 } else if ( "S".equals(type) ) { 059 return SequenceFamily; 060 } else if ( "O".equals(type) ) { 061 return OrthologousSequenceFamily; 062 } else if ( "L".equals(type) ) { 063 return LikeSequenceFamily; 064 } else if ( "I".equals(type) ) { 065 return IdenticalSequenceFamily; 066// } else if ( type.equals("D") ) { 067 } else { 068 return DomainCounter; 069 } 070 } 071 072 @Override 073 public String toString() { 074 switch (this) { 075 case Class: 076 return "C"; 077 case Architecture: 078 return "A"; 079 case Topolgy: 080 return "T"; 081 case Homology: 082 return "H"; 083 case SequenceFamily: 084 return "S"; 085 case OrthologousSequenceFamily: 086 return "O"; 087 case LikeSequenceFamily: 088 return "L"; 089 case IdenticalSequenceFamily: 090 return "I"; 091// case DomainCounter: 092 default: 093 return "D"; 094 } 095 } 096 097 public static CathCategory fromCathCode(String code) { 098 int count = 0; 099 int idx = 0; 100 while ((idx = code.indexOf(".",idx)) != -1) { 101 count++; 102 idx++; 103 } 104 return fromString(lut.substring(count,count+1)); 105 } 106 107}