source: PSPA/Interface_Web/trunk/pspaWT/sources/controler/src/elementFit.cc @ 359

Last change on this file since 359 was 359, checked in by garnier, 11 years ago

Changement de la couleur des sections selectionnes + plein dautres choses

File size: 3.0 KB
Line 
1#include "elementFit.h"
2#include "mixedTools.h"
3
4elementFit::elementFit() : abstractElement()
5{
6    setDefaultValues();
7    setDefaults();
8    elementName_ = nomdElements("fit");
9    nbParam_ = elementName_.getElementNbParameters();
10    parametersString_ = new string[nbParam_+1];
11    // transportOk_ = true;
12    // parmelaIgnored_ = true;
13    registerAcceptableSoftware(nomDeLogiciel::transport, TBoolOk);
14    registerAcceptableSoftware(nomDeLogiciel::parmela, TBoolIgnore);
15}
16
17void elementFit::setDefaultValues()
18{
19    defaultLabel_ = "fit";
20    variableNameDef_ = "";
21    variableValueDef_ = 0.0;
22    toleranceDef_ = 0.0;
23}
24
25void elementFit::setDefaults()
26{
27    label_ = defaultLabel_;
28    variableName_ = variableNameDef_;
29    variableValue_ = variableValueDef_;
30    tolerance_ = toleranceDef_;
31}
32
33
34
35string* elementFit::getParametersString() const
36{
37    int compteur = -1;
38    parametersString_[++compteur] = mixedTools::intToString(nbParam_);
39    parametersString_[++compteur] = label_;
40    parametersString_[++compteur] = variableName_;
41    parametersString_[++compteur] = mixedTools::doubleToString(variableValue_ );
42    parametersString_[++compteur] = mixedTools::doubleToString(tolerance_);
43    if ( compteur != nbParam_ ) {
44        cerr << " elementFit::getParametersString() : ERROR nr pf parameters dosnt match " << endl;
45        return NULL;
46    }
47    return parametersString_;
48}
49
50void elementFit::setParametersString(string* param)
51{
52    if ( param == NULL )
53    {
54        cerr << "  elementFit::setParametersString parameters empty parameter set";
55        return;
56    }
57    int compteur = -1;
58    int nbparam = atoi(param[++compteur].c_str());
59    if ( nbparam != nbParam_ )
60    {
61        cerr << "  elementFit::setParametersString parameters do not match for a BEND" << endl;
62        return;
63    }
64   
65    label_ = param[++compteur];
66    variableName_ = param[++compteur];
67    variableValue_ = atof(param[++compteur].c_str());
68    tolerance_ = atof(param[++compteur].c_str());
69}
70
71
72string elementFit::parmelaOutputFlow() const
73{
74    ostringstream sortie;
75    return sortie.str();
76}
77
78string elementFit::transportOutputFlow() const
79{
80    ostringstream sortie;
81    sortie << label_ << ":" << "  FIT," << variableName_ << " = " << variableValue_ << ", TOLER = " << tolerance_ << " ;" << endl;
82    if ( variableName_ == "R11" || variableName_ == "R22" || variableName_ == "R12" || variableName_ == "R21" ) {
83        sortie << " PRINT, TRANS;" << endl;
84    }
85    return sortie.str();
86}
87
88string elementFit::FileOutputFlow() const
89{
90    ostringstream sortie;
91    //    sortie << elementName_.getElementType() << endl;
92    sortie << elementName_.getElementLabel() << endl;
93    sortie  << label_ << endl;
94    sortie  <<    variableName_ << " " << variableValue_ << " " << tolerance_ << endl;
95    return sortie.str();
96}
97
98void elementFit::FileInput(ifstream& ifs)
99{
100    ifs >> label_;
101    ifs  >>  variableName_ >>  variableValue_   >> tolerance_;
102}
103
104
105string elementFit::print() {
106    string txt = "";
107 
108    txt += label_;
109    return txt;
110}
Note: See TracBrowser for help on using the repository browser.