bio-samtools 0.2.5 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. data/README.rdoc +7 -20
  2. data/Rakefile +11 -0
  3. data/VERSION +1 -1
  4. data/bio-samtools.gemspec +67 -1
  5. data/doc/basic_styles.css +31 -0
  6. data/doc/classes/Bio.html +139 -0
  7. data/doc/classes/Bio/DB.html +137 -0
  8. data/doc/classes/Bio/DB/Alignment.html +441 -0
  9. data/doc/classes/Bio/DB/Alignment.src/M000012.html +19 -0
  10. data/doc/classes/Bio/DB/Alignment.src/M000013.html +27 -0
  11. data/doc/classes/Bio/DB/Alignment.src/M000014.html +45 -0
  12. data/doc/classes/Bio/DB/Alignment.src/M000015.html +40 -0
  13. data/doc/classes/Bio/DB/SAM.html +510 -0
  14. data/doc/classes/Bio/DB/SAM/Library.html +135 -0
  15. data/doc/classes/Bio/DB/SAM/Library.src/M000006.html +28 -0
  16. data/doc/classes/Bio/DB/SAM/Tools.html +278 -0
  17. data/doc/classes/Bio/DB/SAM/Tools.src/M000007.html +20 -0
  18. data/doc/classes/Bio/DB/SAM/Tools/Bam1CoreT.html +111 -0
  19. data/doc/classes/Bio/DB/SAM/Tools/Bam1T.html +150 -0
  20. data/doc/classes/Bio/DB/SAM/Tools/Bam1T.src/M000010.html +20 -0
  21. data/doc/classes/Bio/DB/SAM/Tools/BamHeaderT.html +169 -0
  22. data/doc/classes/Bio/DB/SAM/Tools/BamHeaderT.src/M000008.html +19 -0
  23. data/doc/classes/Bio/DB/SAM/Tools/BamHeaderT.src/M000009.html +18 -0
  24. data/doc/classes/Bio/DB/SAM/Tools/BamPileup1T.html +111 -0
  25. data/doc/classes/Bio/DB/SAM/Tools/SamfileT.html +129 -0
  26. data/doc/classes/Bio/DB/SAM/Tools/SamfileTX.html +111 -0
  27. data/doc/classes/Bio/DB/SAMException.html +140 -0
  28. data/doc/classes/Bio/DB/SAMException.src/M000016.html +18 -0
  29. data/doc/classes/Bio/DB/Sam.src/M000017.html +43 -0
  30. data/doc/classes/Bio/DB/Sam.src/M000018.html +42 -0
  31. data/doc/classes/Bio/DB/Sam.src/M000019.html +18 -0
  32. data/doc/classes/Bio/DB/Sam.src/M000020.html +22 -0
  33. data/doc/classes/Bio/DB/Sam.src/M000021.html +19 -0
  34. data/doc/classes/Bio/DB/Sam.src/M000022.html +25 -0
  35. data/doc/classes/Bio/DB/Sam.src/M000023.html +28 -0
  36. data/doc/classes/Bio/DB/Sam.src/M000024.html +28 -0
  37. data/doc/classes/Bio/DB/Sam.src/M000025.html +46 -0
  38. data/doc/classes/Bio/DB/Sam.src/M000026.html +24 -0
  39. data/doc/classes/Bio/DB/Sam.src/M000027.html +19 -0
  40. data/doc/classes/Bio/DB/Sam.src/M000028.html +24 -0
  41. data/doc/classes/Bio/DB/Sam.src/M000029.html +41 -0
  42. data/doc/classes/Bio/DB/Sam.src/M000030.html +31 -0
  43. data/doc/classes/Bio/DB/Sam.src/M000031.html +86 -0
  44. data/doc/classes/Bio/DB/Sam.src/M000032.html +34 -0
  45. data/doc/classes/Bio/DB/Tag.html +160 -0
  46. data/doc/classes/Bio/DB/Tag.src/M000011.html +21 -0
  47. data/doc/classes/LibC.html +105 -0
  48. data/doc/classes/Pileup.html +374 -0
  49. data/doc/classes/Pileup.src/M000001.html +34 -0
  50. data/doc/classes/Pileup.src/M000002.html +21 -0
  51. data/doc/classes/Pileup.src/M000003.html +21 -0
  52. data/doc/classes/Pileup.src/M000004.html +21 -0
  53. data/doc/classes/Pileup.src/M000005.html +31 -0
  54. data/doc/created.rid +1 -0
  55. data/doc/files/lib/bio-samtools_rb.html +109 -0
  56. data/doc/files/lib/bio/db/sam/bam_rb.html +108 -0
  57. data/doc/files/lib/bio/db/sam/faidx_rb.html +108 -0
  58. data/doc/files/lib/bio/db/sam/library_rb.html +101 -0
  59. data/doc/files/lib/bio/db/sam/pileup_rb.html +178 -0
  60. data/doc/files/lib/bio/db/sam/sam_rb.html +113 -0
  61. data/doc/files/lib/bio/db/sam_rb.html +111 -0
  62. data/doc/fr_class_index.html +43 -0
  63. data/doc/fr_file_index.html +33 -0
  64. data/doc/fr_method_index.html +58 -0
  65. data/doc/index.html +24 -0
  66. data/doc/rdoc-style.css +208 -0
  67. data/doc/tutorial.html +165 -0
  68. data/doc/tutorial.pdf +0 -0
  69. data/lib/bio/db/sam.rb +163 -1
  70. data/lib/bio/db/sam/pileup.rb +98 -0
  71. data/test/basictest.rb +14 -0
  72. data/test/pileup.rb +68 -0
  73. metadata +84 -18
@@ -0,0 +1,27 @@
1
+ <?xml version="1.0" encoding="iso-8859-1"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html>
7
+ <head>
8
+ <title>finalize (Bio::DB::Alignment)</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
+ <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
11
+ </head>
12
+ <body class="standalone-code">
13
+ <pre><span class="ruby-comment cmt"># File lib/bio/db/sam.rb, line 395</span>
14
+ <span class="ruby-keyword kw">def</span> <span class="ruby-constant">Alignment</span>.<span class="ruby-identifier">finalize</span>(<span class="ruby-identifier">object_id</span>)
15
+
16
+ <span class="ruby-comment cmt"># puts &quot;Object #{object_id} dying at #{Time.new}&quot;</span>
17
+ <span class="ruby-comment cmt"># p &quot;?&quot; . object_id.al</span>
18
+ <span class="ruby-comment cmt"># p object_id.al</span>
19
+ <span class="ruby-constant">LibC</span>.<span class="ruby-identifier">free</span> <span class="ruby-identifier">object_id</span>.<span class="ruby-identifier">al</span>
20
+ <span class="ruby-constant">LibC</span>.<span class="ruby-identifier">free</span> <span class="ruby-identifier">object_id</span>.<span class="ruby-identifier">sam</span>
21
+ <span class="ruby-constant">LibC</span>.<span class="ruby-identifier">free</span> <span class="ruby-identifier">object_id</span>.<span class="ruby-identifier">calend</span>
22
+ <span class="ruby-constant">LibC</span>.<span class="ruby-identifier">free</span> <span class="ruby-identifier">object_id</span>.<span class="ruby-identifier">qlen</span>
23
+
24
+ <span class="ruby-constant">LibC</span>.<span class="ruby-identifier">free</span> <span class="ruby-identifier">object_id</span>.<span class="ruby-identifier">samstr</span>
25
+ <span class="ruby-keyword kw">end</span></pre>
26
+ </body>
27
+ </html>
@@ -0,0 +1,45 @@
1
+ <?xml version="1.0" encoding="iso-8859-1"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html>
7
+ <head>
8
+ <title>set (Bio::DB::Alignment)</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
+ <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
11
+ </head>
12
+ <body class="standalone-code">
13
+ <pre><span class="ruby-comment cmt"># File lib/bio/db/sam.rb, line 417</span>
14
+ <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">set</span>(<span class="ruby-identifier">bam_alignment</span>, <span class="ruby-identifier">header</span>)
15
+ <span class="ruby-comment cmt">#Create the FFI object</span>
16
+ <span class="ruby-ivar">@al</span> = <span class="ruby-constant">Bio</span><span class="ruby-operator">::</span><span class="ruby-constant">DB</span><span class="ruby-operator">::</span><span class="ruby-constant">SAM</span><span class="ruby-operator">::</span><span class="ruby-constant">Tools</span><span class="ruby-operator">::</span><span class="ruby-constant">Bam1T</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">bam_alignment</span>)
17
+
18
+ <span class="ruby-comment cmt">#set the raw data</span>
19
+ <span class="ruby-identifier">tmp_str</span> = <span class="ruby-constant">Bio</span><span class="ruby-operator">::</span><span class="ruby-constant">DB</span><span class="ruby-operator">::</span><span class="ruby-constant">SAM</span><span class="ruby-operator">::</span><span class="ruby-constant">Tools</span>.<span class="ruby-identifier">bam_format1</span>(<span class="ruby-identifier">header</span>,<span class="ruby-identifier">al</span>)
20
+ <span class="ruby-comment cmt">#self.sam = tmp_str</span>
21
+ <span class="ruby-comment cmt">#ObjectSpace.define_finalizer(self, proc {|id| puts &quot;Finalizer one on #{id}&quot; })</span>
22
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">sam</span> = <span class="ruby-constant">String</span>.<span class="ruby-identifier">new</span>(<span class="ruby-identifier">tmp_str</span>)
23
+ <span class="ruby-comment cmt">#LibC.free tmp_str</span>
24
+ <span class="ruby-comment cmt">#Set values calculated by libbam</span>
25
+ <span class="ruby-identifier">core</span> = <span class="ruby-identifier">al</span>[<span class="ruby-identifier">:core</span>]
26
+ <span class="ruby-identifier">cigar</span> = <span class="ruby-identifier">al</span>[<span class="ruby-identifier">:data</span>][<span class="ruby-identifier">core</span>[<span class="ruby-identifier">:l_qname</span>]]<span class="ruby-comment cmt">#define bam1_cigar(b) ((uint32_t*)((b)-&gt;data + (b)-&gt;core.l_qname)) </span>
27
+ <span class="ruby-ivar">@calend</span> = <span class="ruby-constant">Bio</span><span class="ruby-operator">::</span><span class="ruby-constant">DB</span><span class="ruby-operator">::</span><span class="ruby-constant">SAM</span><span class="ruby-operator">::</span><span class="ruby-constant">Tools</span>.<span class="ruby-identifier">bam_calend</span>(<span class="ruby-identifier">core</span>,<span class="ruby-identifier">cigar</span>)
28
+ <span class="ruby-ivar">@qlen</span> = <span class="ruby-constant">Bio</span><span class="ruby-operator">::</span><span class="ruby-constant">DB</span><span class="ruby-operator">::</span><span class="ruby-constant">SAM</span><span class="ruby-operator">::</span><span class="ruby-constant">Tools</span>.<span class="ruby-identifier">bam_cigar2qlen</span>(<span class="ruby-identifier">core</span>,<span class="ruby-identifier">cigar</span>)
29
+
30
+ <span class="ruby-comment cmt">#process the flags</span>
31
+ <span class="ruby-ivar">@is_paired</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0001</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
32
+ <span class="ruby-ivar">@is_mapped</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0002</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
33
+ <span class="ruby-ivar">@query_unmapped</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0004</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
34
+ <span class="ruby-ivar">@mate_unmapped</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0008</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
35
+ <span class="ruby-ivar">@query_strand</span> = <span class="ruby-operator">!</span>(<span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0010</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>)
36
+ <span class="ruby-ivar">@mate_strand</span> = <span class="ruby-operator">!</span>(<span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0020</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>)
37
+ <span class="ruby-ivar">@first_in_pair</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0040</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
38
+ <span class="ruby-ivar">@second_in_pair</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0080</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
39
+ <span class="ruby-ivar">@primary</span> = <span class="ruby-operator">!</span>(<span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0100</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>)
40
+ <span class="ruby-ivar">@failed_quality</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0200</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
41
+ <span class="ruby-ivar">@is_duplicate</span> = <span class="ruby-ivar">@flag</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x0400</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
42
+
43
+ <span class="ruby-keyword kw">end</span></pre>
44
+ </body>
45
+ </html>
@@ -0,0 +1,40 @@
1
+ <?xml version="1.0" encoding="iso-8859-1"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html>
7
+ <head>
8
+ <title>sam= (Bio::DB::Alignment)</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
+ <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
11
+ </head>
12
+ <body class="standalone-code">
13
+ <pre><span class="ruby-comment cmt"># File lib/bio/db/sam.rb, line 449</span>
14
+ <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">sam=</span>(<span class="ruby-identifier">sam</span>)
15
+ <span class="ruby-comment cmt">#p sam</span>
16
+ <span class="ruby-identifier">s</span> = <span class="ruby-identifier">sam</span>.<span class="ruby-identifier">split</span>(<span class="ruby-value str">&quot;\t&quot;</span>)
17
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">qname</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">0</span>]
18
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">flag</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">1</span>].<span class="ruby-identifier">to_i</span>
19
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">rname</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">2</span>]
20
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">pos</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">3</span>].<span class="ruby-identifier">to_i</span>
21
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">mapq</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">4</span>].<span class="ruby-identifier">to_i</span>
22
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">cigar</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">5</span>]
23
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">mrnm</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">6</span>]
24
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">mpos</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">7</span>].<span class="ruby-identifier">to_i</span>
25
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">isize</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">8</span>].<span class="ruby-identifier">to_i</span>
26
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">seq</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">9</span>]
27
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">qual</span> = <span class="ruby-identifier">s</span>[<span class="ruby-value">10</span>]
28
+ <span class="ruby-keyword kw">self</span>.<span class="ruby-identifier">tags</span> = {}
29
+ <span class="ruby-value">11</span>.<span class="ruby-identifier">upto</span>(<span class="ruby-identifier">s</span>.<span class="ruby-identifier">size</span><span class="ruby-operator">-</span><span class="ruby-value">1</span>) {<span class="ruby-operator">|</span><span class="ruby-identifier">n</span><span class="ruby-operator">|</span>
30
+ <span class="ruby-identifier">t</span> = <span class="ruby-constant">Tag</span>.<span class="ruby-identifier">new</span>
31
+ <span class="ruby-identifier">t</span>.<span class="ruby-identifier">set</span>(<span class="ruby-identifier">s</span>[<span class="ruby-identifier">n</span>])
32
+ <span class="ruby-identifier">tags</span>[<span class="ruby-identifier">t</span>.<span class="ruby-identifier">tag</span>] = <span class="ruby-identifier">t</span>
33
+ }
34
+
35
+
36
+ <span class="ruby-comment cmt">#&lt;QNAME&gt; &lt;FLAG&gt; &lt;RNAME&gt; &lt;POS&gt; &lt;MAPQ&gt; &lt;CIGAR&gt; &lt;MRNM&gt; &lt;MPOS&gt; &lt;ISIZE&gt; &lt;SEQ&gt; &lt;QUAL&gt; #[&lt;TAG&gt;:&lt;VTYPE&gt;:&lt;VALUE&gt; [...]] </span>
37
+
38
+ <span class="ruby-keyword kw">end</span></pre>
39
+ </body>
40
+ </html>
@@ -0,0 +1,510 @@
1
+ <?xml version="1.0" encoding="iso-8859-1"?>
2
+ <!DOCTYPE html
3
+ PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
+
6
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
7
+ <head>
8
+ <title>Class: Bio::DB::Sam</title>
9
+ <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
+ <meta http-equiv="Content-Script-Type" content="text/javascript" />
11
+ <link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
12
+ <script type="text/javascript">
13
+ // <![CDATA[
14
+
15
+ function popupCode( url ) {
16
+ window.open(url, "Code", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=150,width=400")
17
+ }
18
+
19
+ function toggleCode( id ) {
20
+ if ( document.getElementById )
21
+ elem = document.getElementById( id );
22
+ else if ( document.all )
23
+ elem = eval( "document.all." + id );
24
+ else
25
+ return false;
26
+
27
+ elemStyle = elem.style;
28
+
29
+ if ( elemStyle.display != "block" ) {
30
+ elemStyle.display = "block"
31
+ } else {
32
+ elemStyle.display = "none"
33
+ }
34
+
35
+ return true;
36
+ }
37
+
38
+ // Make codeblocks hidden by default
39
+ document.writeln( "<style type=\"text/css\">div.method-source-code { display: none }</style>" )
40
+
41
+ // ]]>
42
+ </script>
43
+
44
+ </head>
45
+ <body>
46
+
47
+
48
+
49
+ <div id="classHeader">
50
+ <table class="header-table">
51
+ <tr class="top-aligned-row">
52
+ <td><strong>Class</strong></td>
53
+ <td class="class-name-in-header">Bio::DB::Sam</td>
54
+ </tr>
55
+ <tr class="top-aligned-row">
56
+ <td><strong>In:</strong></td>
57
+ <td>
58
+ <a href="../../../files/lib/bio/db/sam_rb.html">
59
+ lib/bio/db/sam.rb
60
+ </a>
61
+ <br />
62
+ </td>
63
+ </tr>
64
+
65
+ <tr class="top-aligned-row">
66
+ <td><strong>Parent:</strong></td>
67
+ <td>
68
+ Object
69
+ </td>
70
+ </tr>
71
+ </table>
72
+ </div>
73
+ <!-- banner header -->
74
+
75
+ <div id="bodyContent">
76
+
77
+
78
+
79
+ <div id="contextContent">
80
+
81
+
82
+
83
+ </div>
84
+
85
+ <div id="method-list">
86
+ <h3 class="section-bar">Methods</h3>
87
+
88
+ <div class="name-list">
89
+ <a href="#M000024">average_coverage</a>&nbsp;&nbsp;
90
+ <a href="#M000025">chromosome_coverage</a>&nbsp;&nbsp;
91
+ <a href="#M000020">close</a>&nbsp;&nbsp;
92
+ <a href="#M000032">deprecated_pileup</a>&nbsp;&nbsp;
93
+ <a href="#M000028">fetch</a>&nbsp;&nbsp;
94
+ <a href="#M000026">fetch_reference</a>&nbsp;&nbsp;
95
+ <a href="#M000029">fetch_with_function</a>&nbsp;&nbsp;
96
+ <a href="#M000021">finalize</a>&nbsp;&nbsp;
97
+ <a href="#M000022">load_index</a>&nbsp;&nbsp;
98
+ <a href="#M000023">load_reference</a>&nbsp;&nbsp;
99
+ <a href="#M000030">merge</a>&nbsp;&nbsp;
100
+ <a href="#M000031">mpileup</a>&nbsp;&nbsp;
101
+ <a href="#M000017">new</a>&nbsp;&nbsp;
102
+ <a href="#M000018">open</a>&nbsp;&nbsp;
103
+ <a href="#M000027">query_string</a>&nbsp;&nbsp;
104
+ <a href="#M000019">to_s</a>&nbsp;&nbsp;
105
+ </div>
106
+ </div>
107
+
108
+ </div>
109
+
110
+
111
+ <!-- if includes -->
112
+
113
+ <div id="section">
114
+
115
+
116
+
117
+
118
+
119
+ <div id="attribute-list">
120
+ <h3 class="section-bar">Attributes</h3>
121
+
122
+ <div class="name-list">
123
+ <table>
124
+ <tr class="top-aligned-row context-row">
125
+ <td class="context-item-name">sam_file</td>
126
+ <td class="context-item-value">&nbsp;[R]&nbsp;</td>
127
+ <td class="context-item-desc"></td>
128
+ </tr>
129
+ </table>
130
+ </div>
131
+ </div>
132
+
133
+
134
+
135
+ <!-- if method_list -->
136
+ <div id="methods">
137
+ <h3 class="section-bar">Public Class methods</h3>
138
+
139
+ <div id="method-M000021" class="method-detail">
140
+ <a name="M000021"></a>
141
+
142
+ <div class="method-heading">
143
+ <a href="Sam.src/M000021.html" target="Code" class="method-signature"
144
+ onclick="popupCode('Sam.src/M000021.html');return false;">
145
+ <span class="method-name">finalize</span><span class="method-args">(id)</span>
146
+ </a>
147
+ </div>
148
+
149
+ <div class="method-description">
150
+ <p>
151
+ Destructor method that closes the file before letting the object be garbage
152
+ collected.
153
+ </p>
154
+ </div>
155
+ </div>
156
+
157
+ <div id="method-M000030" class="method-detail">
158
+ <a name="M000030"></a>
159
+
160
+ <div class="method-heading">
161
+ <a href="Sam.src/M000030.html" target="Code" class="method-signature"
162
+ onclick="popupCode('Sam.src/M000030.html');return false;">
163
+ <span class="method-name">merge</span><span class="method-args">(files, merged_file, headers, add_RG, by_qname)</span>
164
+ </a>
165
+ </div>
166
+
167
+ <div class="method-description">
168
+ <p>
169
+ Merges n BAM files. This doesn&#8216;t require to create a <a
170
+ href="SAM.html">SAM</a> object
171
+ </p>
172
+ <table>
173
+ <tr><td valign="top">files:</td><td>An array with the paths to the files.
174
+
175
+ </td></tr>
176
+ <tr><td valign="top">merged_file:</td><td>The path to the merged file
177
+
178
+ </td></tr>
179
+ <tr><td valign="top">headers:</td><td>The BAM file containing the header
180
+
181
+ </td></tr>
182
+ <tr><td valign="top">add_RG:</td><td>If true, the RG tag is added (infered from the filenames)
183
+
184
+ </td></tr>
185
+ <tr><td valign="top">by_qname:</td><td>If true, the bamfiles should by ordered by query name, if false, by
186
+ coordinates.
187
+
188
+ </td></tr>
189
+ </table>
190
+ </div>
191
+ </div>
192
+
193
+ <div id="method-M000017" class="method-detail">
194
+ <a name="M000017"></a>
195
+
196
+ <div class="method-heading">
197
+ <a href="Sam.src/M000017.html" target="Code" class="method-signature"
198
+ onclick="popupCode('Sam.src/M000017.html');return false;">
199
+ <span class="method-name">new</span><span class="method-args">(optsa={})</span>
200
+ </a>
201
+ </div>
202
+
203
+ <div class="method-description">
204
+ <p>
205
+ To make a <a href="Sam.html#M000017">new</a> sam object. Initialize expects
206
+ a hash optsa with the following elemets:
207
+ </p>
208
+ <table>
209
+ <tr><td valign="top">fasta:</td><td>The fasta file with the reference. (nil)
210
+
211
+ </td></tr>
212
+ <tr><td valign="top">bam:</td><td>path to a binary <a href="SAM.html">SAM</a> file (nil)
213
+
214
+ </td></tr>
215
+ <tr><td valign="top">tam:</td><td>path to a text <a href="SAM.html">SAM</a> file (nil)
216
+
217
+ </td></tr>
218
+ <tr><td valign="top">compressed:</td><td>If the binary file is compressed (true)
219
+
220
+ </td></tr>
221
+ <tr><td valign="top">write:</td><td>If the file is to be writen (false). Not supported yet.
222
+
223
+ </td></tr>
224
+ </table>
225
+ <p>
226
+ *NOTE:* you can&#8216;t use binary and text formats simultaneusly. To make
227
+ queries, the file has to be a sorted binary. This function doesn&#8216;t
228
+ actually <a href="Sam.html#M000018">open</a> the file, it just prepares the
229
+ object to be opened in a later stage.
230
+ </p>
231
+ </div>
232
+ </div>
233
+
234
+ <h3 class="section-bar">Public Instance methods</h3>
235
+
236
+ <div id="method-M000024" class="method-detail">
237
+ <a name="M000024"></a>
238
+
239
+ <div class="method-heading">
240
+ <a href="Sam.src/M000024.html" target="Code" class="method-signature"
241
+ onclick="popupCode('Sam.src/M000024.html');return false;">
242
+ <span class="method-name">average_coverage</span><span class="method-args">(chromosome, qstart, len)</span>
243
+ </a>
244
+ </div>
245
+
246
+ <div class="method-description">
247
+ <p>
248
+ Returns the average coverage of a region in a bam file.
249
+ </p>
250
+ </div>
251
+ </div>
252
+
253
+ <div id="method-M000025" class="method-detail">
254
+ <a name="M000025"></a>
255
+
256
+ <div class="method-heading">
257
+ <a href="Sam.src/M000025.html" target="Code" class="method-signature"
258
+ onclick="popupCode('Sam.src/M000025.html');return false;">
259
+ <span class="method-name">chromosome_coverage</span><span class="method-args">(chromosome, qstart, len)</span>
260
+ </a>
261
+ </div>
262
+
263
+ <div class="method-description">
264
+ <p>
265
+ Returns an array with the coverage at each possition in the queried region
266
+ This is a simple average coverage just calculated with the first and last
267
+ possition of the alignment, ignoring the gaps.
268
+ </p>
269
+ </div>
270
+ </div>
271
+
272
+ <div id="method-M000020" class="method-detail">
273
+ <a name="M000020"></a>
274
+
275
+ <div class="method-heading">
276
+ <a href="Sam.src/M000020.html" target="Code" class="method-signature"
277
+ onclick="popupCode('Sam.src/M000020.html');return false;">
278
+ <span class="method-name">close</span><span class="method-args">()</span>
279
+ </a>
280
+ </div>
281
+
282
+ <div class="method-description">
283
+ <p>
284
+ Closes the sam file and destroys the C pointers using the functions
285
+ provided by libbam
286
+ </p>
287
+ </div>
288
+ </div>
289
+
290
+ <div id="method-M000032" class="method-detail">
291
+ <a name="M000032"></a>
292
+
293
+ <div class="method-heading">
294
+ <a href="Sam.src/M000032.html" target="Code" class="method-signature"
295
+ onclick="popupCode('Sam.src/M000032.html');return false;">
296
+ <span class="method-name">deprecated_pileup</span><span class="method-args">( cmd ) {|Pileup.new(line)| ...}</span>
297
+ </a>
298
+ </div>
299
+
300
+ <div class="method-description">
301
+ <p>
302
+ utility method that does not use the samtools API, it calls samtools
303
+ directly as if on the command line and catches the output, to use this
304
+ method you must have a version of samtools that supports the pileup command
305
+ (&lt; 0.1.17) otherwise the command will fail. <a
306
+ href="Sam.html#M000031">mpileup</a> is the preferred method for getting
307
+ pileups. With this method the sam object should be created as usual, but
308
+ you need to pass this method a string of options for samtools you
309
+ don&#8216;t need to provide the call to samtools pileup itself or -f
310
+ &lt;fasta file&gt; or the bam file itself, these are taken from the sam
311
+ object
312
+ </p>
313
+ </div>
314
+ </div>
315
+
316
+ <div id="method-M000028" class="method-detail">
317
+ <a name="M000028"></a>
318
+
319
+ <div class="method-heading">
320
+ <a href="Sam.src/M000028.html" target="Code" class="method-signature"
321
+ onclick="popupCode('Sam.src/M000028.html');return false;">
322
+ <span class="method-name">fetch</span><span class="method-args">(chromosome, qstart, qend)</span>
323
+ </a>
324
+ </div>
325
+
326
+ <div class="method-description">
327
+ <p>
328
+ Returns an array of Alignments on a given region.
329
+ </p>
330
+ </div>
331
+ </div>
332
+
333
+ <div id="method-M000026" class="method-detail">
334
+ <a name="M000026"></a>
335
+
336
+ <div class="method-heading">
337
+ <a href="Sam.src/M000026.html" target="Code" class="method-signature"
338
+ onclick="popupCode('Sam.src/M000026.html');return false;">
339
+ <span class="method-name">fetch_reference</span><span class="method-args">(chromosome, qstart,qend)</span>
340
+ </a>
341
+ </div>
342
+
343
+ <div class="method-description">
344
+ <p>
345
+ Returns the sequence for a given region.
346
+ </p>
347
+ </div>
348
+ </div>
349
+
350
+ <div id="method-M000029" class="method-detail">
351
+ <a name="M000029"></a>
352
+
353
+ <div class="method-heading">
354
+ <a href="Sam.src/M000029.html" target="Code" class="method-signature"
355
+ onclick="popupCode('Sam.src/M000029.html');return false;">
356
+ <span class="method-name">fetch_with_function</span><span class="method-args">(chromosome, qstart, qend, function)</span>
357
+ </a>
358
+ </div>
359
+
360
+ <div class="method-description">
361
+ <p>
362
+ Executes a function on each <a href="Alignment.html">Alignment</a> inside
363
+ the queried region of the chromosome. The chromosome can be either the
364
+ textual name or a FixNum with the internal index. However, you need to get
365
+ the internal index with the provided API, otherwise the pointer is outside
366
+ the scope of the C library. Returns the count of alignments in the region.
367
+ WARNING: Accepts an index already parsed by the library. It fails when you
368
+ use your own FixNum (FFI-bug?)
369
+ </p>
370
+ </div>
371
+ </div>
372
+
373
+ <div id="method-M000022" class="method-detail">
374
+ <a name="M000022"></a>
375
+
376
+ <div class="method-heading">
377
+ <a href="Sam.src/M000022.html" target="Code" class="method-signature"
378
+ onclick="popupCode('Sam.src/M000022.html');return false;">
379
+ <span class="method-name">load_index</span><span class="method-args">()</span>
380
+ </a>
381
+ </div>
382
+
383
+ <div class="method-description">
384
+ <p>
385
+ Loads the bam index to be used for fetching. If the index doesn&#8216;t
386
+ exists the index is built provided that the user has writing access to the
387
+ folder where the BAM file is located. If the creation of the file fails a
388
+ <a href="SAMException.html">SAMException</a> is thrown. If the index
389
+ doesn&#8216;t exist, loading it will take more time. It is suggested to
390
+ generate the index separatedly if the bam file sits on a server where the
391
+ executing user may not have writing permissions in the server.
392
+ </p>
393
+ </div>
394
+ </div>
395
+
396
+ <div id="method-M000023" class="method-detail">
397
+ <a name="M000023"></a>
398
+
399
+ <div class="method-heading">
400
+ <a href="Sam.src/M000023.html" target="Code" class="method-signature"
401
+ onclick="popupCode('Sam.src/M000023.html');return false;">
402
+ <span class="method-name">load_reference</span><span class="method-args">()</span>
403
+ </a>
404
+ </div>
405
+
406
+ <div class="method-description">
407
+ <p>
408
+ Loads the reference file to be able to query regions of it. This requires
409
+ the fai index to exist in the same folder than the reference. If it
410
+ doesn&#8216;t exisits, this functions attempts to generate it. If user
411
+ doesn&#8216;t have writing permissions on the folder, or the creation of
412
+ the fai fails for any reason, a <a
413
+ href="SAMException.html">SAMException</a> is thrown.
414
+ </p>
415
+ </div>
416
+ </div>
417
+
418
+ <div id="method-M000031" class="method-detail">
419
+ <a name="M000031"></a>
420
+
421
+ <div class="method-heading">
422
+ <a href="Sam.src/M000031.html" target="Code" class="method-signature"
423
+ onclick="popupCode('Sam.src/M000031.html');return false;">
424
+ <span class="method-name">mpileup</span><span class="method-args">( opts ) {|Pileup.new(line)| ...}</span>
425
+ </a>
426
+ </div>
427
+
428
+ <div class="method-description">
429
+ <p>
430
+ calls the <a href="Sam.html#M000031">mpileup</a> function, opts is a hash
431
+ of options identical to the command line options for <a
432
+ href="Sam.html#M000031">mpileup</a>. is an iterator that yields a <a
433
+ href="../../Pileup.html">Pileup</a> object for each postion the command
434
+ line options that generate/affect BCF/VCF are ignored ie (g,u,e,h,I,L,o,p)
435
+ call the option as a symbol of the flag, eg -r for region is called :r
436
+ =&gt; &quot;some <a href="SAM.html">SAM</a> compatible region&quot; eg
437
+ bam.mpileup(:r =&gt; &quot;chr1:1000-2000&quot;, :q =&gt; 50) gets the
438
+ bases with quality &gt; 50 on chr1 between 1000-5000
439
+ </p>
440
+ </div>
441
+ </div>
442
+
443
+ <div id="method-M000018" class="method-detail">
444
+ <a name="M000018"></a>
445
+
446
+ <div class="method-heading">
447
+ <a href="Sam.src/M000018.html" target="Code" class="method-signature"
448
+ onclick="popupCode('Sam.src/M000018.html');return false;">
449
+ <span class="method-name">open</span><span class="method-args">()</span>
450
+ </a>
451
+ </div>
452
+
453
+ <div class="method-description">
454
+ <p>
455
+ Function that actually opens the sam file Throws a <a
456
+ href="SAMException.html">SAMException</a> if the file can&#8216;t be <a
457
+ href="Sam.html#M000018">open</a>.
458
+ </p>
459
+ </div>
460
+ </div>
461
+
462
+ <div id="method-M000027" class="method-detail">
463
+ <a name="M000027"></a>
464
+
465
+ <div class="method-heading">
466
+ <a href="Sam.src/M000027.html" target="Code" class="method-signature"
467
+ onclick="popupCode('Sam.src/M000027.html');return false;">
468
+ <span class="method-name">query_string</span><span class="method-args">(chromosome, qstart,qend)</span>
469
+ </a>
470
+ </div>
471
+
472
+ <div class="method-description">
473
+ <p>
474
+ Generates a query sting to be used by the region parser in samtools. In
475
+ principle, you shouldn&#8216;t need to use this function.
476
+ </p>
477
+ </div>
478
+ </div>
479
+
480
+ <div id="method-M000019" class="method-detail">
481
+ <a name="M000019"></a>
482
+
483
+ <div class="method-heading">
484
+ <a href="Sam.src/M000019.html" target="Code" class="method-signature"
485
+ onclick="popupCode('Sam.src/M000019.html');return false;">
486
+ <span class="method-name">to_s</span><span class="method-args">()</span>
487
+ </a>
488
+ </div>
489
+
490
+ <div class="method-description">
491
+ <p>
492
+ Prints a description of the sam file in a text format containg if it is
493
+ binary or text, the path and the fasta file of the reference
494
+ </p>
495
+ </div>
496
+ </div>
497
+
498
+
499
+ </div>
500
+
501
+
502
+ </div>
503
+
504
+
505
+ <div id="validator-badges">
506
+ <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
507
+ </div>
508
+
509
+ </body>
510
+ </html>