mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-14 02:33:51 +02:00
1ea2f3d3bb
Did not add it to project files to avoid mess. Fixed NaN / infinity issues.
64 lines
2.0 KiB
C++
64 lines
2.0 KiB
C++
/* Copyright 2010 Juan Rada-Vilela
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
#include "TakagiSugenoRule.h"
|
|
#include "TakagiSugenoConsequent.h"
|
|
#include "DescriptiveAntecedent.h"
|
|
#include "StrOp.h"
|
|
|
|
namespace fl {
|
|
|
|
TakagiSugenoRule::TakagiSugenoRule() : FuzzyRule() {
|
|
|
|
}
|
|
|
|
TakagiSugenoRule::TakagiSugenoRule(const std::string& rule, const FuzzyEngine& engine)
|
|
: FuzzyRule() {
|
|
try {
|
|
parse(rule, engine);
|
|
} catch (ParsingException& e) {
|
|
FL_LOG(e.toString());
|
|
}
|
|
}
|
|
|
|
TakagiSugenoRule::~TakagiSugenoRule() {
|
|
|
|
}
|
|
|
|
void TakagiSugenoRule::parse(const std::string& rule, const FuzzyEngine& engine) {
|
|
std::string str_antecedent, str_consequent;
|
|
ExtractFromRule(rule, str_antecedent, str_consequent);
|
|
|
|
DescriptiveAntecedent* obj_antecedent = new DescriptiveAntecedent;
|
|
obj_antecedent->parse(str_antecedent, engine);
|
|
setAntecedent(obj_antecedent);
|
|
|
|
std::vector<std::string> consequents = StrOp::SplitByWord(str_consequent, FuzzyRule::FR_AND);
|
|
TakagiSugenoConsequent* obj_consequent = NULL;
|
|
|
|
for (size_t i = 0; i < consequents.size(); ++i) {
|
|
obj_consequent = new TakagiSugenoConsequent;
|
|
try {
|
|
std::string x = consequents[i];
|
|
StrOp::FindReplace(x,"="," = ");
|
|
obj_consequent->parse(x, engine);
|
|
} catch (ParsingException& e) {
|
|
delete obj_consequent;
|
|
throw e;
|
|
}
|
|
addConsequent(obj_consequent);
|
|
}
|
|
}
|
|
}
|