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.scop;
022
023import java.io.IOException;
024import java.io.Serializable;
025import java.util.HashSet;
026import java.util.List;
027import java.util.Set;
028
029import jakarta.xml.bind.annotation.XmlAccessType;
030import jakarta.xml.bind.annotation.XmlAccessorType;
031import jakarta.xml.bind.annotation.XmlRootElement;
032
033import org.biojava.nbio.structure.PdbId;
034import org.biojava.nbio.structure.ResidueRange;
035import org.biojava.nbio.structure.Structure;
036import org.biojava.nbio.structure.StructureException;
037import org.biojava.nbio.structure.StructureIdentifier;
038import org.biojava.nbio.structure.SubstructureIdentifier;
039import org.biojava.nbio.structure.align.util.AtomCache;
040
041
042/** Container for the information for a domain. Contains a line in the file
043 * dir.cla.scop.txt_1.75
044 *
045 * e.g d1dlwa_  1dlw    A:      a.1.1.1 14982   cl=46456,cf=46457,sf=46458,fa=46459,dm=46460,sp=46461,px=14982
046 *
047 * Instantiated using {@link ScopDatabase#getDomainByScopID(String)}
048 * @author Andreas Prlic
049 *
050 */
051@XmlRootElement(name = "ScopDomain", namespace ="http://source.rcsb.org")
052@XmlAccessorType(XmlAccessType.PUBLIC_MEMBER)
053public class ScopDomain implements Serializable, Cloneable, StructureIdentifier {
054
055        private static final long serialVersionUID = 5890476209571654301L;
056
057        String scopId;
058        PdbId pdbId;
059        List<String> ranges;
060        String classificationId;
061        Integer sunid;
062
063        int classId;
064        int foldId;
065        int superfamilyId;
066        int familyId;
067        int domainId;
068        int speciesId;
069        int px;
070
071
072
073
074        @Override
075        public String toString() {
076                StringBuilder buf = new StringBuilder();
077                buf.append(scopId);
078                buf.append("\t") ;
079                buf.append(pdbId.getId().toLowerCase());
080                buf.append( "\t");
081
082                int rangePos = 0;
083                for (String range: ranges){
084                        rangePos++;
085
086                        buf.append(range);
087
088                        if ( ( ranges.size()> 1 ) && (rangePos < ranges.size()))
089                                buf.append(",");
090                }
091                buf.append("\t") ;
092                buf.append(classificationId);
093                buf.append("\t") ;
094                buf.append(String.valueOf(sunid));
095                buf.append("\t") ;
096
097                buf.append("cl=");
098                buf.append(String.valueOf(classId));
099                buf.append(",cf=");
100                buf.append(String.valueOf(foldId));
101                buf.append(",sf=");
102                buf.append(String.valueOf(superfamilyId));
103                buf.append(",fa=");
104                buf.append(String.valueOf(familyId));
105                buf.append(",dm=");
106                buf.append(String.valueOf(domainId));
107                buf.append(",sp=");
108                buf.append(String.valueOf(speciesId));
109                buf.append(",px=");
110                buf.append(String.valueOf(px));
111
112
113                return buf.toString();
114        }
115
116        public String getScopId() {
117                return scopId;
118        }
119        public void setScopId(String scopId) {
120                this.scopId = scopId;
121        }
122
123        /** 
124         * Gets the PDB identifier for this protein structure.
125         * Before BioJava 6.0.0, this method used to return a {@link String}.
126         *
127         * @return the {@link PdbId} PDB identifier
128         * @see #setPdbId(PdbId)
129         * @since 6.0.0
130         */
131        public PdbId getPdbId() {
132                return pdbId;
133        }
134
135        /**
136         * @param pdbId
137         * @deprecated use {@link #setPdbId(PdbId)}
138         */
139        @Deprecated
140        public void setPdbId(String pdbId) {
141                if (pdbId == null)
142                        this.pdbId = null;
143                else
144                        this.pdbId = new PdbId(pdbId);
145        }
146
147        
148        /**
149         * @param pdbId
150         * @since 6.0.0
151         */
152        public void setPdbId(PdbId pdbId) {
153                this.pdbId = pdbId;
154        }
155
156        public List<String> getRanges() {
157                return ranges;
158        }
159        public void setRanges(List<String> ranges) {
160                this.ranges = ranges;
161        }
162        public String getClassificationId() {
163                return classificationId;
164        }
165        public void setClassificationId(String classificationId) {
166                this.classificationId = classificationId;
167        }
168        public Integer getSunid() {
169                return sunid;
170        }
171        public void setSunid(Integer sunid) {
172                this.sunid = sunid;
173        }
174        public int getClassId() {
175                return classId;
176        }
177        public void setClassId(int classId) {
178                this.classId = classId;
179        }
180        public int getFoldId() {
181                return foldId;
182        }
183        public void setFoldId(int foldId) {
184                this.foldId = foldId;
185        }
186        public int getSuperfamilyId() {
187                return superfamilyId;
188        }
189        public void setSuperfamilyId(int superfamilyId) {
190                this.superfamilyId = superfamilyId;
191        }
192        public int getFamilyId() {
193                return familyId;
194        }
195        public void setFamilyId(int familyId) {
196                this.familyId = familyId;
197        }
198        public int getDomainId() {
199                return domainId;
200        }
201        public void setDomainId(int domainId) {
202                this.domainId = domainId;
203        }
204        public int getSpeciesId() {
205                return speciesId;
206        }
207        public void setSpeciesId(int speciesId) {
208                this.speciesId = speciesId;
209        }
210        public int getPx() {
211                return px;
212        }
213        public void setPx(int px) {
214                this.px = px;
215        }
216
217        @Override
218        protected Object clone() throws CloneNotSupportedException {
219
220                super.clone();
221
222                ScopDomain n = new ScopDomain();
223                n.setClassId(getClassId());
224                n.setClassificationId(getClassificationId());
225                n.setDomainId(getDomainId());
226                n.setFamilyId(getFamilyId());
227                n.setFoldId(getFoldId());
228                n.setPdbId(getPdbId());
229                n.setPx(getPx());
230                n.setRanges(getRanges());
231                n.setScopId(getScopId());
232                n.setSpeciesId(getSpeciesId());
233                n.setSunid(getSunid());
234                n.setSuperfamilyId(getSuperfamilyId());
235
236
237                return n;
238
239
240        }
241
242        /**
243         * Returns the chains this domain is defined over; contains more than 1 element only if this domains is a multi-chain domain.
244         */
245        public Set<String> getChains() {
246                Set<String> chains = new HashSet<>();
247                List<ResidueRange> rrs = ResidueRange.parseMultiple(getRanges());
248                for (ResidueRange rr : rrs) chains.add(rr.getChainName());
249                return chains;
250        }
251
252        @Override
253        public String getIdentifier() {
254                return getScopId();
255        }
256
257        public List<ResidueRange> getResidueRanges() {
258                return ResidueRange.parseMultiple(ranges);
259        }
260
261        @Override
262        public SubstructureIdentifier toCanonical() {
263                return new SubstructureIdentifier(getPdbId(), ResidueRange.parseMultiple(getRanges()));
264        }
265
266        @Override
267        public Structure reduce(Structure input) throws StructureException {
268                return toCanonical().reduce(input);
269        }
270
271        @Override
272        public Structure loadStructure(AtomCache cache) throws StructureException,
273        IOException {
274                return cache.getStructureForPdbId(pdbId);
275        }
276
277}