File: KnimeReadySeqAnApp.rst

package info (click to toggle)
seqan2 2.5.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 228,748 kB
  • sloc: cpp: 257,602; ansic: 91,967; python: 8,326; sh: 1,056; xml: 570; makefile: 229; awk: 51; javascript: 21
file content (87 lines) | stat: -rw-r--r-- 4,232 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
.. sidebar:: ToC

    .. contents::

.. _tutorial-workflows-knime-ready-seqan-app:

Make Your SeqAn App KNIME Ready
===============================

Learning Objective
  You will learn how to use the the seqan2:::dox:`ArgumentParser` and the SeqAn build system
  so that, at the end, a new SeqAn application can be integrated in KNIME easily.
  After completing this tutorial, you will be able write a new SeqAn application
  that can be imported into a KNIME Eclipse plugin with a couple of commands.

Difficulty
  Basic

Duration
  1.5 h

Prerequisites
  :ref:`tutorial-getting-started-first-steps-in-seqan`, :ref:`tutorial-getting-started-parsing-command-line-arguments`

In this tutorial you will learn how to write a SeqAn app, which can be, easily converted into a KNIME node.

The first part consists of preparing a dummy app such that it can be used in a KNIME workflow and in the second part you are asked to adapt the app such that it becomes a simple quality control tool.

Using the seqan2::ArgumentParser
--------------------------------

When we add options to the parser using :dox:`ArgumentParser#addOption`,
we pass an :dox:`ArgParseOption` object together with the parser. The :dox:`ArgParseArgument::ArgumentType` of this :dox:`ArgParseOption` object is highly correlated to how the node generated from our application will look like.

The ArgumentType can be one of the following

::

  *STRING:*  Argument is a string.
  *INTEGER:* Argument is a signed 32 bit integer.
  *INT64:* Argument is a signed 64 bit integer.
  *DOUBLE:* Argument is a floating point number stored as double.
  *INPUT_FILE:*  Argument is an input file.
  *OUTPUT_FILE:* Argument is an output file.
  *INPUT_PREFIX:*  Argument is a prefix to input file(s).
  *OUTPUT_PREFIX:* Argument is a prefix to output file(s).

Consider the following example application.

.. includefrags:: demos/tutorial/workflows/knime_node.cpp
   :fragment: all

While adding an :dox:`ArgParseOption` to your :dox:`ArgumentParser` you should consider the following points.

- KNIME needs to know the input and output ports of a node. Therefore we must specify them using ``ArgParseArgument::INPUT_FILE`` or ``ArgParseArgument::OUTPUT_FILE`` as can be seen in the example above.
- In addition, KNIME needs to know the valid file endings, which you can specify with :dox:`ArgParseArgument#setValidValues`, which is also shown in the example.

.. tip::

  Later, when building workflows, you can only connect an output-port of a node to the input-port of the next one if they have a compatible file endings.

- There are special types of input/output ports which are prefixes to a list of files. Such ports are specified using ``ArgParseArgument::INPUT_PREFIX`` or ``ArgParseArgument::OUTPUT_PREFIX``. You can only connect an output prefix port to an input prefix port and vise-versa.

Using the SeqAn build system to generate KNIME nodes
----------------------------------------------------

If you are using the SeqAn build system you can generate a workflow plugin directory for all the SeqAn apps including your new one using the target ``prepare_workflow_plugin``.

In order for your application to turn into a KNIME node, you should register your app ``e.g. my_app``, by simply adding the line:

.. code-block:: cmake

    set (SEQAN_CTD_EXECUTABLES ${SEQAN_CTD_EXECUTABLES} <my_app> CACHE INTERNAL "")

to the end of the *CMakeList.txt* file of your application. All applications with this line in their  *CMakeList.txt* file will be included in the generated plugin when building the target``prepare_workflow_plugin``.

.. tip::

  *If You are not using the SeqAn build system for some reason*, but you used the seqan2::ArgumentParser as recommended above, you still can generate a CTD file of your application.
  After building your application and go to the directory containing the executable of your application and run the following.

  .. code-block:: console

    ./seqan_app_name -write-ctd seqan_app_name.ctd

  This will give you the CTD file of your command-line tool. Then you can follow :ref:`tutorial-workflows-generating-knime-nodes-overview` section of the tutorial Generating KNIME Nodes to prepare a plugin directory of your application.