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.structure; 022 023import java.util.HashMap; 024import java.util.Set; 025 026/** 027 * 028 * An enum to represent the experimental technique of a PDB structure 029 * 030 * @author duarte_j 031 * 032 */ 033public enum ExperimentalTechnique { 034 035 036 XRAY_DIFFRACTION ("X-RAY DIFFRACTION", true, false), 037 038 SOLUTION_NMR ("SOLUTION NMR", false, true), 039 SOLID_STATE_NMR ("SOLID-STATE NMR", false, true), 040 041 ELECTRON_MICROSCOPY ("ELECTRON MICROSCOPY", false, false), 042 ELECTRON_CRYSTALLOGRAPHY ("ELECTRON CRYSTALLOGRAPHY",true, false), 043 044 FIBER_DIFFRACTION ("FIBER DIFFRACTION", false, false), 045 046 NEUTRON_DIFFRACTION ("NEUTRON DIFFRACTION", true, false), 047 048 SOLUTION_SCATTERING ("SOLUTION SCATTERING", false, false), 049 050 051 // from here, not in "official list" in pdb.org advanced search: they call these "OTHER" 052 POWDER_DIFFRACTION ("POWDER DIFFRACTION", true, false), 053 054 FLUORESCENCE_TRANSFER ("FLUORESCENCE TRANSFER", false, false), 055 056 INFRARED_SPECTROSCOPY ("INFRARED SPECTROSCOPY", false, false); 057 058 059 private static final HashMap<String, ExperimentalTechnique> expTechStr2Value = initExpTechStr2Value(); 060 061 062 private String name; 063 private boolean isCrystallographic; 064 private boolean isNmr; 065 066 private ExperimentalTechnique(String name, boolean isXtallographic, boolean isNmr) { 067 this.name = name; 068 this.isCrystallographic = isXtallographic; 069 this.isNmr = isNmr; 070 } 071 072 073 private static HashMap<String, ExperimentalTechnique> initExpTechStr2Value() { 074 HashMap<String, ExperimentalTechnique> expTechStr2Value = new HashMap<>(); 075 for(ExperimentalTechnique exp:ExperimentalTechnique.values()) { 076 expTechStr2Value.put(exp.getName(), exp); 077 } 078 return expTechStr2Value; 079 } 080 081 public String getName() { 082 return name; 083 } 084 085 public boolean isCrystallographic() { 086 return isCrystallographic; 087 } 088 089 public boolean isNmr() { 090 return isNmr; 091 } 092 093 /** 094 * Returns the ExpTechnique given an experimental technique name as used in the PDB, 095 * e.g. "X-RAY DIFFRACTION" returns {@link ExperimentalTechnique#XRAY_DIFFRACTION} 096 * @param expTechniqueName the ExpTechnique value or null if string doesn't match one of the known PDB experimental strings 097 * @return 098 */ 099 public static ExperimentalTechnique getByName(String expTechniqueName) { 100 return expTechStr2Value.get(expTechniqueName); 101 } 102 103 /** 104 * Given a Set of ExperimentalTechniques returns true if at least one is crystallographic 105 * @return true if at least 1 of the techniques is crystallographic, false if 106 * none of the techniques are crystallographic 107 * @throws NullPointerException if input is null 108 */ 109 public static boolean isCrystallographic(Set<ExperimentalTechnique> techniques) { 110 111 for (ExperimentalTechnique et:techniques) { 112 if (et.isCrystallographic()) return true; 113 } 114 115 return false; 116 117 } 118 119 /** 120 * Given a Set of ExperimentalTechniques returns true if at least one is NMR 121 * @return true if at least 1 of the techniques is NMR, false if 122 * none of the techniques are NMR 123 * @throws NullPointerException if input is null 124 */ 125 public static boolean isNmr(Set<ExperimentalTechnique> techniques) { 126 127 for (ExperimentalTechnique et:techniques) { 128 if (et.isNmr()) return true; 129 } 130 131 return false; 132 } 133 134 @Override 135 public String toString() { 136 return getName(); 137 } 138}