Version: 8.3.0
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
sasimpl.cxx
Go to the documentation of this file.
1
// Copyright (C) 2006-2016 CEA/DEN, EDF R&D
2
//
3
// This library is free software; you can redistribute it and/or
4
// modify it under the terms of the GNU Lesser General Public
5
// License as published by the Free Software Foundation; either
6
// version 2.1 of the License, or (at your option) any later version.
7
//
8
// This library is distributed in the hope that it will be useful,
9
// but WITHOUT ANY WARRANTY; without even the implied warranty of
10
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11
// Lesser General Public License for more details.
12
//
13
// You should have received a copy of the GNU Lesser General Public
14
// License along with this library; if not, write to the Free Software
15
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
//
17
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18
//
19
20
#include "
sasimpl.hxx
"
21
22
#include "
saconst.h
"
23
24
#include "
solution.hxx
"
25
26
SalomeTest::SalomeTest
(
Superviseur
&
t
)
27
{
28
super
= &
t
;
29
// distribution
30
dst
= (
SalomeEventLoop
*) NULL;
31
dec
= (
LinearDecoder
*) NULL;
32
mtr
= (
Maestro
*) NULL;
33
// swarm
34
solv
= (
Simplex
*) NULL;
35
36
}
37
38
SalomeTest::~SalomeTest
(
void
)
39
{
40
// distribution
41
delete
dst
;
42
delete
dec
;
43
delete
mtr
;
44
// swarm
45
delete
solv
;
46
}
47
48
void
SalomeTest::readFromFile
(std::string rien)
49
{
50
std::vector<std::pair<double, double> > dom(
NBGENE
);
51
long
i
;
52
53
// domaine de recherche
54
for
(i=0; i<
NBGENE
; i++) {
55
dom[
i
].first =
BORNEMIN
;
56
dom[
i
].second =
BORNEMAX
;
57
}
58
// distribution
59
dst
=
new
SalomeEventLoop
(*
super
);
60
dec
=
new
LinearDecoder
(dom);
61
mtr
=
new
Maestro
((
Decoder
&) *
dec
, (
Critere
*) NULL, (
Distrib
&) *
dst
);
62
// swarm
63
solv
=
new
Simplex
(
NBNODE
, NBGENE, *
mtr
);
64
65
solv
->
setStop
(
NBEVAL
);
66
}
67
68
void
SalomeTest::start
(
void
)
69
{
70
solv
->
start
();
71
}
72
73
void
SalomeTest::next
(
void
)
74
{
75
int
rien;
76
rien =
solv
->
next
();
77
}
78
79
void
SalomeTest::finish
(
void
)
80
{
81
Solution
*res;
82
83
solv
->
finish
();
84
res =
solv
->
solution
();
85
dec->
echo
(*res);
86
}
87
src
engine
Plugin
sasimpl.cxx
Copyright © 2006-2017 CEA/DEN, EDF R&D