annotate mayachemtool/mayachemtools/lib/PDBFileUtil.pm @ 0:a4a2ad5a214e draft default tip

Uploaded
author deepakjadmin
date Thu, 05 Nov 2015 02:37:56 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1 package PDBFileUtil;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
2 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
3 # $RCSfile: PDBFileUtil.pm,v $
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
4 # $Date: 2015/02/28 20:47:18 $
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
5 # $Revision: 1.36 $
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
6 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
7 # Author: Manish Sud <msud@san.rr.com>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
8 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
9 # Copyright (C) 2015 Manish Sud. All rights reserved.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
10 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
11 # This file is part of MayaChemTools.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
12 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
13 # MayaChemTools is free software; you can redistribute it and/or modify it under
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
14 # the terms of the GNU Lesser General Public License as published by the Free
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
15 # Software Foundation; either version 3 of the License, or (at your option) any
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
16 # later version.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
17 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
18 # MayaChemTools is distributed in the hope that it will be useful, but without
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
19 # any warranty; without even the implied warranty of merchantability of fitness
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
20 # for a particular purpose. See the GNU Lesser General Public License for more
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
21 # details.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
22 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
23 # You should have received a copy of the GNU Lesser General Public License
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
24 # along with MayaChemTools; if not, see <http://www.gnu.org/licenses/> or
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
25 # write to the Free Software Foundation Inc., 59 Temple Place, Suite 330,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
26 # Boston, MA, 02111-1307, USA.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
27 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
28
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
29 use strict;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
30 use Exporter;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
31 use Text::ParseWords;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
32 use TextUtil;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
33 use FileUtil;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
34 use TimeUtil ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
35
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
36 use vars qw(@ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
37
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
38 @ISA = qw(Exporter);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
39 @EXPORT = qw(GetPDBRecordType GetRecordTypesCount GetAllResidues GetConectRecordLines GetChainsAndResidues GetExperimentalTechnique GetExperimentalTechniqueResolution GetMinMaxCoords IsPDBFile IsAtomRecordType IsConectRecordType IsHeaderRecordType IsHetatmRecordType IsSeqresRecordType IsModelRecordType IsEndmdlRecordType IsTerRecordType IsMasterRecordType ReadPDBFile ParseHeaderRecordLine GenerateHeaderRecordLine GenerateHeaderRecordTimeStamp ParseAtomRecordLine GenerateAtomRecordLine ParseAtomOrHetatmRecordLine GenerateAtomOrHetatmRecordLine GenerateHetatmRecordLine ParseHetatmRecordLine ParseConectRecordLine GenerateConectRecordLine ParseExpdtaRecordLine ParseRemark2ResolutionRecordLine ParseSeqresRecordLine ParseTerRecordLine GenerateTerRecordLine ParseMasterRecordLine GenerateEndRecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
40 @EXPORT_OK = qw();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
41
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
42 %EXPORT_TAGS = (all => [@EXPORT, @EXPORT_OK]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
43
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
44 # Get PDB record type...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
45 sub GetPDBRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
46 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
47
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
48 return _GetRecordType($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
49 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
50
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
51 # Is it a PDB file?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
52 sub IsPDBFile {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
53 my($PDBFile) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
54 my($Line, $Status);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
55
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
56 $Status = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
57 open PDBFILE, "$PDBFile" or die "Can't open $PDBFile: $!\n";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
58 $Line = GetTextLine(\*PDBFILE);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
59 $Status = ($Line =~ /^HEADER/i) ? 1 : 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
60 close PDBFILE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
61
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
62 return $Status;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
63 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
64
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
65 # Is it a atom record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
66 sub IsAtomRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
67 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
68
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
69 return _IsRecordType($Line, 'ATOM');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
70 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
71
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
72 # Is it a connect record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
73 sub IsConectRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
74 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
75
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
76 return _IsRecordType($Line, 'CONECT');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
77 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
78
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
79 # Is it a header atom record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
80 sub IsHeaderRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
81 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
82
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
83 return _IsRecordType($Line, 'HEADER');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
84 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
85
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
86 # Is it a hetro atom record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
87 sub IsHetatmRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
88 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
89
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
90 return _IsRecordType($Line, 'HETATM');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
91 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
92
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
93 # Is it a seqres record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
94 sub IsSeqresRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
95 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
96
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
97 return _IsRecordType($Line, 'SEQRES');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
98 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
99
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
100 # Is it a MODEL record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
101 sub IsModelRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
102 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
103
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
104 return _IsRecordType($Line, 'MODEL');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
105 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
106
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
107 # Is it a ENDMDL record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
108 sub IsEndmdlRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
109 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
110
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
111 return _IsRecordType($Line, 'ENDMDL');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
112 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
113
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
114 # Is it a TER record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
115 sub IsTerRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
116 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
117
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
118 return _IsRecordType($Line, 'TER');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
119 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
120
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
121 # Is it a MASTER record type?
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
122 sub IsMasterRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
123 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
124
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
125 return _IsRecordType($Line, 'MASTER');
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
126 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
127
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
128 # Count the number of each record type and a reference to data type with these key/value pairs:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
129 # {RecordTypes} - An array of unique record types in order of their presence in the file
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
130 # {Count}{$RecordType} - Count of each record type
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
131 # {Lines}{$RecordType} - Optional lines data for a specific record type.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
132 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
133 sub GetRecordTypesCount {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
134 my($PDBRecordLinesRef, $SpecifiedRecordType, $GetRecordLinesFlag, $RecordType, $RecordLine, %RecordTypeDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
135
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
136 %RecordTypeDataMap = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
137 @{$RecordTypeDataMap{RecordTypes}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
138 %{$RecordTypeDataMap{Count}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
139 %{$RecordTypeDataMap{Lines}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
140
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
141 $SpecifiedRecordType = '';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
142 $GetRecordLinesFlag = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
143 if (@_ == 3) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
144 ($PDBRecordLinesRef, $SpecifiedRecordType, $GetRecordLinesFlag) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
145 $SpecifiedRecordType = uc $SpecifiedRecordType;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
146 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
147 elsif (@_ == 2) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
148 ($PDBRecordLinesRef, $SpecifiedRecordType) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
149 $SpecifiedRecordType = uc $SpecifiedRecordType;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
150 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
151 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
152 ($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
153 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
154 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
155 $RecordType = _GetRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
156 if ($SpecifiedRecordType && ($SpecifiedRecordType ne $RecordType)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
157 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
158 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
159 if (exists $RecordTypeDataMap{Count}{$RecordType}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
160 # Update count...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
161 $RecordTypeDataMap{Count}{$RecordType} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
162
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
163 if ($GetRecordLinesFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
164 push @{$RecordTypeDataMap{Lines}{$RecordType}}, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
165 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
166 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
167 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
168 # New record type...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
169 push @{$RecordTypeDataMap{RecordTypes}}, $RecordType;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
170 $RecordTypeDataMap{Count}{$RecordType} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
171
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
172 if ($GetRecordLinesFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
173 @{$RecordTypeDataMap{Lines}{$RecordType}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
174 push @{$RecordTypeDataMap{Lines}{$RecordType}}, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
175 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
176 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
177 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
178 return (\%RecordTypeDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
179 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
180
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
181 # Collect CONECT record lines for specific atom number, modified specified data to exclude any atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
182 # number not present in the list of specified atom numbers and return a reference to list of
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
183 # CONECT record lines.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
184 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
185 sub GetConectRecordLines {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
186 my($PDBRecordLinesRef, $AtomNumbersMapRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
187 my($AtomNumber, $ConectAtomNumber, $RecordLine, @ConectRecordAtomNums, @ConectRecordLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
188
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
189 @ConectRecordLines = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
190 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
191 if (!IsConectRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
192 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
193 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
194 @ConectRecordAtomNums = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
195 push @ConectRecordAtomNums, ParseConectRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
196 ATOMNUMBER: for $ConectAtomNumber (@ConectRecordAtomNums) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
197 if (defined $ConectAtomNumber) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
198 $AtomNumber = $ConectAtomNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
199 if ($AtomNumber) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
200 if (! exists $AtomNumbersMapRef->{$AtomNumber}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
201 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
202 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
203 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
204 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
205 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
206 push @ConectRecordLines, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
207 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
208 return \@ConectRecordLines;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
209 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
210
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
211 # Get chains and residue information using ATOM/HETATM or SEQRES records. And return a reference to a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
212 # hash with these keys:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
213 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
214 # @{$ChainsDataMap{ChainIDs}} - List of chain IDs with 'None' for no chain identification
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
215 # @{$ChainsDataMap{Residues}{$ChainID}} - List of residues in order of their appearance in a chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
216 # @{$ChainsDataMap{ResidueNumbers}{$ChainID}} - List of residue numbers in order of their appearance in a chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
217 # %{$ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName}} - Count of specific residues in a chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
218 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
219 # Notes:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
220 # . Chains and residue data can be extacted using either ATOM/HETATM records or SEQRES records.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
221 # . In addition to a different chain ID in ATOM/HETATM a TER record also indicates end of an existing chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
222 # and start of a new one: ChainID in ATOM/HETATM records might still be emtpy.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
223 # . ATOM/HETATM records after the first ENDMDL records are simply ingnored.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
224 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
225 sub GetChainsAndResidues {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
226 my($PDBRecordLinesRef, $RecordsSource, $GetChainResiduesBeyondTERFlag, $GetRecordLinesFlag);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
227
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
228 $RecordsSource = 'AtomAndHetatm';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
229 $GetChainResiduesBeyondTERFlag = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
230 $GetRecordLinesFlag = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
231
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
232 if (@_ == 4) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
233 ($PDBRecordLinesRef, $RecordsSource, $GetChainResiduesBeyondTERFlag, $GetRecordLinesFlag) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
234 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
235 elsif (@_ == 3) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
236 ($PDBRecordLinesRef, $RecordsSource, $GetChainResiduesBeyondTERFlag) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
237 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
238 elsif (@_ == 2) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
239 ($PDBRecordLinesRef, $RecordsSource) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
240 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
241 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
242 ($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
243 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
244
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
245 if ($RecordsSource =~ /^AtomAndHetatm$/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
246 return _GetChainsAndResiduesFromAtomHetatmRecords($PDBRecordLinesRef, $GetChainResiduesBeyondTERFlag, $GetRecordLinesFlag);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
247 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
248 elsif ($RecordsSource =~ /^Seqres$/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
249 return _GetChainsAndResiduesFromSeqresRecords($PDBRecordLinesRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
250 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
251 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
252 my(%ChainsDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
253 %ChainsDataMap = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
254 @{$ChainsDataMap{ChainIDs}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
255 %{$ChainsDataMap{Residues}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
256 %{$ChainsDataMap{ResidueNumbers}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
257 %{$ChainsDataMap{ResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
258
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
259 return \%ChainsDataMap;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
260 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
261 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
262
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
263
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
264 # Get residue information using ATOM/HETATM records and return a reference to a hash with
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
265 # these keys:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
266 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
267 # @{$ResiduesDataMap{ResidueNames}} - List of all the residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
268 # %{$ResiduesDataMap{ResidueCount}{$ResidueName}} - Count of residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
269 # @{$ResiduesDataMap{AtomResidueNames}} - List of all the residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
270 # %{$ResiduesDataMap{AtomResidueCount}{$ResidueName}} - Count of residues in ATOM records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
271 # @{$ResiduesDataMap{HetatomResidueNames}} - List of all the residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
272 # %{$ResiduesDataMap{HetatmResidueCount}{$ResidueName}} - Count of residues HETATM records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
273 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
274 # Notes:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
275 # . ATOM/HETATM records after the first ENDMDL records are simply ingnored.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
276 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
277 sub GetAllResidues {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
278 my($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
279
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
280 my($PreviousChainID, $PreviousResidueNumber, $RecordLine, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge, %ResiduesDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
281
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
282 %ResiduesDataMap = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
283 @{$ResiduesDataMap{ResidueNames}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
284 %{$ResiduesDataMap{ResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
285 @{$ResiduesDataMap{AtomResidueNames}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
286 %{$ResiduesDataMap{AtomResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
287 @{$ResiduesDataMap{HetatmResidueNames}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
288 %{$ResiduesDataMap{HetatmResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
289
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
290 $PreviousChainID = '';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
291 $PreviousResidueNumber = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
292
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
293 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
294 if (IsEndmdlRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
295 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
296 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
297 if (!(IsAtomRecordType($RecordLine) || IsHetatmRecordType($RecordLine))) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
298 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
299 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
300 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = ParseAtomRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
301
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
302 if ($PreviousChainID eq $ChainID) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
303 if ($ResidueNumber == $PreviousResidueNumber) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
304 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
305 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
306 $PreviousResidueNumber = $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
307 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
308 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
309 # New chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
310 $PreviousChainID = $ChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
311 $PreviousResidueNumber = $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
312 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
313
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
314 # Store the residue and update its count...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
315 push @{$ResiduesDataMap{ResidueNames}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
316 if (exists $ResiduesDataMap{ResidueCount}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
317 $ResiduesDataMap{ResidueCount}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
318 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
319 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
320 $ResiduesDataMap{ResidueCount}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
321 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
322 # Update ATOM residue data...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
323 if (IsAtomRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
324 push @{$ResiduesDataMap{AtomResidueNames}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
325 if (exists $ResiduesDataMap{AtomResidueCount}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
326 $ResiduesDataMap{AtomResidueCount}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
327 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
328 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
329 $ResiduesDataMap{AtomResidueCount}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
330 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
331 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
332 # Update HETATM residue data...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
333 if (IsHetatmRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
334 push @{$ResiduesDataMap{HetatmResidueNames}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
335 if (exists $ResiduesDataMap{HetatmResidueCount}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
336 $ResiduesDataMap{HetatmResidueCount}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
337 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
338 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
339 $ResiduesDataMap{HetatmResidueCount}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
340 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
341 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
342 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
343
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
344 return \%ResiduesDataMap;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
345 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
346
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
347 # Return min/max XYZ coordinates for ATOM/HETATM records...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
348 sub GetMinMaxCoords {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
349 my($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
350
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
351 my($XMin, $YMin, $ZMin, $XMax, $YMax, $ZMax, $RecordLine, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
352
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
353 ($XMin, $YMin, $ZMin) = (99999) x 3;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
354 ($XMax, $YMax, $ZMax) = (-99999) x 3;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
355
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
356 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
357 if (!(IsAtomRecordType($RecordLine) || IsHetatmRecordType($RecordLine))) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
358 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
359 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
360 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = ParseAtomRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
361
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
362 $XMin = ($X < $XMin) ? $X : $XMin;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
363 $YMin = ($Y < $YMin) ? $Y : $YMin;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
364 $ZMin = ($Z < $ZMin) ? $Z : $ZMin;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
365
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
366 $XMax = ($X > $XMax) ? $X : $XMax;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
367 $YMax = ($Y > $YMax) ? $Y : $YMax;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
368 $ZMax = ($Z > $ZMax) ? $Z : $ZMax;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
369 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
370
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
371 if ($XMin == 99999) { $XMin = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
372 if ($YMin == 99999) { $YMin = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
373 if ($ZMin == 99999) { $ZMin = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
374 if ($XMax == -99999) { $XMax = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
375 if ($YMax == -99999) { $YMax = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
376 if ($ZMax == -99999) { $ZMax = undef; }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
377
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
378 return ($XMin, $YMin, $ZMin, $XMax, $YMax, $ZMax);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
379 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
380
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
381 # Read PDB file and return reference to record lines..
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
382 sub ReadPDBFile {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
383 my($PDBFile) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
384
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
385 my($Line, @PDBRecordLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
386
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
387 @PDBRecordLines = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
388 open PDBFILE, "$PDBFile" or die "Can't open $PDBFile: $!\n";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
389 while ($Line = GetTextLine(\*PDBFILE)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
390 push @PDBRecordLines, $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
391 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
392
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
393 close PDBFILE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
394
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
395 return (\@PDBRecordLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
396 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
397
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
398 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
399 # Get experimental technique information...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
400 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
401 sub GetExperimentalTechnique {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
402 my($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
403 my($RecordLine, $ContinuationNum, $ExperimentalTechnique);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
404
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
405 $ExperimentalTechnique = undef;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
406
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
407 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
408 if (_IsRecordType($RecordLine, 'EXPDTA')) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
409 ($ContinuationNum, $ExperimentalTechnique) = ParseExpdtaRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
410 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
411 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
412 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
413
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
414 return $ExperimentalTechnique;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
415 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
416
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
417 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
418 # Get experimental technique resolution information...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
419 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
420 sub GetExperimentalTechniqueResolution {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
421 my($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
422 my($RecordLine, $Resolution, $ResolutionUnits);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
423
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
424 ($Resolution, $ResolutionUnits) = ((undef) x 2);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
425
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
426 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
427 if ($RecordLine =~ /^REMARK 2 RESOLUTION./i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
428 ($Resolution, $ResolutionUnits) = ParseRemark2ResolutionRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
429 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
430 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
431 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
432
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
433 return ($Resolution, $ResolutionUnits);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
434 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
435
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
436 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
437 # Parse HEADER record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
438 sub ParseHeaderRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
439 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
440 my($Classification, $DepositionDate, $IDCode) = (undef, undef, undef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
441
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
442 if ($Line !~ /^HEADER/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
443 return ($Classification, $DepositionDate, $IDCode);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
444 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
445 my($Length);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
446
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
447 ($Classification, $DepositionDate, $IDCode) = ('') x 3;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
448
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
449 $Length = length $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
450
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
451 if ($Length <= 62) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
452 ($Classification, $DepositionDate) = unpack("x10A40A9", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
453 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
454 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
455 ($Classification, $DepositionDate, $IDCode) = unpack("x10A40A9x3A4", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
456 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
457
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
458 $Classification = RemoveLeadingAndTrailingWhiteSpaces($Classification);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
459 $DepositionDate =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
460 $IDCode =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
461
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
462 return ($Classification, $DepositionDate, $IDCode);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
463 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
464
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
465 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
466 # Generate HEADER record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
467 sub GenerateHeaderRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
468 my($Classification, $Date, $IDCode, $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
469
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
470 $Classification = "Created using MayaChemTools";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
471 $Date = GenerateHeaderRecordTimeStamp();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
472 if (@_ == 3) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
473 ($IDCode, $Classification, $Date) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
474 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
475 elsif (@_ == 2) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
476 ($IDCode, $Classification) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
477 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
478 elsif (@_ == 1) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
479 ($IDCode) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
480 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
481
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
482 $Line = sprintf "HEADER %-40.40s%9.9s %4.4s", $Classification, $Date, $IDCode;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
483 return $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
484 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
485
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
486 # Generate PDB header time stamp...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
487 sub GenerateHeaderRecordTimeStamp {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
488 return TimeUtil::PDBFileTimeStamp();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
489 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
490
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
491 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
492 # Parse ATOM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
493 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
494 sub ParseAtomRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
495 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
496
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
497 return _ParseAtomOrHetatmRecordLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
498 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
499
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
500 # Generate ATOM record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
501 sub GenerateAtomRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
502 my($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
503
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
504 return _GenerateAtomOrHetatmRecordLine('ATOM', $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
505 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
506
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
507 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
508 # Parse ATOM/HETATm record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
509 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
510 sub ParseAtomOrHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
511 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
512
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
513 return _ParseAtomOrHetatmRecordLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
514 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
515
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
516 # Generate ATOM/HETATM record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
517 sub GenerateAtomOrHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
518 my($RecordType, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
519
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
520 return _GenerateAtomOrHetatmRecordLine($RecordType, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
521 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
522 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
523 # Parse HETATM record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
524 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
525 sub ParseHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
526 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
527
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
528 return _ParseAtomOrHetatmRecordLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
529 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
530
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
531 # Generate HETATM record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
532 sub GenerateHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
533 my($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
534
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
535 return _GenerateAtomOrHetatmRecordLine('HETATM', $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
536 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
537
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
538 # Parse EXPDTA record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
539 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
540 # EXPDTA format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
541 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
542 #1 - 6 Record name "EXPDTA"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
543 # 9 - 10 Continuation continuation Allows concatenation of multiple records.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
544 # 11 - 70 SList technique The experimental technique(s) with optional comment describing the sample or experiment.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
545 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
546 # The EXPDTA record identifies the experimental technique used. This may refer to the type of radiation and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
547 # sample, or include the spectroscopic or modeling technique. Permitted values include:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
548 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
549 # ELECTRON DIFFRACTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
550 # FIBER DIFFRACTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
551 # FLUORESCENCE TRANSFER
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
552 # NEUTRON DIFFRACTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
553 # NMR
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
554 # THEORETICAL MODEL
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
555 # X-RAY DIFFRACTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
556 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
557 sub ParseExpdtaRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
558 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
559
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
560 if ($Line !~ /^EXPDTA/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
561 return ((undef) x 2);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
562 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
563
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
564 my($ContinuationNum, $ExperimentalTechnique) = unpack("x8A2A60" , $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
565
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
566 $ContinuationNum =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
567 $ExperimentalTechnique = RemoveLeadingAndTrailingWhiteSpaces($ExperimentalTechnique);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
568
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
569 return ($ContinuationNum, $ExperimentalTechnique);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
570 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
571
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
572 # Parse REMARK 2 record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
573 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
574 # REMARK 2 format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
575 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
576 # The second REMARK 2 record has one of two formats. The first is used for diffraction studies, the second
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
577 # for other types of experiments in which resolution is not relevant, e.g., NMR and theoretical modeling.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
578 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
579 #For diffraction experiments:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
580 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
581 # 1 - 6 Record name "REMARK"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
582 # 10 LString(1) "2"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
583 # 12 - 22 LString(11) "RESOLUTION."
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
584 # 23 - 27 Real(5.2) resolution Resolution.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
585 # 29 - 38 LString(10) "ANGSTROMS."
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
586 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
587 # REMARK 2 when not a diffraction experiment:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
588 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
589 # 1 - 6 Record name "REMARK"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
590 # 10 LString(1) "2"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
591 # 12 - 38 LString(28) "RESOLUTION. NOT APPLICABLE."
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
592 # 41 - 70 String comment Comment.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
593 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
594 sub ParseRemark2ResolutionRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
595 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
596
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
597 if ($Line !~ /^REMARK 2 RESOLUTION./i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
598 return ((undef) x 2);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
599 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
600
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
601 my($Resolution, $ResolutionUnits);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
602
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
603 if ($Line =~ /NOT APPLICABLE/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
604 ($Resolution, $ResolutionUnits) = ("NOT APPLICABLE", "");
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
605 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
606 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
607 ($Resolution, $ResolutionUnits) = unpack("x22A5x1A10" , $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
608 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
609
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
610 $Resolution = RemoveLeadingAndTrailingWhiteSpaces($Resolution);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
611
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
612 $ResolutionUnits = RemoveLeadingAndTrailingWhiteSpaces($ResolutionUnits);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
613 $ResolutionUnits =~ s/\.$//;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
614
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
615 return ($Resolution, $ResolutionUnits);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
616 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
617
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
618 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
619 # Parse SEQRES record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
620 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
621 # SEQRES format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
622 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
623 # 1 - 6 Record name "SEQRES"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
624 # 9 - 10 Serial number of the SEQRES record for the current chain. Starts at 1 and increments by one each line. Reset to 1 for each chain.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
625 # 12 - Chain identifier
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
626 # 14 - 17 Integer numRes Number of residues in the chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
627 # 20 - 22 24 -26 ... ... 68 - 70 Residue name resName Residue name.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
628 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
629 sub ParseSeqresRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
630 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
631
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
632 if ($Line !~ /^SEQRES/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
633 return ((undef) x 5);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
634 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
635 my($RecordSerialNumber, $ChainID, $NumOfResidues, $ResidueNames) = unpack("x8A2x1A1x1A4x2A51" , $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
636 $RecordSerialNumber =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
637 $ChainID =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
638 $NumOfResidues =~ s/ //g;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
639 $ResidueNames = RemoveLeadingAndTrailingWhiteSpaces($ResidueNames);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
640
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
641 return ($RecordSerialNumber, $ChainID, $NumOfResidues, $ResidueNames);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
642 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
643
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
644 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
645 # Parse CONECT record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
646 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
647 # CONECT format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
648 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
649 # 1 - 6 Record name "CONECT"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
650 # 7 - 11 Atom number
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
651 # 12 - 16, 17 - 21, 22 - 26, 27 - 31 Atom number of bonded atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
652 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
653 # 32 - 36, 37 - 41 Atom number of hydrogen bonded atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
654 # 42 - 46 Atom number of salt bridged atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
655 # 47 - 51, 52 -56 Atom number of hydrogen bonded atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
656 # 57 - 61 Atom number of salt bridged atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
657 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
658 sub ParseConectRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
659 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
660
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
661 if ($Line !~ /^CONECT/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
662 return ((undef) x 11);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
663 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
664 my($AtomNum, $BondedAtomNum1, $BondedAtomNum2, $BondedAtomNum3, $BondedAtomNum4, $HBondedAtomNum1, $HBondedAtomNum2, $SaltBridgedAtomNum1, $HBondedAtomNum3, $HBondedAtomNum4, $SaltBridgedAtomNum2) = map {s/ //g; $_} unpack("x6A5A5A5A5A5A5A5A5A5A5A5", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
665
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
666 return ($AtomNum, $BondedAtomNum1, $BondedAtomNum2, $BondedAtomNum3, $BondedAtomNum4, $HBondedAtomNum1, $HBondedAtomNum2, $SaltBridgedAtomNum1, $HBondedAtomNum3, $HBondedAtomNum4, $SaltBridgedAtomNum2);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
667 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
668
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
669 # Generate CONECT record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
670 sub GenerateConectRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
671 my($AtomNum, $BondedAtomNum1, $BondedAtomNum2, $BondedAtomNum3, $BondedAtomNum4, $HBondedAtomNum1, $HBondedAtomNum2, $SaltBridgedAtomNum1, $HBondedAtomNum3, $HBondedAtomNum4, $SaltBridgedAtomNum2) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
672 my($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
673
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
674 $Line = sprintf "CONECT%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s%5.5s", $AtomNum, $BondedAtomNum1, $BondedAtomNum2, $BondedAtomNum3, $BondedAtomNum4, $HBondedAtomNum1, $HBondedAtomNum2, $SaltBridgedAtomNum1, $HBondedAtomNum3, $HBondedAtomNum4, $SaltBridgedAtomNum2;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
675
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
676 return $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
677 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
678
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
679 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
680 # Parse TER record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
681 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
682 # TER format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
683 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
684 #1 - 6 Record name "TER "
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
685 # 7 - 11 Serial number
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
686 # 18 - 20 Residue name
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
687 # 22 Chain identifier
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
688 # 23 - 26 Residue sequence number
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
689 # 27 Insertion code
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
690 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
691 sub ParseTerRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
692 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
693
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
694 if ($Line !~ /^TER/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
695 return ((undef) x 5);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
696 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
697 my($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $Length);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
698
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
699 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode) = ('') x 5;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
700
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
701 $Length = length $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
702
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
703 if ($Length <= 17) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
704 ($SerialNumber, $ResidueName) = map {s/ //g; $_} unpack("x6A5", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
705 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
706 elsif ($Length <= 21) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
707 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode) = map {s/ //g; $_} unpack("x6A5x6A3", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
708 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
709 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
710 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode) = map {s/ //g; $_} unpack("x6A5x6A3xA1A4A1", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
711 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
712
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
713 return ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
714 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
715
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
716 # Generate TER record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
717 sub GenerateTerRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
718 my($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $Line) = ('') x 6;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
719
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
720 if (@_ == 5) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
721 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
722 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
723 elsif (@_ == 4) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
724 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
725 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
726 elsif (@_ == 3) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
727 ($SerialNumber, $ResidueName) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
728 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
729 elsif (@_ == 2) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
730 ($SerialNumber, $ResidueName) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
731 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
732 elsif (@_ == 1) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
733 ($SerialNumber) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
734 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
735 $Line = sprintf "TER %5.5s %-3.3s %1.1s%4.4s%1.1s", $SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
736
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
737 return $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
738 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
739
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
740 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
741 # Parse MASTER record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
742 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
743 # MASTER record format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
744 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
745 #1 - 6 Record name "MASTER"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
746 # 11 - 15 Number of REMARK records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
747 # 16 - 20 "0"
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
748 # 21 - 25 Number of HET records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
749 # 26 - 30 Number of HELIX records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
750 # 31 - 35 Number of SHEET records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
751 # 36 - 40 Number of TURN records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
752 # 41 - 45 Number of SITE records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
753 # 46 - 50 Number of coordinate transformation records (ORIGXn+SCALEn+MTRIXn)
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
754 # 51 - 55 Number of atomic coordinate records (ATOM+HETATM)
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
755 # 56 - 60 Number of TER records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
756 # 61 - 65 Number of CONECT records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
757 # 66 - 70 Number of SEQRES records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
758 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
759 sub ParseMasterRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
760 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
761
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
762 if ($Line !~ /^MASTER/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
763 return ((undef) x 11);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
764 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
765 my($NumOfRemarkRecords, $NumOfHetRecords, $NumOfHelixRecords, $NumOfSheetRecords, $NumOfTurnRecords, $NumOfSiteRecords, $NumOfTransformationsRecords, $NumOfAtomAndHetatmRecords, $NumOfTerRecords, $NumOfConectRecords, $NumOfSeqresRecords) = map {s/ //g; $_} unpack("x6x4A5x5A5A5A5A5A5A5A5A5A5A5", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
766
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
767 return ($NumOfRemarkRecords, $NumOfHetRecords, $NumOfHelixRecords, $NumOfSheetRecords, $NumOfTurnRecords, $NumOfSiteRecords, $NumOfTransformationsRecords, $NumOfAtomAndHetatmRecords, $NumOfTerRecords, $NumOfConectRecords, $NumOfSeqresRecords);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
768 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
769
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
770 # End record...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
771 sub GenerateEndRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
772 my($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
773 $Line = 'END ';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
774 return $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
775 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
776
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
777 # ATOM/HETATM record format:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
778 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
779 # 1 - 6 Record name
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
780 # 7 - 11 Atom serial number - right justified
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
781 # 13 - 16 Atom name
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
782 # 17 Alternate location indicator.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
783 # 18 - 20 Residue name - right justified
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
784 # 22 Chain identifier.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
785 # 23 - 26 Residue sequence number - right justified
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
786 # 27 Code for insertion of residues.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
787 # 31 - 38 Real(8.3), Orthogonal coordinates for X in Angstroms.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
788 # 39 - 46 Real(8.3), Orthogonal coordinates for Y in Angstroms.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
789 # 47 - 54 Real(8.3), Orthogonal coordinates for Z in Angstroms.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
790 # 55 - 60 Real(6.2), Occupancy
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
791 # 61 - 66 Real(6.2), Temperature factor
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
792 # 73 - 76 LString(4), Segment identifier, left-justified.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
793 # 77 - 78 LString(2), Element symbol, right-justified.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
794 #79 - 80 LString(2), Charge on the atom.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
795 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
796 # Notes:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
797 # . Atom names starting with C, N, O and S are left justified starting with column 14
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
798 # and others are left justified starting with column 13.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
799 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
800 # . Six characters (columns) are reserved for atom names, assigned as follows:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
801 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
802 # 13 - 14 Chemical symbol - right justified, except for hydrogen atoms
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
803 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
804 # And for amino acids:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
805 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
806 # 15 Remoteness indicator (alphabetic) (A, B, G, D, E, Z and so on)
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
807 # 16 Branch designator (numeric)
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
808 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
809 sub _ParseAtomOrHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
810 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
811
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
812 if ($Line !~ /^(ATOM|HETATM)/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
813 return ((undef) x 15);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
814 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
815 my($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge, $Length);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
816
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
817 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = ('') x 15;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
818
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
819 $Length = length $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
820
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
821 if ($Length <= 72) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
822 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor) = map {s/ //g; $_} unpack("x6A5xA4A1A3xA1A4A1x3A8A8A8A6A6", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
823 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
824 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
825 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = map {s/ //g; $_} unpack("x6A5xA4A1A3xA1A4A1x3A8A8A8A6A6x6A4A2A2", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
826 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
827 return($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
828 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
829
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
830 # Generate ATOM/HETATM record line...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
831 sub _GenerateAtomOrHetatmRecordLine {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
832 my($RecordType, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
833 my($Line, $AtomNameFormat);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
834
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
835 if (length($AtomName) >= 4) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
836 # Left justified starting at column 13 for all atom names of length 4...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
837 $AtomNameFormat = "%-4.4s";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
838 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
839 elsif (IsEmpty($ElementSymbol)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
840 # No element symbol specified; just guess from atom name to cover most likely cases...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
841 $AtomNameFormat = ($AtomName =~ /^(C|N|O|S)/i) ? " %-3.3s" : "%-4.4s";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
842 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
843 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
844 # Element symbol specified...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
845 if ($ElementSymbol =~ /^H$/i) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
846 # Hydrogen atom name with <=3 characters is left justified starting at column 14;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
847 # Otherwise, left justified starting at column 13.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
848 $AtomNameFormat = (length($AtomName) <= 3) ? " %-3.3s" : "%-4.4s";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
849 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
850 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
851 # Non-hydrogen atom name...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
852 $AtomNameFormat = (length($ElementSymbol) == 1) ? " %-3.3s" : "%-4.4s";
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
853 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
854 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
855
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
856 $Line = sprintf "%-6.6s%5.5s ${AtomNameFormat}%1.1s%3.3s %1.1s%4.4s%1.1s %8.8s%8.8s%8.8s%6.6s%6.6s %-4.4s%2.2s%2.2s", $RecordType, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
857
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
858 return $Line;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
859 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
860
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
861 # Check record type...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
862 sub _IsRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
863 my($Line, $SpecifiedType) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
864 my($Type, $Status);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
865
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
866 ($Type) = map {s/ //g; $_} unpack("A6", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
867
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
868 $Status = ($SpecifiedType eq $Type) ? 1 : 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
869
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
870 return $Status;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
871 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
872
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
873 # Get record type...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
874 sub _GetRecordType {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
875 my($Line) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
876 my($Type);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
877
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
878 ($Type) = map {s/ //g; $_} unpack("A6", $Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
879
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
880 return $Type;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
881 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
882
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
883 # Get chains and residues data using ATOM/HETATM records...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
884 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
885 sub _GetChainsAndResiduesFromAtomHetatmRecords {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
886 my($PDBRecordLinesRef, $GetChainResiduesBeyondTERFlag, $GetRecordLinesFlag) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
887
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
888 my($LineCount, $TotalChainCount, $PreviousResidueNumber, $ChainCount, $DefaultChainID, $DefaultChainLabel, $RecordLine, $AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge, %ChainsDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
889
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
890 # Do a quick chain count using TER record...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
891 $TotalChainCount = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
892 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
893 if (IsEndmdlRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
894 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
895 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
896 if (IsTerRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
897 $TotalChainCount++;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
898 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
899 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
900
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
901 %ChainsDataMap = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
902 @{$ChainsDataMap{ChainIDs}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
903 %{$ChainsDataMap{Residues}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
904 %{$ChainsDataMap{ResidueNumbers}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
905 %{$ChainsDataMap{Lines}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
906 %{$ChainsDataMap{ResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
907
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
908 $LineCount = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
909 $ChainCount = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
910 $DefaultChainLabel = 'None';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
911 $DefaultChainID = $DefaultChainLabel . ($ChainCount + 1);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
912 $PreviousResidueNumber = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
913
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
914 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
915 $LineCount++;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
916 if (IsTerRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
917 $DefaultChainID = $DefaultChainLabel . ($ChainCount + 1);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
918 $ChainCount++;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
919 if ($ChainCount == $TotalChainCount) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
920 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
921 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
922 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
923 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
924 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
925 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
926 elsif (!(IsAtomRecordType($RecordLine) || IsHetatmRecordType($RecordLine))) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
927 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
928 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
929 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = ParseAtomRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
930
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
931 if (IsEmpty($ChainID)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
932 $ChainID = $DefaultChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
933 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
934 if (exists $ChainsDataMap{Residues}{$ChainID}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
935 # Data for existing chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
936 if ($GetRecordLinesFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
937 push @{$ChainsDataMap{Lines}{$ChainID}}, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
938 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
939
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
940 if ($ResidueNumber != $PreviousResidueNumber) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
941 # Next residue with in the chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
942 push @{$ChainsDataMap{Residues}{$ChainID}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
943 push @{$ChainsDataMap{ResidueNumbers}{$ChainID}}, $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
944
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
945 if (exists $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
946 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
947 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
948 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
949 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
950 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
951 $PreviousResidueNumber = $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
952 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
953 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
954 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
955 # Data for new chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
956 push @{$ChainsDataMap{ChainIDs}}, $ChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
957
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
958 @{$ChainsDataMap{Residues}{$ChainID}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
959 push @{$ChainsDataMap{Residues}{$ChainID}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
960
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
961 @{$ChainsDataMap{ResidueNumbers}{$ChainID}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
962 push @{$ChainsDataMap{ResidueNumbers}{$ChainID}}, $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
963
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
964 @{$ChainsDataMap{Lines}{$ChainID}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
965 if ($GetRecordLinesFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
966 push @{$ChainsDataMap{Lines}{$ChainID}}, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
967 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
968
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
969 %{$ChainsDataMap{ResidueCount}{$ChainID}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
970 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
971 $PreviousResidueNumber = $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
972 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
973 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
974 if (!$GetChainResiduesBeyondTERFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
975 return \%ChainsDataMap;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
976 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
977 # Look for any HETATM residues specified outside TER records which could belong to an existing chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
978 my($LineIndex, $PreviousChainID);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
979 $PreviousChainID = '';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
980 $PreviousResidueNumber = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
981 LINE: for $LineIndex (($LineCount - 1) .. $#{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
982 $RecordLine = $PDBRecordLinesRef->[$LineIndex];
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
983 if (IsEndmdlRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
984 last LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
985 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
986 if (!(IsAtomRecordType($RecordLine) || IsHetatmRecordType($RecordLine))) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
987 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
988 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
989 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) = ParseAtomRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
990 if (IsEmpty($ChainID)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
991 # Ignore the chains with no ids...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
992 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
993 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
994 if (! exists($ChainsDataMap{Residues}{$ChainID})) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
995 # Don't collect any new chains after TER record...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
996 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
997 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
998 if ($GetRecordLinesFlag) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
999 push @{$ChainsDataMap{Lines}{$ChainID}}, $RecordLine;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1000 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1001 if ($ResidueNumber != $PreviousResidueNumber || $ChainID ne $PreviousChainID) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1002
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1003 push @{$ChainsDataMap{Residues}{$ChainID}}, $ResidueName;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1004 push @{$ChainsDataMap{ResidueNumbers}{$ChainID}}, $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1005
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1006 if (exists $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1007 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1008 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1009 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1010 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1011 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1012 $PreviousChainID = $ChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1013 $PreviousResidueNumber = $ResidueNumber;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1014 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1015 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1016 return \%ChainsDataMap;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1017 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1018
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1019 # Get chains and residues data using SEQRES records...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1020 #
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1021 sub _GetChainsAndResiduesFromSeqresRecords {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1022 my($PDBRecordLinesRef) = @_;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1023
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1024 my($ChainCount, $DefaultChainLabel, $DefaultChainID, $RecordLine, $RecordSerialNumber, $ChainID, $NumOfResidues, $ResidueName, $ResidueNamesString, @ResidueNamesList, %ChainsDataMap);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1025
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1026 %ChainsDataMap = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1027 @{$ChainsDataMap{ChainIDs}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1028 %{$ChainsDataMap{Residues}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1029 %{$ChainsDataMap{ResidueNumbers}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1030 %{$ChainsDataMap{ResidueCount}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1031
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1032 $ChainCount = 0;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1033 $DefaultChainLabel = 'None';
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1034 $DefaultChainID = $DefaultChainLabel . ($ChainCount + 1);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1035
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1036 LINE: for $RecordLine (@{$PDBRecordLinesRef}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1037 if (!IsSeqresRecordType($RecordLine)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1038 next LINE;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1039 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1040 ($RecordSerialNumber, $ChainID, $NumOfResidues, $ResidueNamesString) = ParseSeqresRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1041 if ($RecordSerialNumber == 1) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1042 # Indicates start of a new chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1043 $DefaultChainID = $DefaultChainLabel . ($ChainCount + 1);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1044 $ChainCount++;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1045 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1046 if (IsEmpty($ChainID)) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1047 $ChainID = $DefaultChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1048 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1049 # Process the residues...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1050 @ResidueNamesList = split /[ ]+/, $ResidueNamesString;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1051
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1052 if (exists $ChainsDataMap{Residues}{$ChainID}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1053 # Data for existing chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1054 push @{$ChainsDataMap{Residues}{$ChainID}}, @ResidueNamesList;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1055 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1056 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1057 # Data for new chain...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1058 push @{$ChainsDataMap{ChainIDs}}, $ChainID;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1059 @{$ChainsDataMap{Residues}{$ChainID}} = ();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1060 push @{$ChainsDataMap{Residues}{$ChainID}}, @ResidueNamesList;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1061 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1062
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1063 # Setup residue count...
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1064 for $ResidueName (@ResidueNamesList) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1065 if (exists $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName}) {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1066 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} += 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1067 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1068 else {
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1069 $ChainsDataMap{ResidueCount}{$ChainID}{$ResidueName} = 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1070 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1071 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1072 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1073 return \%ChainsDataMap;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1074 }
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1075
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1076 1;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1077
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1078 __END__
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1079
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1080 =head1 NAME
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1081
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1082 PDBFileUtil
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1083
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1084 =head1 SYNOPSIS
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1085
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1086 use PDBFileUtil ;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1087
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1088 use PDBFileUtil qw(:all);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1089
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1090 =head1 DESCRIPTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1091
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1092 B<PDBFileUtil> module provides the following functions:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1093
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1094 GenerateAtomOrHetatmRecordLine, GenerateAtomRecordLine, GenerateConectRecordLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1095 GenerateEndRecordLine, GenerateHeaderRecordLine, GenerateHeaderRecordTimeStamp,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1096 GenerateHetatmRecordLine, GenerateTerRecordLine, GetAllResidues,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1097 GetChainsAndResidues, GetConectRecordLines, GetExperimentalTechnique,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1098 GetExperimentalTechniqueResolution, GetMinMaxCoords, GetPDBRecordType,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1099 GetRecordTypesCount, IsAtomRecordType, IsConectRecordType, IsEndmdlRecordType,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1100 IsHeaderRecordType, IsHetatmRecordType, IsMasterRecordType, IsModelRecordType,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1101 IsPDBFile, IsSeqresRecordType, IsTerRecordType, ParseAtomOrHetatmRecordLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1102 ParseAtomRecordLine, ParseConectRecordLine, ParseExpdtaRecordLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1103 ParseHeaderRecordLine, ParseHetatmRecordLine, ParseMasterRecordLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1104 ParseRemark2ResolutionRecordLine, ParseSeqresRecordLine, ParseTerRecordLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1105 ReadPDBFile
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1106
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1107 =head1 METHODS
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1108
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1109 =over 4
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1110
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1111 =item B<GenerateAtomOrHetatmRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1112
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1113 $RecordLine = GenerateAtomOrHetatmRecordLine($RecordType,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1114 $AtomNumber, $AtomName, $AlternateLocation, $ResidueName,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1115 $ChainID, $ResidueNumber, $InsertionCode, $X, $Y, $Z,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1116 $Occupancy, $TemperatureFactor, $SegmentID,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1117 $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1118
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1119 Returns ATOM or HETATM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1120
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1121 =item B<GenerateAtomRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1122
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1123 $RecordLine = GenerateAtomRecordLine($AtomNumber,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1124 $AtomName, $AlternateLocation, $ResidueName, $ChainID,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1125 $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1126 $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1127
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1128 Returns ATOM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1129
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1130 =item B<GenerateConectRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1131
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1132 $RecordLine = GenerateConectRecordLine($AtomNum, $BondedAtomNum1,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1133 $BondedAtomNum2, $BondedAtomNum3, $BondedAtomNum4,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1134 $HBondedAtomNum1, $HBondedAtomNum2, $SaltBridgedAtomNum1,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1135 $HBondedAtomNum3, $HBondedAtomNum4, $SaltBridgedAtomNum2);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1136
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1137 Returns CONECT record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1138
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1139 =item B<GenerateHeaderRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1140
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1141 $RecordLine = GenerateHeaderRecordLine($IDCode, [$Classification,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1142 $Date]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1143
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1144 Returns HEADER record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1145
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1146 =item B<GenerateHeaderRecordTimeStamp>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1147
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1148 $Date = GenerateHeaderRecordTimeStamp();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1149
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1150 Returns PDB header time stamp.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1151
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1152 =item B<GenerateHetatmRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1153
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1154 $RecordLine = GenerateHetatmRecordLine($AtomNumber, $AtomName,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1155 $AlternateLocation, $ResidueName, $ChainID, $ResidueNumber,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1156 $InsertionCode, $X, $Y, $Z, $Occupancy, $TemperatureFactor,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1157 $SegmentID, $ElementSymbol, $AtomCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1158
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1159 Returns HETATM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1160
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1161 =item B<GenerateEndRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1162
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1163 $RecordLine = GenerateEndRecordLine();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1164
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1165 Returns END record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1166
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1167 =item B<GenerateTerRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1168
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1169 $RecordLine = GenerateTerRecordLine($SerialNumber, [$ResidueName,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1170 $ChainID, $ResidueNumber, $InsertionCode]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1171
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1172 Returns TER record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1173
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1174 =item B<GetAllResidues>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1175
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1176 $ResiduesDataRef = GetAllResidues($PDBRecordLinesRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1177
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1178 Gets residue information using ATOM/HETATM records and returns a reference to a hash with
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1179 following key/value pairs:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1180
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1181 $ResiduesDataRef->{ResidueNames} - Array of all the residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1182 $ResiduesDataRef->{ResidueCount}{$ResidueName} - Count of residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1183 $ResiduesDataRef->{AtomResidueNames}} - Array of all ATOM residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1184 $ResiduesDataRef->{AtomResidueCount}{$ResidueName} - Count of
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1185 residues in ATOM records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1186 $ResiduesDataRef->{HetatomResidueNames} - List of all HETATM
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1187 residues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1188 $ResiduesDataRef->{HetatmResidueCount}{$ResidueName} - Count of
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1189 residues HETATM records
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1190
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1191 ATOM/HETATM records after the first ENDMDL records are simply ingnored.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1192
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1193 =item B<GetChainsAndResidues>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1194
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1195 $ChainsDataRef = GetChainsAndResidues($PDBRecordLinesRef,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1196 [$RecordsSource, $GetChainResiduesBeyondTERFlag,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1197 $GetRecordLinesFlag]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1198
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1199 Gets chains and residue information using ATOM/HETATM or SEQRES records and returns a reference to a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1200 hash with these keys:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1201
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1202 $ChainsDataRef->{ChainIDs} - List of chain IDs with 'None' for
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1203 no IDs
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1204 $ChainsDataRef->{Residues}{$ChainID} - List of residues in order
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1205 of their appearance in a chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1206 $ChainsDataRef->{ResidueCount}{$ChainID}{$ResidueName} - Count of
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1207 residues in a chain
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1208
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1209 Chains and residue data can be extacted using either ATOM/HETATM records or SEQRES records.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1210 ATOM/HETATM records after the first ENDMDL records are simply ingnored.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1211
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1212 =item B<GetConectRecordLines>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1213
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1214 $ConectRecordLinesRef = GetConectRecordLines($PDBRecordLinesRef,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1215 $AtomNumbersMapRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1216
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1217 Collects CONECT record lines for specific atom number, modified specified data to exclude any atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1218 number not present in the list of specified atom numbers and returns a reference to list of
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1219 CONECT record lines.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1220
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1221 =item B<GetExperimentalTechnique>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1222
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1223 $ExperimentalTechnique = GetExperimentalTechnique($PDBRecordLinesRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1224
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1225 Returns I<ExperimentalTechnique> value retrieved from EXPDATA record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1226
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1227 =item B<GetExperimentalTechniqueResolution>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1228
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1229 ($Resolution, $ResolutionUnits) = GetExperimentalTechniqueResolution(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1230 $PDBRecordLinesRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1231
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1232 Returns I<Resolution> and I<ResolutionUnits> values from REMARK 2 RESOLUTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1233 record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1234
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1235 =item B<GetMinMaxCoords>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1236
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1237 ($XMin, $YMin, $ZMin, $XMax, $YMax, $ZMax) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1238 GetMinMaxCoords($PDBRecordLinesRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1239
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1240 Returns minimum and maximum XYZ coordinates for ATOM/HETATM records.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1241
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1242 =item B<GetPDBRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1243
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1244 $RecordType = GetPDBRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1245
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1246 Returns type of I<RecordLine>.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1247
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1248 =item B<GetRecordTypesCount>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1249
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1250 $RecordTypeDataRef = GetRecordTypesCount($PDBRecordLinesRef,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1251 [$SpecifiedRecordType, $GetRecordLinesFlag]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1252
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1253 Counts the number of each record type or a $SpecifiedRecordType and returns a reference to data
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1254 type with following key/value pairs:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1255
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1256 $RecordTypeDataRef->{RecordTypes} - An array of unique record types
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1257 in order of their presence in the file
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1258 $RecordTypeDataRef->{Count}{$RecordType} - Count of each record type
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1259 $RecordTypeDataRef->{Lines}{$RecordType} - Optional lines data for a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1260 specific record type.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1261
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1262 =item B<IsAtomRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1263
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1264 $Status = IsAtomRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1265
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1266 Returns 1 or 0 based on whether it's a ATOM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1267
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1268 =item B<IsConectRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1269
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1270 $Status = IsAtomConectType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1271
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1272 Returns 1 or 0 based on whether it's a CONECT record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1273
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1274 =item B<IsEndmdlRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1275
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1276 $Status = IsEndmdlRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1277
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1278 Returns 1 or 0 based on whether it's a ENDMDL a record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1279
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1280 =item B<IsHeaderRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1281
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1282 $Status = IsHeaderRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1283
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1284 Returns 1 or 0 based on whether it's a HEADER a record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1285
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1286 =item B<IsHetatmRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1287
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1288 $Status = IsHetatmRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1289
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1290 Returns 1 or 0 based on whether it's a HETATM a record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1291
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1292 =item B<IsMasterRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1293
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1294 $Status = IsMasterRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1295
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1296 Returns 1 or 0 based on whether it's a MASTER a record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1297
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1298 =item B<IsModelRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1299
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1300 $Status = IsModelRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1301
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1302 Returns 1 or 0 based on whether it's a MODEL record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1303
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1304 =item B<IsPDBFile>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1305
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1306 $Status = IsPDBFile($PDBFile);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1307
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1308 Returns 1 or 0 based on whether it's a PDB file.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1309
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1310 =item B<IsSeqresRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1311
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1312 $Status = IsSeqresRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1313
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1314 Returns 1 or 0 based on whether it's SEQRES a record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1315
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1316 =item B<IsTerRecordType>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1317
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1318 $Status = IsTerRecordType($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1319
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1320 Returns 1 or 0 based on whether it's a TER record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1321
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1322 =item B<ParseAtomOrHetatmRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1323
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1324 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1325 $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1326 $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1327 ParseAtomOrHetatmRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1328
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1329 Parses ATOM or HETATM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1330
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1331 =item B<ParseAtomRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1332
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1333 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1334 $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1335 $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1336 ParseAtomRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1337
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1338 Parses ATOM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1339
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1340 =item B<ParseConectRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1341
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1342 ($AtomNum, $BondedAtomNum1, $BondedAtomNum2, $BondedAtomNum3,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1343 $BondedAtomNum4, $HBondedAtomNum1, $HBondedAtomNum2,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1344 $SaltBridgedAtomNum1, $HBondedAtomNum3, $HBondedAtomNum4,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1345 $SaltBridgedAtomNum2) = ParseConectRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1346
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1347 Parses CONECT record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1348
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1349 =item B<ParseExpdtaRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1350
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1351 ($ContinuationNum, $ExperimentalTechnique) = ParseExpdtaRecordLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1352
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1353 Parses EXPDTA record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1354
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1355 =item B<ParseHeaderRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1356
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1357 ($Classification, $DepositionDate, $IDCode) = ParseHeaderRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1358
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1359 Parses HEADER record line
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1360
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1361 =item B<ParseHetatmRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1362
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1363 ($AtomNumber, $AtomName, $AlternateLocation, $ResidueName, $ChainID,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1364 $ResidueNumber, $InsertionCode, $X, $Y, $Z, $Occupancy,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1365 $TemperatureFactor, $SegmentID, $ElementSymbol, $AtomCharge) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1366 ParseHetatmRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1367
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1368 Parses HETATM record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1369
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1370 =item B<ParseMasterRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1371
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1372 ($NumOfRemarkRecords, $NumOfHetRecords, $NumOfHelixRecords,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1373 $NumOfSheetRecords, $NumOfTurnRecords, $NumOfSiteRecords,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1374 $NumOfTransformationsRecords, $NumOfAtomAndHetatmRecords,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1375 $NumOfTerRecords, $NumOfConectRecords, $NumOfSeqresRecords) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1376 ParseMasterRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1377
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1378 Parses MASTER ecord line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1379
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1380 =item B<ParseRemark2ResolutionRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1381
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1382 ($Resolution, $ResolutionUnits) = ParseRemark2ResolutionRecordLine(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1383 $RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1384
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1385 Parses REMARK 2 RESOLUTION record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1386
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1387 =item B<ParseSeqresRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1388
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1389 ($RecordSerialNumber, $ChainID, $NumOfResidues, $ResidueNames) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1390 ParseSeqresRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1391
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1392 Parses SEQRES record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1393
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1394 =item B<ParseTerRecordLine>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1395
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1396 ($SerialNumber, $ResidueName, $ChainID, $ResidueNumber, $InsertionCode) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1397 ParseTerRecordLine($RecordLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1398
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1399 Parses TER record line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1400
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1401 =item B<ReadPDBFile>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1402
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1403 $PDBRecordLinesRef = ReadPDBFile($PDBFile);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1404
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1405 Reads PDB file and returns reference to record lines.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1406
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1407 =back
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1408
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1409 =head1 AUTHOR
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1410
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1411 Manish Sud <msud@san.rr.com>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1412
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1413 =head1 SEE ALSO
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1414
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1415 FileUtil.pm, SequenceFileUtil.pm, TextUtil.pm
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1416
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1417 =head1 COPYRIGHT
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1418
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1419 Copyright (C) 2015 Manish Sud. All rights reserved.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1420
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1421 This file is part of MayaChemTools.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1422
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1423 MayaChemTools is free software; you can redistribute it and/or modify it under
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1424 the terms of the GNU Lesser General Public License as published by the Free
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1425 Software Foundation; either version 3 of the License, or (at your option)
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1426 any later version.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1427
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
1428 =cut