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 88 89
|
/*
* Copyright (C) 2013-2015, 2019 by the Konclude Developer Team.
*
* This file is part of the reasoning system Konclude.
* For details and support, see <http://konclude.com/>.
*
* Konclude is free software: you can redistribute it and/or modify
* it under the terms of version 3 of the GNU Lesser General Public
* License (LGPLv3) as published by the Free Software Foundation.
*
* Konclude is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU (Lesser) General Public License for more details.
*
* You should have received a copy of the GNU (Lesser) General Public
* License along with Konclude. If not, see <http://www.gnu.org/licenses/>.
*
*/
#include "CReasonerEvaluationLoadingTimeExtractor.h"
namespace Konclude {
namespace Test {
namespace Evaluation {
CReasonerEvaluationLoadingTimeExtractor::CReasonerEvaluationLoadingTimeExtractor(double timelimit) {
mTimelimit = timelimit;
}
CReasonerEvaluationLoadingTimeExtractor::~CReasonerEvaluationLoadingTimeExtractor() {
}
CReasonerEvaluationDataValue* CReasonerEvaluationLoadingTimeExtractor::extractEvaluationData(const QString& responseFileString) {
CReasonerEvaluationDoubleDataValue* doubleEvalValue = nullptr;
double doubleValue = 0;
QFile responseFile(responseFileString);
if (responseFile.open(QIODevice::ReadOnly)) {
QDomDocument document;
document.setContent(&responseFile,false);
QDomElement rootEl = document.documentElement();
QDomElement responseElement = rootEl.firstChildElement();
bool allRespTimeValid = true;
bool oneRespTimeValid = false;
if (!responseElement.isNull()) {
while (!responseElement.isNull()) {
QString requestCommand = responseElement.attribute("request-command");
if (requestCommand == "LoadOntologies" || requestCommand == "GraphLoad") {
QString respTimeString = responseElement.attribute("response-time","timeout");
bool validRespTime = false;
double respTime = respTimeString.toDouble(&validRespTime);
allRespTimeValid &= validRespTime;
oneRespTimeValid |= validRespTime;
doubleValue += respTime;
}
responseElement = responseElement.nextSiblingElement();
}
}
if (!oneRespTimeValid) {
QString respTimeString = rootEl.attribute("response-time","timeout");
bool validRespTime = false;
double respTime = respTimeString.toDouble(&validRespTime);
allRespTimeValid &= validRespTime;
oneRespTimeValid |= validRespTime;
doubleValue += respTime;
}
responseFile.close();
if (oneRespTimeValid) {
if (mTimelimit >= 0) {
doubleValue = qMin(mTimelimit,doubleValue);
}
doubleEvalValue = new CReasonerEvaluationDoubleDataValue(doubleValue);
}
}
return doubleEvalValue;
}
}; // end namespace Evaluation
}; // end namespace Test
}; // end namespace Konclude
|