annotate mayachemtools/docs/modules/html/SDFileIO.html @ 0:73ae111cf86f draft

Uploaded
author deepakjadmin
date Wed, 20 Jan 2016 11:55:01 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
1 <html>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
2 <head>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
3 <title>MayaChemTools:Documentation:FileIO::SDFileIO.pm</title>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
4 <meta http-equiv="content-type" content="text/html;charset=utf-8">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
5 <link rel="stylesheet" type="text/css" href="../../css/MayaChemTools.css">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
6 </head>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
7 <body leftmargin="20" rightmargin="20" topmargin="10" bottommargin="10">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
8 <br/>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
9 <center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
10 <a href="http://www.mayachemtools.org" title="MayaChemTools Home"><img src="../../images/MayaChemToolsLogo.gif" border="0" alt="MayaChemTools"></a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
11 </center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
12 <br/>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
13 <div class="DocNav">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
14 <table width="100%" border=0 cellpadding=0 cellspacing=2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
15 <tr align="left" valign="top"><td width="33%" align="left"><a href="./MDLMolFileIO.html" title="MDLMolFileIO.html">Previous</a>&nbsp;&nbsp;<a href="./index.html" title="Table of Contents">TOC</a>&nbsp;&nbsp;<a href="./FileUtil.html" title="FileUtil.html">Next</a></td><td width="34%" align="middle"><strong>FileIO::SDFileIO.pm</strong></td><td width="33%" align="right"><a href="././code/SDFileIO.html" title="View source code">Code</a>&nbsp;|&nbsp;<a href="./../pdf/SDFileIO.pdf" title="PDF US Letter Size">PDF</a>&nbsp;|&nbsp;<a href="./../pdfgreen/SDFileIO.pdf" title="PDF US Letter Size with narrow margins: www.changethemargins.com">PDFGreen</a>&nbsp;|&nbsp;<a href="./../pdfa4/SDFileIO.pdf" title="PDF A4 Size">PDFA4</a>&nbsp;|&nbsp;<a href="./../pdfa4green/SDFileIO.pdf" title="PDF A4 Size with narrow margins: www.changethemargins.com">PDFA4Green</a></td></tr>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
16 </table>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
17 </div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
18 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
19 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
20 <h2>NAME</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
21 <p>SDFileIO</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
22 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
23 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
24 <h2>SYNOPSIS</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
25 <p>use FileIO::SDFileIO;</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
26 <p>use FileIO::SDFileIO qw(:all);</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
27 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
28 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
29 <h2>DESCRIPTION</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
30 <p><strong>SDFIleIO</strong> class provides the following methods:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
31 <p> <a href="#new">new</a>, <a href="#generatemoleculestring">GenerateMoleculeString</a>, <a href="#issdfile">IsSDFile</a>, <a href="#parsemoleculestring">ParseMoleculeString</a>, <a href="#readmolecule">ReadMolecule</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
32 , <a href="#readmoleculestring">ReadMoleculeString</a>, <a href="#writemolecule">WriteMolecule</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
33 </p><p>The following methods can also be used as functions:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
34 <p>GenerateMoleculeString, IsSDFile, ParseMoleculeString</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
35 <p>Data specific to <strong>SDFileIO</strong> class not directly used by <strong>Molecule</strong>, <strong>Atom</strong> and
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
36 <strong>Bond</strong> objects - data label/value pairs, atom SteroParity and so on - is associated to
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
37 and retrieved from approptiate objects using following methods:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
38 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
39 SetMDL&lt;PropertyName&gt;
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
40 <br/> GetMDL&lt;PropertyName&gt;.</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
41 <p>SD data label and values are attached to <strong>Molecule</strong> object as a refernece to a hash
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
42 using SetDataFieldLabelAndValues and can be retrieved using GetDataFieldLabelAndValues
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
43 method.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
44 <p><strong>SDFileIO</strong> class is derived from <em>FileIO</em> class and uses its methods to support
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
45 generic file related functionality.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
46 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
47 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
48 <h2>METHODS</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
49 <dl>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
50 <dt><strong><a name="new" class="item"><strong>new</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
51 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
52 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
53 $NewSDFileIO = new FileIO::SDFileIO(%NamesAndValues);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
54 <p>Using specified <em>SDFileIO</em> property names and values hash, <strong>new</strong> method creates a new object
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
55 and returns a reference to newly created <strong>SDFileIO</strong> object.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
56 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
57 <dt><strong><a name="generatemoleculestring" class="item"><strong>GenerateMoleculeString</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
58 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
59 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
60 $MoleculeString = $SDFileIO-&gt;GenerateMoleculeString($Molecule);
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
61 <br/> $MoleculeString = FileIO::SDFileIO::GenerateMoleculeString($Molecule);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
62 <p>Returns a <strong>MoleculeString</strong> in SD format corresponding to <em>Molecule</em>.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
63 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
64 <dt><strong><a name="issdfile" class="item"><strong>IsSDFile</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
65 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
66 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
67 $Status = $SDFileIO-&gt;IsSDFile($FileName);
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
68 <br/> $Status = FileIO::SDFileIO::IsSDFile($FileName);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
69 <p>Returns 1 or 0 based on whether <em>FileName</em> is a SD file.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
70 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
71 <dt><strong><a name="parsemoleculestring" class="item"><strong>ParseMoleculeString</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
72 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
73 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
74 $Molecule = $SDFileIO-&gt;ParseMoleculeString($MoleculeString);
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
75 <br/> $Molecule = FileIO::SDFileIO::ParseMoleculeString($MoleculeString);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
76 <p>Parses <em>MoleculeString</em> and returns a <strong>Molecule</strong> object. SD data field label and value pairs
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
77 are associated to <strong>Molecule</strong> object as a reference to a hash using:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
78 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
79 $Molecule-&gt;SetDataFieldLabelAndValues(\%DataLabelsAndValues)</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
80 <p>The reference to hash can be retrieved by:</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
81 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
82 $DataLabelsAndValues = $Molecule-&gt;GetDataFieldLabelAndValues();
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
83 <br/> for $DataLabel (sort keys %{$DataLabelsAndValues}) {
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
84 <br/>&nbsp;&nbsp;&nbsp;&nbsp; $DataValue = $DataLabelsAndValues-&gt;{$DataLabel};
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
85 <br/> }</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
86 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
87 <dt><strong><a name="readmolecule" class="item"><strong>ReadMolecule</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
88 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
89 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
90 $Molecule = $SDFileIO-&gt;ReadMolecule($FileHandle);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
91 <p>Reads data for the next compound in a file using already opened <em>FileHandle</em>, creates,
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
92 and returns a <strong>Molecule</strong> object.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
93 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
94 <dt><strong><a name="readmoleculestring" class="item"><strong>ReadMoleculeString</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
95 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
96 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
97 $MoleculeString = $SDFileIO-&gt;ReadMoleculeString($FileHandle);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
98 <p>Reads data for the next compound in a file using already opened <em>FileHandle</em> and
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
99 returns a <strong>MoleculeString</strong> corresponding to compound structure and other associated
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
100 data.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
101 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
102 <dt><strong><a name="writemolecule" class="item"><strong>WriteMolecule</strong></a></strong></dt>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
103 <dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
104 <div class="OptionsBox">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
105 $SDFileIO-&gt;WriteMolecule($Molecule);</div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
106 <p>Writes <em>Molecule</em> data to a file in MDLMol format and returns <strong>SDFileIO</strong>.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
107 </dd>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
108 </dl>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
109 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
110 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
111 <h2>AUTHOR</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
112 <p><a href="mailto:msud@san.rr.com">Manish Sud</a></p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
113 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
114 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
115 <h2>SEE ALSO</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
116 <p><a href="./MoleculeFileIO.html">MoleculeFileIO.pm</a>,&nbsp<a href="./MDLMolFileIO.html">MDLMolFileIO.pm</a>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
117 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
118 <p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
119 </p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
120 <h2>COPYRIGHT</h2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
121 <p>Copyright (C) 2015 Manish Sud. All rights reserved.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
122 <p>This file is part of MayaChemTools.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
123 <p>MayaChemTools is free software; you can redistribute it and/or modify it under
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
124 the terms of the GNU Lesser General Public License as published by the Free
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
125 Software Foundation; either version 3 of the License, or (at your option)
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
126 any later version.</p>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
127 <p>&nbsp</p><p>&nbsp</p><div class="DocNav">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
128 <table width="100%" border=0 cellpadding=0 cellspacing=2>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
129 <tr align="left" valign="top"><td width="33%" align="left"><a href="./MDLMolFileIO.html" title="MDLMolFileIO.html">Previous</a>&nbsp;&nbsp;<a href="./index.html" title="Table of Contents">TOC</a>&nbsp;&nbsp;<a href="./FileUtil.html" title="FileUtil.html">Next</a></td><td width="34%" align="middle"><strong>March 29, 2015</strong></td><td width="33%" align="right"><strong>FileIO::SDFileIO.pm</strong></td></tr>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
130 </table>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
131 </div>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
132 <br />
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
133 <center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
134 <img src="../../images/h2o2.png">
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
135 </center>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
136 </body>
73ae111cf86f Uploaded
deepakjadmin
parents:
diff changeset
137 </html>