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.aaproperties.xml;
022
023import jakarta.xml.bind.annotation.XmlAccessType;
024import jakarta.xml.bind.annotation.XmlAccessorType;
025import jakarta.xml.bind.annotation.XmlAttribute;
026import jakarta.xml.bind.annotation.XmlElement;
027import java.util.HashMap;
028import java.util.List;
029import java.util.Map;
030
031/**
032 * One way to model the elements
033 * @author pvtroshin
034 *
035 */
036@XmlAccessorType(XmlAccessType.NONE)
037public class Element {
038
039        /**
040         * Element name as per periodic table e.g. "Hydrogen"
041         */
042        @XmlAttribute(name = "name", required = true)
043        private String name;
044        /**
045         * Element short name as in periodic table e.g. "H"
046         */
047        @XmlAttribute(name = "symbol")
048        private String symbol;
049        /**
050         * The atomic number of the element = number of protons.
051         */
052        @XmlAttribute(name = "atomicnumber")
053        private int atomicNumber;
054        /**
055         * The computed mass based on isotopes and their abundances
056         */
057        @XmlAttribute(name = "mass", required = true)
058        private double mass;
059        /**
060         * List of common isotopes of the element
061         */
062        @XmlElement
063        private List<Isotope> isotope;
064
065        /**
066         * To enable quick retrieval of Isotope from its name
067         */
068        private Map<String, Isotope> name2Isotope;
069
070        public Element(){}
071
072        public Element(String name, String symbol, int atomicNumber, List<Isotope> isotopes, double mass){
073                if(atomicNumber <= 0){
074                        throw new Error("Atomic number of Elements must be > 0.");
075                }
076                if(mass <= 0){
077                        throw new Error("Mass of Elements must be > 0.");
078                }
079                this.setName(name);
080                this.setSymbol(symbol);
081                this.setAtomicNumber(atomicNumber);
082                this.setIsotopes(isotopes);
083                this.setMass(mass);
084        }
085
086        @Override
087        public String toString(){
088                return symbol + ", " + name + ", " + atomicNumber;
089        }
090
091        public void setMass(double mass){
092                this.mass = mass;
093        }
094
095        public double getMass(){
096                return this.mass;
097        }
098
099        public void setName(String name) {
100                this.name = name;
101        }
102
103        public String getName(){
104                return this.name;
105        }
106
107        public void setSymbol(String symbol) {
108                this.symbol = symbol;
109        }
110
111        public void setAtomicNumber(int atomicNumber) {
112                this.atomicNumber = atomicNumber;
113        }
114
115
116        public List<Isotope> getIsotopes() {
117                return isotope;
118        }
119
120
121        public void setIsotopes(List<Isotope> isotopes) {
122                this.isotope = isotopes;
123                this.name2Isotope = new HashMap<>();
124                if(isotopes != null){
125                        for(Isotope i:isotopes){
126                                name2Isotope.put(i.getName(), i);
127                        }
128                }
129        }
130}