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.xtal;
022
023import java.util.HashMap;
024
025/**
026 * An enum to represent the 7 Bravais lattices
027 *
028 * @author duarte_j
029 *
030 */
031public enum BravaisLattice {
032
033        TRICLINIC    (1, "TRICLINIC",    new CrystalCell(1.00,1.25,1.50, 60,70,80)), // alpha,beta,gamma!=90
034        MONOCLINIC   (2, "MONOCLINIC",   new CrystalCell(1.00,1.25,1.50, 90,60,90)), // beta!=90, alpha=gamma=90
035        ORTHORHOMBIC (3, "ORTHORHOMBIC", new CrystalCell(1.00,1.25,1.50, 90,90,90)), // alpha=beta=gamma=90
036        TETRAGONAL   (4, "TETRAGONAL",   new CrystalCell(1.00,1.00,1.25, 90,90,90)), // alpha=beta=gamma=90, a=b
037        TRIGONAL     (5, "TRIGONAL",     new CrystalCell(1.00,1.00,1.25, 90,90,120)),// a=b!=c, alpha=beta=90, gamma=120
038        HEXAGONAL    (6, "HEXAGONAL",    new CrystalCell(1.00,1.00,1.25, 90,90,120)),// a=b!=c, alpha=beta=90, gamma=120
039        CUBIC        (7, "CUBIC",        new CrystalCell(1.00,1.00,1.00, 90,90,90)); // a=b=c, alpha=beta=gamma=90
040
041        private static HashMap<String, BravaisLattice> name2bl = initname2bl();
042        private String name;
043        private int id;
044        private CrystalCell exampleUnitCell;
045
046        private BravaisLattice(int id, String name, CrystalCell exampleUnitCell) {
047                this.name = name;
048                this.id = id;
049                this.exampleUnitCell = exampleUnitCell;
050        }
051
052        public String getName() {
053                return name;
054        }
055
056        public int getId() {
057                return id;
058        }
059
060        public CrystalCell getExampleUnitCell() {
061                return exampleUnitCell;
062        }
063
064        private static HashMap<String,BravaisLattice> initname2bl(){
065                HashMap<String,BravaisLattice> name2bl = new HashMap<>();
066                for (BravaisLattice bl:BravaisLattice.values()) {
067                        name2bl.put(bl.getName(), bl);
068                }
069                return name2bl;
070        }
071
072        public static BravaisLattice getByName(String blName) {
073                return name2bl.get(blName);
074        }
075}