template-blast-ui-help.html.twig 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. {#
  2. /**
  3. * @file
  4. * Default theme implementation of BLAST UI Help page.
  5. */
  6. #}
  7. <h3>Tripal BLAST Module Description</h3>
  8. <p>This module provides a basic interface to allow your users to utilize your server's NCBI BLAST+.</p>
  9. <p>
  10. <a href="#setup">Setup</a> |
  11. <a href="#function">Functionality</a> |
  12. <a href="#protection">Large jobs |
  13. <a href="#genomeview">Genome visualization</a>
  14. </p>
  15. <a name="setup"></a>
  16. &mdash;
  17. <h3><b>Setup Instructions</b></h3>
  18. <ol>
  19. <li>
  20. Install NCBI BLAST+ on your server (Tested with 2.2.26+). There is a
  21. <a href="https://launchpad.net/ubuntu/+source/ncbi-blast+">package available
  22. for Ubuntu</a> to ease installation. Optionally you can set the path to your
  23. BLAST executable: {{ context_links['link_config'] }} Page.
  24. </li>
  25. <li>
  26. Optionally, create Tripal External Database References to allow you to link
  27. the records in your BLAST database to further information. To do this simply
  28. go to {{ context_links['link_dbadd'] }} and make sure to fill in the Database
  29. prefix which will be concatenated with the record IDs in your BLAST database
  30. to determine the link-out to additional information. Note that a regular
  31. expression can be used when creating the BLAST database to indicate what the
  32. ID is.
  33. </li>
  34. <li>
  35. Create "BLAST Database" {{ context_links['link_nodeadd'] }} nodes for each dataset you want to make available for your users to BLAST
  36. against. BLAST databases should first be created using the command-line
  37. <code>makeblastdb</code> program with the <code>-parse_seqids</code> flag.
  38. </li>
  39. <li>
  40. It's recommended that you also install the <a href="http://drupal.org/project/tripal_daemon">Tripal Job Daemon</a>
  41. to manage BLAST jobs and ensure they are run soon after being submitted by the
  42. user. Without this additional module, administrators will have to execute the
  43. tripal jobs either manually or through use of cron jobs.
  44. </li>
  45. </ol>
  46. <a name="function"></a>
  47. &mdash;
  48. <h3><b>Highlighted Functionality</b></h3>
  49. <ul>
  50. <li>Supports {{ context_links['link_blastn'] }},
  51. {{ context_links['link_blastx'] }},
  52. {{ context_links['blastp'] }} and
  53. {{ context_linkst['tblastx'] with separate forms depending upon the database/query type.
  54. </li>
  55. <li>
  56. Simple interface allowing users to paste or upload a query sequence and then
  57. select from available databases. Additionally, a FASTA file can be uploaded
  58. for use as a database to BLAST against (this functionality can be disabled).
  59. </li>
  60. <li>
  61. Tabular Results listing with alignment information and multiple download
  62. formats (HTML, TSV, XML) available.
  63. </li>
  64. <li>
  65. Completely integrated with Tripal Jobs: {{ context_links['link_jobs'] }}
  66. providing administrators with a way to track BLAST jobs and ensuring long
  67. running BLASTs will not cause page time-outs
  68. </li>
  69. <li>
  70. BLAST databases are made available to the module by creating Drupal Pages: {{ context_link['link_nodeadd'] }}
  71. describing them. This allows administrators to use the Drupal Field API to add any information they want to these pages:
  72. {{ context_links['link_dbfields'] }}
  73. </li>
  74. <li>
  75. BLAST database records can be linked to an external source with more
  76. information (ie: NCBI) per BLAST database.
  77. </li>
  78. </ul>
  79. <a name="protection"</a></a>
  80. &mdash;
  81. <h3><b>Protection Against Large Jobs</b></h3>
  82. Depending on the size and nature of your target databases, you may wish to constrain use
  83. of this module.
  84. <ol>
  85. <li>Limit the number of results displayed via admin page. The recommended number is 500.</li>
  86. <li>
  87. Limit the maximum upload file size in php settings. This is less useful because some
  88. very large queries may be manageable, and others not.
  89. </li>
  90. <li>
  91. Repeat-mask your targets, or provide repeat-masked versions. Note that some
  92. researchers may be looking for repeats, so this may limit the usefulness of the BLAST
  93. service.
  94. </li>
  95. </ol>
  96. <a name="genomeview"></a>
  97. &mdash;
  98. <h3><b>Whole Genome Visualization</b></h3>
  99. This module can be configured to use
  100. <a href="https://github.com/LegumeFederation/cvitjs">CViTjs</a> to display BLAST hits on
  101. a genome image.
  102. <h4>CViTjs Setup</h4>
  103. <ol>
  104. <li>
  105. <a href="https://github.com/LegumeFederation/cvitjs">Download CViTjs</a> and copy
  106. the code to your webserver. It needs to be placed in <code>[your drupal root]/sites/all/libraries</code>. To download, execute
  107. the git command inside the <code>libraries/</code> directory:<br>
  108. <code>git clone https://github.com/LegumeFederation/cvitjs.git</code>
  109. </li>
  110. <li>
  111. CViTjs will have a config file in its root directory named cvit.conf. This file
  112. provides information for whole genome visualization for each genome BLAST target.
  113. <b>Make sure the config file can be edited by your web server.</b>
  114. </li>
  115. <li>
  116. Enable CViTjs from the BLAST module administration page.
  117. </li>
  118. <li>
  119. Edit the configuration file to define each genome target. These will look like:
  120. <pre>
  121. [data.Cajanus cajan - genome]
  122. conf = data/cajca/cajca.conf
  123. defaultData = data/cajca/cajca.gff</pre>
  124. Where:<br>
  125. <ul>
  126. <li>the section name, "data.Cajanus cajan - genome", consists of "data." followed
  127. by the name of the BLAST target node,</li>
  128. <li>the file "cajca.conf" is a cvit configuration file which describes how to draw the
  129. chromosomes and BLAST hits on the <i>Cajanus cajan</i> genome,</li>
  130. <li>and the file "cajca.gff" is a GFF3 file that describes the <i>Cajanus cajan</i>
  131. chromosomes.</li>
  132. </ul>
  133. At the top of the configuration file there must be a [general] section that defines
  134. the default data set. For example:
  135. <pre>
  136. [general]
  137. data_default = data.Cajanus cajan - genome</pre>
  138. </li>
  139. <li>
  140. Edit the nodes for each genome target (nodes of type "BLAST Database") and enable whole
  141. genome visualization. Remember that the names listed in the CViTjs config file must
  142. match the BLAST node name. In the example above, the BLAST database node for the
  143. <i>Cajanus cajan</i> genome assembly is named "Cajanus cajan - genome"
  144. </li>
  145. </ol>
  146. <h4>Notes</h4>
  147. <ul>
  148. <li>The .conf file for each genome can be modified to suit your needs and tastes. See the
  149. sample configuration file, <code>data/test1/test1.conf</code>, and the CViTjs
  150. <a href="https://github.com/LegumeFederation/cvitjs#using-cvitjs">documentation</a>.</li>
  151. <li>Each blast target CViTjs configuration file must define how to visualize blast hits or you will not see them.
  152. <pre>[blast]
  153. feature = BLASTRESULT:match_part
  154. glyph = position
  155. shape = rect
  156. color = #FF00FF
  157. width = 5</pre></li>
  158. <li>You will have to put the target-specific conf and gff files (e.g. cajca.conf and
  159. cjca.gff) on your web server, in the directory, <code>sites/all/libraries/cvitjs/data</code>. You may
  160. choose to group files for each genome into subdirectories, for example,
  161. <code>sites/all/libraries/cvitjs/data/cajca</code>.</li>
  162. <li>It is important to make sure that cvit.conf points to the correct data directory and the
  163. correct .gff and .conf files for the genome in question. For more information about how to
  164. create the .gff file, see the
  165. <a href="https://github.com/LegumeFederation/cvitjs#how-to">documentation</a>.</li>
  166. </ul>