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.contact;
022
023import org.biojava.nbio.structure.Group;
024
025import java.io.Serializable;
026import java.util.ArrayList;
027import java.util.List;
028
029/**
030 * A pair of residues that are in contact
031 * @author duarte_j
032 *
033 */
034public class GroupContact implements Serializable {
035
036
037        private static final long serialVersionUID = 1L;
038
039        private Pair<Group> pair;
040
041        private List<AtomContact> atomContacts;
042
043        public GroupContact() {
044                atomContacts = new ArrayList<>();
045        }
046
047        public void addAtomContact(AtomContact atomContact) {
048                atomContacts.add(atomContact);
049        }
050
051        public Pair<Group> getPair() {
052                return pair;
053        }
054
055        public void setPair(Pair<Group> pair) {
056                this.pair = pair;
057        }
058
059        public double getMinDistance() {
060                if (atomContacts.size()==0) return 0;
061
062                double minDistance = Double.MAX_VALUE;
063                for (AtomContact atomContact:atomContacts) {
064                        if (atomContact.getDistance()<minDistance)
065                                minDistance = atomContact.getDistance();
066                }
067                return minDistance;
068        }
069
070        public int getNumAtomContacts() {
071                return atomContacts.size();
072        }
073
074        public List<AtomContact> getAtomContacts() {
075                return atomContacts;
076        }
077
078        /**
079         * Returns the list of atom contacts in this GroupContact that are within the given distance.
080         * @param distance
081         * @return
082         */
083        public List<AtomContact> getContactsWithinDistance(double distance) {
084
085                List<AtomContact> list = new ArrayList<>();
086                for (AtomContact contact:this.atomContacts) {
087                        if (contact.getDistance()<distance) {
088                                list.add(contact);
089                        }
090                }
091                return list;
092        }
093
094        @Override
095        public String toString() {
096                return pair.getFirst().getResidueNumber()+","+pair.getSecond().getResidueNumber();
097        }
098}