source: tags/arb-6.0/MULTI_PROBE/MP_main.cxx

Last change on this file was 11512, checked in by westram, 10 years ago
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.5 KB
Line 
1// ================================================================ //
2//                                                                  //
3//   File      : MP_main.cxx                                        //
4//   Purpose   :                                                    //
5//                                                                  //
6//   Institute of Microbiology (Technical University Munich)        //
7//   http://www.arb-home.de/                                        //
8//                                                                  //
9// ================================================================ //
10
11#include <multi_probe.hxx>
12
13#include "MP_probe.hxx"
14#include "MultiProbe.hxx"
15#include "mp_proto.hxx"
16
17#include <aw_root.hxx>
18#include <aw_awar_defs.hxx>
19#include <awt_canvas.hxx>
20
21awar_vars  mp_gl_awars;
22MP_Main   *mp_main             = NULL;
23char       MP_probe_tab[256];                       // zum checken, ob ein eingegebener Sondenstring ok ist
24int        remembered_mismatches;
25int        anz_elem_marked     = 0;
26int        anz_elem_unmarked   = 0;
27bool       pt_server_different = false;
28
29MP_Main::MP_Main(AW_root *awr, AWT_canvas *canvas) {
30    aw_root   = awr;
31    scr       = canvas;
32    stc       = NULL;
33    create_awars();
34    mp_window = new MP_Window(aw_root, canvas->gb_main);
35    p_eval    = NULL;
36}
37
38MP_Main::~MP_Main()
39{
40    aw_root->awar_int(MP_AWAR_QUALITY)->remove_callback(MP_gen_quality);
41    aw_root->awar_int(MP_AWAR_SINGLEMISMATCHES)->remove_callback(MP_gen_singleprobe);
42    aw_root->awar_int(MP_AWAR_MISMATCHES)->remove_callback(MP_modify_selected);
43
44    delete p_eval;
45    delete stc;
46    delete mp_window;
47
48    new_pt_server = true;
49}
50
51void MP_Main::destroy_probe_eval()
52{
53    delete p_eval;
54    p_eval = NULL;
55}
56
57ProbeValuation *MP_Main::new_probe_eval(char **field, int size, int *array, int *single_mismatch)
58{
59    p_eval = new ProbeValuation(field, size, array, single_mismatch);
60    p_eval->set_act_gen(new Generation(p_eval->get_max_init_for_gen(), 1)); // erste Generation = Ausgangspopulation
61    return p_eval;
62}
63
64void MP_Main::create_awars()
65{
66    aw_root->awar_string(MP_AWAR_SEQIN);
67    aw_root->awar_string(MP_AWAR_SELECTEDPROBES)->add_target_var(& mp_gl_awars.selected_probes);
68    aw_root->awar_string(MP_AWAR_PROBELIST)->add_target_var(& mp_gl_awars.probelist);
69    aw_root->awar_int(MP_AWAR_WEIGHTEDMISMATCHES)->add_target_var(& mp_gl_awars.weightedmismatches)->write_int(2);
70    aw_root->awar_int(MP_AWAR_COMPLEMENT, 1)->add_target_var(& mp_gl_awars.complement);
71    aw_root->awar_int(MP_AWAR_MISMATCHES)->add_target_var(& mp_gl_awars.no_of_mismatches)->add_callback(MP_modify_selected);
72    remembered_mismatches = 0;      // derselbe initiale Wert wie mp_gl_awars.no_of_mismatches
73    aw_root->awar_int(MP_AWAR_PTSERVER)->add_target_var(& mp_gl_awars.ptserver);
74    aw_root->awar_string(MP_AWAR_RESULTPROBES)->add_target_var(& mp_gl_awars.result_probes);
75    aw_root->awar_string(MP_AWAR_RESULTPROBESCOMMENT)->add_target_var(& mp_gl_awars.result_probes_comment);
76    aw_root->awar_int(MP_AWAR_NOOFPROBES)->add_target_var(& mp_gl_awars.no_of_probes)->write_int(3);
77    aw_root->awar_int(MP_AWAR_QUALITY)->add_target_var(& mp_gl_awars.probe_quality)->add_callback(MP_gen_quality)->write_int(QUALITYDEFAULT);
78    aw_root->awar_int(MP_AWAR_SINGLEMISMATCHES)->add_target_var(& mp_gl_awars.singlemismatches)->add_callback(MP_gen_singleprobe);
79    aw_root->awar_float(MP_AWAR_OUTSIDEMISMATCHES)->add_target_var(& mp_gl_awars.outside_mismatches_difference)->write_float(1.0);
80    aw_root->awar_int(MP_AWAR_QUALITYBORDER1)->add_target_var(& mp_gl_awars.qualityborder_best)->write_int(5);
81
82    aw_root->awar_int(MP_AWAR_EMPHASIS)->add_target_var(& mp_gl_awars.emphasis)->write_int(0);
83    aw_root->awar_float(MP_AWAR_GREYZONE)->add_target_var(& mp_gl_awars.greyzone)->write_float(0.0);
84    aw_root->awar_int(MP_AWAR_ECOLIPOS)->add_target_var(& mp_gl_awars.ecolipos)->write_int(0);
85
86    aw_root->awar_int(MP_AWAR_AUTOADVANCE, 1);
87}
88
89
90static void create_tables()
91{
92    int i;
93
94    // probe_tab
95    for (i=0; i<256; i++)
96        MP_probe_tab[i] = false;
97
98    const unsigned char *true_chars = (const unsigned char *)"atgucnATGUCN";
99    for (i = 0; true_chars[i]; ++i) {
100        MP_probe_tab[true_chars[i]] = true;
101    }
102}
103
104AW_window *create_multiprobe_window(AW_root *root, AWT_canvas *canvas) {
105    if (!mp_main) {
106        create_tables();
107        mp_main = new MP_Main(root, canvas);
108    }
109
110    AW_window *aw = mp_main->get_mp_window()->get_window();
111    aw->show();
112
113    return aw;
114}
115
Note: See TracBrowser for help on using the repository browser.