Logo Search packages:      
Sourcecode: cdk version File versions  Download package

Ring.java

/* $RCSfile$
 * $Author: egonw $    
 * $Date: 2007-01-04 18:46:10 +0100 (Thu, 04 Jan 2007) $    
 * $Revision: 7636 $
 *
 * Copyright (C) 1997-2007  Christoph Steinbeck <steinbeck@users.sf.net>
 * 
 * Contact: cdk-devel@lists.sourceforge.net
 * 
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public License
 * as published by the Free Software Foundation; either version 2.1
 * of the License, or (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 
 */
package org.openscience.cdk;

/** 
 * Class representing a ring structure in a molecule.
 * A ring is a linear sequence of
 * N atoms interconnected to each other by covalent bonds,
 * such that atom i (1 < i < N) is bonded to
 * atom i-1 and atom i + 1 and atom 1 is bonded to atom N and atom 2.
 *
 * @cdk.module  data
 * @cdk.keyword ring
 */
00036 public class Ring extends AtomContainer implements java.io.Serializable, org.openscience.cdk.interfaces.IRing
{

      /**
     * Determines if a de-serialized object is compatible with this class.
     *
     * This value must only be changed if and only if the new version
     * of this class is imcompatible with the old version. See Sun docs
     * for <a href=http://java.sun.com/products/jdk/1.1/docs/guide
     * /serialization/spec/version.doc.html>details</a>.
       */
00047       private static final long serialVersionUID = 6604894792331865990L;

      /**
       * Constructs an empty ring.
       *
       */
00053       public Ring() {
            super();
      }
      
    /**
     * Constructs a ring from the atoms in an IAtomContainer object.
     *
     * @param atomContainer The IAtomContainer object containing the atoms to form the ring
     */
00062       public Ring(org.openscience.cdk.interfaces.IAtomContainer atomContainer)
      {
            super(atomContainer);
      }
      
      /**
       * Constructs a ring that will have a certain number of atoms of the given elements.
       *
       * @param   ringSize   The number of atoms and bonds the ring will have
       * @param   elementSymbol   The element of the atoms the ring will have
       */
00073       public Ring(int ringSize, String elementSymbol) {
            this(ringSize);
            super.atomCount = ringSize;
            super.bondCount = ringSize;
            atoms[0] = new Atom(elementSymbol);
            for (int i = 1; i < ringSize; i++) {
                  atoms[i] = new Atom(elementSymbol);
                  super.bonds[i-1] = new Bond(atoms[i - 1], atoms[i], 1);
            }
            super.bonds[ringSize-1] = new Bond(atoms[ringSize - 1], atoms[0], 1);
      }
      
            
      /**
       * Constructs an empty ring that will have a certain size.
       *
       * @param   ringSize  The size (number of atoms) the ring will have
       */

00092       public Ring(int ringSize) {
            super(ringSize, ringSize, 0, 0);
      }
      

      /**
       * Returns the number of atoms\edges in this ring.
       *
       * @return   The number of atoms\edges in this ring   
       */

00103       public int getRingSize() {
            return this.atomCount;
      }
      

      /**
       * Returns the next bond in order, relative to a given bond and atom.
       * Example: Let the ring be composed of 0-1, 1-2, 2-3 and 3-0. A request getNextBond(1-2, 2)
       * will return Bond 2-3.
       *
       * @param   bond  A bond for which an atom from a consecutive bond is sought
       * @param   atom  A atom from the bond above to assign a search direction
       * @return  The next bond in the order given by the above assignment   
       */
00117       public org.openscience.cdk.interfaces.IBond getNextBond(org.openscience.cdk.interfaces.IBond bond, org.openscience.cdk.interfaces.IAtom atom)
      {
            org.openscience.cdk.interfaces.IBond tempBond;
            for (int f = 0; f < getBondCount(); f++) {
                  tempBond = getBond(f);
            if (tempBond.contains(atom) && bond != tempBond) return tempBond;
            }
            return null;
      }

      /**
       * Returns the sum of all bond orders in the ring.
       *
       * @return the sum of all bond orders in the ring
       */
00132       public int getBondOrderSum()
      {
            int orderSum = 0;
            for (int i = 0; i < getBondCount(); i++) {
            orderSum += getBond(i).getOrder();
        }
            return orderSum;
      }
      
00141       public String toString() {
            StringBuffer buffer = new StringBuffer();
            buffer.append("Ring(");
            buffer.append(super.toString());
            buffer.append(')');
            return buffer.toString();
      }

}

Generated by  Doxygen 1.6.0   Back to index