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 * Created on 28.04.2004
021 * @author Andreas Prlic
022 *
023 */
024package org.biojava.nbio.structure;
025
026import java.util.List;
027
028import javax.vecmath.Point3d;
029
030/**
031 * A simple interface for an Atom.
032 * The coordinates can be accessed via the
033 * {@link #getCoords()}, or the
034 * {@link #getX()}, {@link #getY()}, {@link #getZ()} methods.
035 * There are a few additional methods here to provide some PDB specific information.
036 *
037
038 * @author Andreas Prlic
039 * @author Horvath Tamas
040 * @version %I% %G%
041 * @since 1.4
042 *
043 */
044public interface Atom extends Cloneable, PDBRecord {
045
046        /**
047         * Set atom name, e.g. "CA".
048         * @param s  a trimmed String specifying the name value
049         * @see #getName
050         */
051        void   setName(String s);
052
053        /**
054         * Get atom name, e.g. "CA".
055         * Beware that some PDB atom names are ambiguous (e.g. CA, which means C-alpha or Calcium),
056         * the ambiguity can simply be resolved by also checking the element with {@link #getElement()}
057         * @return a trimmed String representing the name value
058         * @see #setName
059         */
060        String getName();
061
062        /**
063         * Set element of the atom name, e.g. {@link Element#Fe}
064         * @param e  an Element enumeration
065         * @see #getElement
066         */
067        void   setElement(Element e);
068
069        /**
070         * Get element of the atom, e.g. {@link Element#Ca}
071         * @return an Element enumeration
072         * @see #setElement
073         */
074        Element getElement();
075
076        /**
077         * Set PDB atom number.
078         * @param i  an int specifying the PDBserial value
079         * @see #getPDBserial
080         */
081        void setPDBserial(int i) ;
082
083        /**
084         * Get PDB atom number.
085         * @return an int representing the PDBserial value
086         * @see #setPDBserial
087         */
088        int  getPDBserial() ;
089
090        /**
091         * Set the coordinates.
092         * @param c  an array of doubles specifying the coords value
093         * @see #getCoords
094         */
095        void    setCoords(double[] c);
096
097        /**
098         * Get the coordinates.
099         * @return a new array of doubles representing the coords value
100         * @see #setCoords
101         * @see #getCoordsAsPoint3d()
102         */
103        double[] getCoords() ;
104
105        /**
106         * Get the coordinates.
107         * <p>
108         * Internally the coordinates are represented as Point3d so this
109         * is recommended over {@link #getCoords()}
110         * @return a reference to the Point3d coordinates
111         * @see #getCoords()
112         */
113        Point3d getCoordsAsPoint3d();
114
115        /**
116         * Set the X coordinate.
117         * @param x  a double
118         * @see #getX()
119         */
120        void setX(double x);
121
122        /**
123         * Set the Y coordinate.
124         * @param y  a double
125         * @see #getY()
126         */
127        void setY(double y);
128
129        /**
130         * Set the Z coordinate.
131         * @param z  a double
132         * @see #getZ()
133         */
134        void setZ(double z);
135
136        /**
137         * Get coordinate X.
138         * @return a double
139         * @see #setX(double)
140         */
141        double getX() ;
142
143        /**
144         * Get coordinate Y.
145         * @return a double
146         * @see #setY(double)
147         */
148        double getY() ;
149
150        /**
151         * Get coordinate Z.
152         * @return a double
153         * @see #setZ(double)
154         */
155        double getZ() ;
156
157        /**
158         * Set alternate Location.
159         * @param c  a Character object specifying the alt loc value
160         * @see #getAltLoc
161         */
162        void setAltLoc(Character c);
163
164        /**
165         * Get alternate Location.
166         * @return a Character object representing the alt loc value. Default altLoc ('.' in mmCIF files)
167         * is represented by ' ' (space character, ascii 32).
168         * @see #setAltLoc
169         */
170        Character getAltLoc();
171
172        /**
173         * Set occupancy.
174         * @param occupancy  a float specifying the occupancy value
175         * @see #getOccupancy
176         */
177        void setOccupancy(float occupancy) ;
178
179        /**
180         * Get occupancy.
181         * @return a float representing the occupancy value
182         * @see #setOccupancy
183         */
184        float getOccupancy();
185
186        /**
187         * Set temp factor .
188         * @param temp  a float specifying the temp factor value
189         * @see #getTempFactor
190         */
191        void   setTempFactor(float temp) ;
192
193        /**
194         * Get temp factor.
195         * @return a float representing the temp factor value
196         * @see #setTempFactor
197         */
198        float getTempFactor() ;
199
200        /**
201         * Return an identical copy of this  object .
202         * @return  an identical copy of this  object
203         */
204        Object clone();
205
206        /**
207         * Set the back-reference to its parent Group.
208         * @param parent the parent Group
209         * @see #getGroup()
210         */
211
212        void setGroup(Group parent);
213
214        /**
215         * Return the parent Group of the Atom.
216         * returns null if the referenced object is not Group
217         * @return Group the parent Group of the Atom, or null
218         * @see #setGroup(Group)
219         */
220        Group getGroup();
221
222        /**
223         * Add a bond
224         * @param bond to be added
225         * @see #getBonds()
226         */
227        void addBond(Bond bond);
228
229        /**
230         * Get all {@link Bond}s this atom is part of.
231         *
232         * @return a list of {@link Bond}s or null if no bonds exist for this Atom
233         */
234        List<Bond> getBonds();
235
236        /**
237         * Sets the bonds
238         * @param bonds
239         */
240        void setBonds(List<Bond> bonds);
241
242        /**
243         * Test if another atom has a bond to this atom
244         *
245         * @param other
246         * @return
247         */
248        boolean hasBond(Atom other);
249
250        /**
251         * Get the charge of this atom
252         *
253         * @return a the integer charge.
254         */
255        short getCharge();
256
257        /**
258         * Set the charge of this atom
259         *
260         */
261        void setCharge(short charge);
262}