001/*
002 *                    PDB web 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 *
015 * Created on May 24, 2009
016 * Created by Andreas Prlic
017 *
018 */
019
020package org.biojava.nbio.structure.align.pairwise;
021
022import java.io.*;
023
024/** A class to track the alignment results in a flat file
025 *
026 * @author andreas
027 *
028 */
029public class AlignmentResult implements Serializable
030{
031
032        /**
033         *
034         */
035        private static final long serialVersionUID = -4132105905712445473L;
036        AlternativeAlignment[] alignments;
037        String pdb1;
038        String pdb2;
039
040        String chain1;
041        String chain2;
042
043        int length1;
044        int length2;
045
046        long calculationTime;
047        long ioTime;
048
049        @Override
050public String toString(){
051                StringBuffer buf = new StringBuffer();
052                buf.append(pdb1);
053                buf.append("_");
054                buf.append(chain1);
055                buf.append(" vs. ");
056                buf.append(pdb2);
057                buf.append("_");
058                buf.append(chain2);
059                buf.append(" : ");
060                buf.append(" l1: ");
061                buf.append(length1);
062                buf.append(" l2: ");
063                buf.append(length2);
064                buf.append(" ");
065                if ( alignments != null)
066                        if ( alignments.length > 0) {
067                                AlternativeAlignment a = alignments[0];
068                                buf.append(a.toString());
069                                int eqr = a.getEqr();
070                                buf.append(" %res1: ");
071                                buf.append(Math.round((eqr/(float)length2)*100));
072                                buf.append(" %res2: ");
073                                buf.append(Math.round((eqr/(float)length1)*100));
074                                buf.append(" ");
075
076                        }
077                buf.append(" ioTime: ");
078                buf.append(ioTime);
079                buf.append(" compTime: ");
080                buf.append(calculationTime);
081                return buf.toString();
082
083        }
084
085        public AlternativeAlignment[] getAlignments()
086        {
087                return alignments;
088        }
089
090        /** we only keep the first alternative...
091         *
092         * @param alignments
093         */
094        public void setAlignments(AlternativeAlignment[] alignments)
095        {
096                if ( alignments.length > 0){
097                        this.alignments = new AlternativeAlignment[1];
098                        this.alignments[0]=alignments[0];
099                }
100
101        }
102        public String getPdb1()
103        {
104                return pdb1;
105        }
106        public void setPdb1(String pdb1)
107        {
108                this.pdb1 = pdb1;
109        }
110        public String getPdb2()
111        {
112                return pdb2;
113        }
114        public void setPdb2(String pdb2)
115        {
116                this.pdb2 = pdb2;
117        }
118        public String getChain1()
119        {
120                return chain1;
121        }
122        public void setChain1(String chain1)
123        {
124                this.chain1 = chain1;
125        }
126        public String getChain2()
127        {
128                return chain2;
129        }
130        public void setChain2(String chain2)
131        {
132                this.chain2 = chain2;
133        }
134        public int getLength1()
135        {
136                return length1;
137        }
138        public void setLength1(int length1)
139        {
140                this.length1 = length1;
141        }
142        public int getLength2()
143        {
144                return length2;
145        }
146        public void setLength2(int length2)
147        {
148                this.length2 = length2;
149        }
150
151
152        public long getCalculationTime()
153        {
154                return calculationTime;
155        }
156        public void setCalculationTime(long calculationTime)
157        {
158                this.calculationTime = calculationTime;
159        }
160        public long getIoTime()
161        {
162                return ioTime;
163        }
164        public void setIoTime(long ioTime)
165        {
166                this.ioTime = ioTime;
167        }
168        public void serialize (File output)
169        throws IOException{
170                // save alignment result:
171
172                FileOutputStream outStream = new FileOutputStream(output);
173                ObjectOutputStream objStream = new ObjectOutputStream(outStream);
174                objStream.writeObject(this);
175                objStream.close();
176
177        }
178
179        public static AlignmentResult deserialize(File output)
180        throws IOException, ClassNotFoundException{
181                FileInputStream fin = new FileInputStream(output);
182                ObjectInputStream objIn = new ObjectInputStream(fin);
183                AlignmentResult result = (AlignmentResult) objIn.readObject();
184                objIn.close();
185                return result;
186        }
187
188
189}