annotate mayachemtool/mayachemtools/docs/modules/txt/SDFileUtil.txt @ 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 NAME
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
2 SDFileUtil
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
3
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
4 SYNOPSIS
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
5 use SDFileUtil ;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
6
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
7 use SDFileUtil qw(:all);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
8
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
9 DESCRIPTION
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
10 SDFileUtil module provides the following functions:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
11
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
12 GenerateCmpdAtomAliasPropertyLines, GenerateCmpdAtomLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
13 GenerateCmpdBondLine, GenerateCmpdChargePropertyLines,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
14 GenerateCmpdCommentsLine, GenerateCmpdCountsLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
15 GenerateCmpdDataHeaderLabelsAndValuesLines,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
16 GenerateCmpdIsotopePropertyLines, GenerateCmpdMiscInfoLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
17 GenerateCmpdMolNameLine, GenerateCmpdRadicalPropertyLines,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
18 GenerateEmptyCtabBlockLines, GenerateMiscLineDateStamp,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
19 GetAllAndCommonCmpdDataHeaderLabels, GetCmpdDataHeaderLabels,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
20 GetCmpdDataHeaderLabelsAndValues, GetCmpdFragments, GetCtabLinesCount,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
21 GetInvalidAtomNumbers, GetUnknownAtoms, InternalBondOrderToMDLBondType,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
22 InternalBondStereochemistryToMDLBondStereo, InternalChargeToMDLCharge,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
23 InternalSpinMultiplicityToMDLRadical, IsCmpd2D, IsCmpd3D,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
24 MDLBondStereoToInternalBondStereochemistry,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
25 MDLBondTypeToInternalBondOrder, MDLChargeToInternalCharge,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
26 MDLRadicalToInternalSpinMultiplicity, ParseCmpdAtomAliasPropertyLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
27 ParseCmpdAtomLine, ParseCmpdBondLine, ParseCmpdChargePropertyLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
28 ParseCmpdCommentsLine, ParseCmpdCountsLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
29 ParseCmpdIsotopePropertyLine, ParseCmpdMiscInfoLine,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
30 ParseCmpdMolNameLine, ParseCmpdRadicalPropertyLine, ReadCmpdString,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
31 RemoveCmpdDataHeaderLabelAndValue, WashCmpd
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
32
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
33 METHODS
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
34 GenerateCmpdAtomAliasPropertyLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
35 @Lines = GenerateCmpdAtomAliasPropertyLines($AliasValuePairsRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
36
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
37 Returns a formatted atom alias property lines corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
38 successive pairs of atom number and alias values specified by a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
39 refernce to an array. Two lines are generate for each atom number
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
40 and alias value pairs: First line - A <AtomNum>; Second
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
41 line:<AtomAlias>.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
42
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
43 GenerateCmpdAtomLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
44 $Line = GenerateCmpdAtomLine($AtomSymbol, $AtomX, $AtomY,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
45 $AtomZ, [$MassDifference, $Charge, $StereoParity]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
46
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
47 Returns a formatted atom data line containing all the input values.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
48
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
49 GenerateCmpdBondLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
50 $Line = GenerateCmpdBondLine($FirstAtomNum, $SecondAtomNum,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
51 $BondType, [$BondStereo]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
52
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
53 Returns a formatted bond data line containing all the input values.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
54
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
55 GenerateCmpdChargePropertyLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
56 @Lines = GenerateCmpdChargePropertyLines($ChargeValuePairsRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
57
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
58 Returns a formatted M CHG property lines corresponding to successive
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
59 pairs of atom number and charge values specified by a refernce to an
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
60 array.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
61
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
62 GenerateCmpdCommentsLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
63 $Line = GenerateCmpdCommentsLine($Comments);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
64
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
65 Returns a formatted comments data line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
66
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
67 GenerateCmpdCountsLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
68 $Line = GenerateCmpdCountsLine($AtomCount, $BondCount,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
69 $ChiralFlag, [$PropertyCount, $Version]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
70
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
71 Returns a formatted line containing all the input values. The
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
72 default values of 999 and V2000 are used for *PropertyCount* and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
73 *Version*.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
74
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
75 GenerateCmpdDataHeaderLabelsAndValuesLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
76 @Lines = GenerateCmpdDataHeaderLabelsAndValuesLines(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
77 $DataHeaderLabelsRef, $DataHeaderLabelsAndValuesRef,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
78 [$SortDataLabels]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
79
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
80 Returns formatted data lines containing header label and values
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
81 lines corresponding to all data header labels in array reference
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
82 *DataHeaderLabelsRef* with values in hash reference
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
83 *DataHeaderLabelsAndValuesRef*. By default, data header labels are
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
84 not sorted and correspond to the label order in array reference
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
85 *DataHeaderLabelsRef*.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
86
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
87 GenerateCmpdIsotopePropertyLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
88 @Lines = GenerateCmpdIsotopePropertyLines($IsotopeValuePairsRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
89
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
90 Returns a formatted M ISO property lines corresponding to successive
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
91 pairs of atom number and isotope values specified by a refernce to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
92 an array.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
93
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
94 GenerateCmpdMiscInfoLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
95 $Line = GenerateCmpdMiscInfoLine([$ProgramName, $UserInitial,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
96 $Code]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
97
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
98 Returns a formatted line containing specified user initial, program
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
99 name, date and code. Default values are: *ProgramName - MayaChem;
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
100 UserInitial - NULL; Code - 2D*.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
101
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
102 GenerateCmpdMolNameLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
103 $Line = GenerateCmpdMolNameLine($MolName);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
104
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
105 Returns a formatted molecule name data line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
106
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
107 GenerateCmpdRadicalPropertyLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
108 @Lines = GenerateCmpdRadicalPropertyLines($RadicalValuePairsRef);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
109
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
110 Returns a formatted M CHG property lines corresponding to successive
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
111 pairs of atom number and multiplicity values specified by a refernce
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
112 to an array.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
113
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
114 GenerateEmptyCtabBlockLines
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
115 $Lines = GenerateCmpdMiscInfoLine([$Date]);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
116
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
117 Returns formatted lines representing empty CTAB block.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
118
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
119 GenerateMiscLineDateStamp
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
120 $Line = GenerateMiscLineDateStamp();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
121
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
122 Returns date stamp for misc line.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
123
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
124 GetAllAndCommonCmpdDataHeaderLabels
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
125 ($CmpdCount, $DataFieldLabelsArrayRef,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
126 $CommonDataFieldLabelsArrayRef) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
127 GetAllAndCommonCmpdDataHeaderLabels(\*SDFILE);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
128
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
129 Returns number of comopunds, a reference to an array containing all
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
130 unique data header label and a reference to an array containing
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
131 common data field labels for all compounds in SD file.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
132
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
133 GetCmpdDataHeaderLabels
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
134 (@Labels) = GetCmpdDataHeaderLabels(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
135
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
136 Returns an array containg data header labels for a compound
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
137
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
138 GetCmpdDataHeaderLabelsAndValues
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
139 (%DataValues) = GetCmpdDataHeaderLabelsAndValues(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
140
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
141 Returns a hash conating data header labes and values for a compound.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
142
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
143 GetCmpdFragments
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
144 ($FragmentCount, $FragmentString) = GetCmpdFragments(\@CmpLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
145
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
146 Figures out the number of disconnected fragments and return their
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
147 values along with the atom numbers in a string delimited by new line
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
148 character. Fragment data in FragmentString is sorted on based on its
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
149 size.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
150
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
151 GetCtabLinesCount
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
152 $CtabLinesCount = GetCtabLinesCount(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
153
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
154 Returns number of lines present between the 4th line and the line
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
155 containg "M END".
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
156
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
157 GetInvalidAtomNumbers
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
158 ($InvalidAtomNumbersCount, $InvalidAtomNumbers, $InvalidAtomNumberLines) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
159 GetInvalidAtomNumbers(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
160
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
161 Returns a list of values containing information about invalid atom
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
162 numbers present in block or atom property lines.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
163
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
164 GetUnknownAtoms
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
165 ($UnknownAtomCount, $UnknownAtoms, $UnknownAtomLines) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
166 GetUnknownAtoms(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
167
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
168 Returns a list of values containing information about atoms which
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
169 contain special element symbols not present in the periodic table.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
170
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
171 InternalBondOrderToMDLBondType
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
172 $MDLBondType = InternalBondOrderToMDLBondType($InternalBondOrder);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
173
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
174 Returns value of *MDLBondType* corresponding to *InternalBondOrder*.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
175
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
176 InternalBondOrder MDLBondType
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
177
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
178 1 1
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
179 2 2
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
180 3 3
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
181 1.5 4
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
182
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
183 InternalBondStereochemistryToMDLBondStereo
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
184 $MDLBondStereo = InternalBondStereochemistryToMDLBondStereo(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
185 $InternalBondStereo);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
186
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
187 Returns value of *MDLBondStereo* corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
188 *InternalBondStereo* using following mapping:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
189
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
190 InternalBondStereo MDLBondStereo
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
191
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
192 Up 1
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
193 UpOrDown 4
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
194 Down 6
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
195 CisOrTrans 3
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
196 Other 0
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
197
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
198 InternalChargeToMDLCharge
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
199 $MDLCharge = InternalChargeToMDLCharge($InternalCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
200
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
201 Returns value of *MDLCharge* corresponding to *InternalCharge* using
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
202 following mapping:
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
203
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
204 InternalCharge MDLCharge
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
205
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
206 3 1
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
207 2 2
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
208 1 3
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
209 -1 5
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
210 -2 6
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
211 -3 7
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
212
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
213 InternalSpinMultiplicityToMDLRadical
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
214 $MDLRadical = InternalSpinMultiplicityToMDLRadical(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
215 $InternalSpinMultiplicity);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
216
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
217 Returns value of *MDLRadical* corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
218 *InternalSpinMultiplicity*. These value are equivalent.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
219
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
220 MDLBondStereoToInternalBondType
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
221 $InternalBondType = MDLBondStereoToInternalBondType($MDLBondStereo);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
222
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
223 Returns value of *InternalBondType* corresponding to *MDLBondStereo*
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
224 using mapping shown for InternalBondTypeToMDLBondStereo function.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
225
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
226 IsCmpd2D
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
227 $Status = IsCmpd2D();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
228
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
229 Returns 1 or 0 based on whether z-coordinate of any atom is
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
230 non-zero.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
231
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
232 IsCmpd3D
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
233 $Status = IsCmpd3D();
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
234
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
235 Returns 1 or 0 based on whether z-coordinate of any atom is
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
236 non-zero.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
237
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
238 MDLBondStereoToInternalBondStereochemistry
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
239 $InternalBondStereo = MDLBondStereoToInternalBondStereochemistry(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
240 $MDLBondStereo);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
241
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
242 Returns value of *InternalBondStereo* corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
243 *MDLBondStereo* using mapping shown for
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
244 InternalBondStereochemistryToMDLBondStereo function.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
245
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
246 MDLBondTypeToInternalBondOrder
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
247 $InternalBondOrder = MDLBondTypeToInternalBondOrder($MDLBondType);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
248
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
249 Returns value of *InternalBondOrder* corresponding to *MDLBondType*
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
250 using mapping shown for InternalBondOrderToMDLBondType function.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
251
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
252 MDLChargeToInternalCharge
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
253 $InternalCharge = MDLChargeToInternalCharge($MDLCharge);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
254
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
255 Returns value of *$InternalCharge* corresponding to *MDLCharge*
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
256 using mapping shown for InternalChargeToMDLCharge function.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
257
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
258 MDLRadicalToInternalSpinMultiplicity
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
259 $InternalSpinMultiplicity = MDLRadicalToInternalSpinMultiplicity(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
260 $MDLRadical);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
261
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
262 Returns value of *InternalSpinMultiplicity* corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
263 *MDLRadical*. These value are equivalent.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
264
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
265 ParseCmpdAtomAliasPropertyLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
266 @AtomNumAndValuePairs = ParseCmpdAtomAliasPropertyLine(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
267 $CurrentLine, $NexLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
268
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
269 Parses atom alias propery lines in CTAB generic properties block and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
270 returns an array with successive pairs of values corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
271 atom number and its alias.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
272
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
273 ParseCmpdAtomLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
274 ($AtomSymbol, $AtomX, $AtomY, $AtomZ, $MassDifference, $Charge,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
275 $StereoParity) = ParseCmpdAtomLine($AtomDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
276
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
277 Parses compound data line containing atom information and returns a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
278 list of values.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
279
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
280 ParseCmpdBondLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
281 ($FirstAtomNum, $SecondAtomNum, $BondType) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
282 ParseCmpdBondLine($BondDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
283
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
284 Parses compound data line containing bond information and returns a
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
285 list of values.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
286
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
287 ParseCmpdCommentsLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
288 $Comments = ParseCmpdCommentsLine($CommentsDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
289
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
290 Returns the comment string.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
291
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
292 ParseCmpdChargePropertyLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
293 @AtomNumAndValuePairs = ParseCmpdChargePropertyLine(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
294 $ChargeDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
295
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
296 Parses charge propery line in CTAB generic properties block and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
297 returns an array with successive pairs of values corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
298 atom number and its charge.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
299
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
300 ParseCmpdCountsLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
301 ($AtomCount, $BondCount, $ChiralFlag, $PropertyCount, $Version) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
302 ParseCmpdCountsLine(\@CountDataLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
303
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
304 Returns a list of values containing count information.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
305
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
306 ParseCmpdMiscInfoLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
307 ($UserInitial, $ProgramName, $Date, $Code, $ScalingFactor1, $ScalingFactor2,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
308 $Energy, $RegistryNum) = ParseCmpdMiscInfoLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
309
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
310 Returns a list of values containing miscellaneous information.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
311
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
312 ParseCmpdIsotopePropertyLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
313 @AtomNumAndValuePairs = ParseCmpdIsotopePropertyLine(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
314 $IsotopeDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
315
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
316 Parses isotopic propery line in CTAB generic properties block and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
317 returns an array with successive pairs of values corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
318 atom number and absolute mass of atom isotope.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
319
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
320 ParseCmpdMolNameLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
321 $MolName = ParseCmpdMolNameLine($Line);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
322
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
323 Returns a string containing molecule name.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
324
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
325 ParseCmpdRadicalPropertyLine
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
326 @AtomNumAndValuePairs = ParseCmpdRadicalPropertyLine(
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
327 $RadicalDataLine);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
328
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
329 Parses radical propery line in CTAB generic properties block and
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
330 returns an array with successive pairs of values corresponding to
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
331 atom number and radical number value.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
332
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
333 RemoveCmpdDataHeaderLabelAndValue
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
334 $NewCmpdString = RemoveCmpdDataHeaderLabelAndValue($CmpdString,
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
335 $DataHeaderLabel);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
336
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
337 Returns a NewCmpdString after removing *DataHeaderLabel* along with
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
338 its value from *CmpdString*.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
339
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
340 ReadCmpdString
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
341 $CmpdString = ReadCmpdString(\*SDFILEHANDLE);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
342
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
343 Returns a string containing all the data lines for the next
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
344 available compound in an already open file indicated by
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
345 SDFILEHANDLE. A NULL string is returned on EOF.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
346
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
347 WashCmpd
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
348 ($FragmentCount, $Fragments, $WashedCmpdString) =
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
349 WashCmpd(\@CmpdLines);
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
350
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
351 Figures out the number of disconnected fragments and return their
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
352 values along with the atom numbers in a string delimited by new line
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
353 character. Fragment data in FragmentString is sorted on based on its
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
354 size.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
355
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
356 AUTHOR
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
357 Manish Sud <msud@san.rr.com>
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
358
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
359 SEE ALSO
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
360 TextUtil.pm
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
361
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
362 COPYRIGHT
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
363 Copyright (C) 2015 Manish Sud. All rights reserved.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
364
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
365 This file is part of MayaChemTools.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
366
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
367 MayaChemTools is free software; you can redistribute it and/or modify it
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
368 under the terms of the GNU Lesser General Public License as published by
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
369 the Free Software Foundation; either version 3 of the License, or (at
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
370 your option) any later version.
a4a2ad5a214e Uploaded
deepakjadmin
parents:
diff changeset
371