Commit 8b64e676 authored by 刘乐's avatar 刘乐

1, 更新

parent 03c5b5a4
#include "CivHydrTest.h" #include "CivHydrTest.h"
#include "CivHydrFuncInter.h" #include "CivHydrFuncInter.h"
#include <iostream> #include <iostream>
#include <string>
CivHydrTest::~CivHydrTest() CivHydrTest::~CivHydrTest()
{ {
} }
// 优化调度测试
void CivOptSchedulingTest::test(char* uri)
{
std::string condtionMap = "{\"JD0000159\":{\"min\":20,\"max\":48},\"JD0000324\":{\"min\":20,\"max\":48},\"JD0000416\":{\"min\":20,\"max\":48},\"JD0000422\":{\"min\":20,\"max\":48},\"JD0000457\":{\"min\":20,\"max\":48},\"JD0000532\":{\"min\":20,\"max\":48},\"JD0000538\":{\"min\":20,\"max\":48},\"JD0000582\":{\"min\":20,\"max\":48},\"JD0000648\":{\"min\":20,\"max\":48},\"JD0000652\":{\"min\":20,\"max\":48},\"JD0000665\":{\"min\":20,\"max\":48},\"JD0000703\":{\"min\":20,\"max\":48},\"JD0000724\":{\"min\":20,\"max\":48}}";
int time = 9;
char* condition = const_cast<char*>(condtionMap.c_str());
char result[1024 * 512];
bool res = optimalSchedulingSimulation(uri, condition, 9, result);
std::cout << "测试结果" << res << std::endl;
std::cout << result << std::endl;
}
// 水力测试 // 水力测试
void CivConHydrTest::test(char* uri) void CivConHydrTest::test(char* uri)
{ {
...@@ -40,7 +56,7 @@ void CivUpstreamTrackingTest::test(char* uri) ...@@ -40,7 +56,7 @@ void CivUpstreamTrackingTest::test(char* uri)
{ {
// 追踪节点编号 // 追踪节点编号
char sn[64]; char sn[64];
strcpy(sn, "5fbaaf9e-dfcf-4e97-9fb1-31d03293f654"); strcpy(sn, "913fdd03-6b29-4a61-9c3b-e2f0bb33cb3c");
char result[1024 * 128]; char result[1024 * 128];
...@@ -58,7 +74,7 @@ void CivDownStreamTrackingTest::test(char* uri) ...@@ -58,7 +74,7 @@ void CivDownStreamTrackingTest::test(char* uri)
{ {
// 追踪节点编号 // 追踪节点编号
char sn[64]; char sn[64];
strcpy(sn, "5fbaaf9e-dfcf-4e97-9fb1-31d03293f654"); strcpy(sn, "48ff56e6-b50f-4003-ad5c-95240c114e42");
char result[1024 * 512]; char result[1024 * 512];
...@@ -76,7 +92,7 @@ void CivWaterSupplyScopeTest::test(char* uri) ...@@ -76,7 +92,7 @@ void CivWaterSupplyScopeTest::test(char* uri)
{ {
// 追踪节点编号 // 追踪节点编号
char sn[512]; char sn[512];
strcpy(sn, "ffd0f63d-b8c3-4354-aea5-aedc52cb8e16"); strcpy(sn, "913fdd03-6b29-4a61-9c3b-e2f0bb33cb3c");
char result[1024 * 32]; char result[1024 * 32];
...@@ -90,7 +106,7 @@ void CivProjSimulationTest::test(char* uri) ...@@ -90,7 +106,7 @@ void CivProjSimulationTest::test(char* uri)
{ {
// 追踪节点编号 // 追踪节点编号
char projCode[512]; char projCode[512];
strcpy(projCode, "ba01c9a8-f113-4131-b566-5f7f1ce25e5c"); strcpy(projCode, "e9443d7f-d05b-4768-94b7-084a5d0fe3ba");
char time[512]; char time[512];
strcpy(time, "2020-09-24 09:00:00"); strcpy(time, "2020-09-24 09:00:00");
......
...@@ -8,6 +8,13 @@ public: ...@@ -8,6 +8,13 @@ public:
virtual ~CivHydrTest(); virtual ~CivHydrTest();
}; };
// 优化调度测试
class CivOptSchedulingTest :public CivHydrTest
{
public:
virtual void test(char* uri);
};
// 水力测试 // 水力测试
class CivConHydrTest :public CivHydrTest class CivConHydrTest :public CivHydrTest
{ {
......
...@@ -135,12 +135,13 @@ ...@@ -135,12 +135,13 @@
<PreprocessorDefinitions>NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS;PANDANALYSIS_DLL;PANDANALYSIS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions> <PreprocessorDefinitions>NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS;PANDANALYSIS_DLL;PANDANALYSIS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode> <ConformanceMode>true</ConformanceMode>
<AdditionalIncludeDirectories>$(OUTDIR)..\include</AdditionalIncludeDirectories> <AdditionalIncludeDirectories>$(OUTDIR)..\include</AdditionalIncludeDirectories>
<Optimization>Disabled</Optimization>
</ClCompile> </ClCompile>
<Link> <Link>
<SubSystem>Console</SubSystem> <SubSystem>Console</SubSystem>
<EnableCOMDATFolding>true</EnableCOMDATFolding> <EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences> <OptimizeReferences>true</OptimizeReferences>
<GenerateDebugInformation>false</GenerateDebugInformation> <GenerateDebugInformation>true</GenerateDebugInformation>
<AdditionalDependencies>pandaAnalysis.lib;pandaLog.lib;%(AdditionalDependencies)</AdditionalDependencies> <AdditionalDependencies>pandaAnalysis.lib;pandaLog.lib;%(AdditionalDependencies)</AdditionalDependencies>
<AdditionalLibraryDirectories>$(OUTDIR)..\lib</AdditionalLibraryDirectories> <AdditionalLibraryDirectories>$(OUTDIR)..\lib</AdditionalLibraryDirectories>
</Link> </Link>
......
...@@ -14,14 +14,42 @@ ...@@ -14,14 +14,42 @@
#include <windows.h> #include <windows.h>
#include <consoleapi2.h> #include <consoleapi2.h>
#include "JsonParseObject.h"
using namespace std; using namespace std;
double random(int min, int max)
{
double m1 = (double)(rand() % 101) / 101; // 计算 0,1之间的随机小数,得到的值域近似为(0,1)
min++; //将 区间变为(min+1,max),
double m2 = (double)((rand() % (max - min + 1)) + min); //计算 min+1,max 之间的随机整数,得到的值域为[min+1,max]
m2 = m2 - 1; //令值域为[min,max-1]
double dd = (m1 + m2) * 100;
double res = (int)dd;
return res / 100; //返回值域为(min,max),为所求随机浮点
}
// 测试json解析字符出
void testJson()
{
std::string jsonstr = "{\"监测点1\":{\"min\":20,\"max\":30},\"监测点2\":{\"min\":28.5,\"max\":32.4},\"雄楚大道\":{\"min\":23,\"max\":31.9}}";
JsonParseObject parseObj;
parseObj.parse(jsonstr);
map<string, vector<double>> resMap;
parseObj.read(resMap);
parseObj.clear();
}
int main(int argc, char* argv[]) int main(int argc, char* argv[])
{ {
double res = random(0, 1);
std::cout<< res <<std::endl;
// testJson();
while (true) while (true)
{ {
const char* uri = "host=192.168.19.100 port=5432 dbname=JinXian user=postgres password=admin"; const char* uri = "host=192.168.19.100 port=5432 dbname=JinXian3 user=postgres password=admin";
char* findUri = const_cast<char*>(uri); char* findUri = const_cast<char*>(uri);
SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_INTENSITY | FOREGROUND_GREEN); SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_INTENSITY | FOREGROUND_GREEN);
...@@ -81,6 +109,8 @@ int main(int argc, char* argv[]) ...@@ -81,6 +109,8 @@ int main(int argc, char* argv[])
break; break;
case 8: // 8 优化调度测试 case 8: // 8 优化调度测试
context.setHydrTest(new CivOptSchedulingTest());
context.contextTest(findUri);
break; break;
default: default:
cout << "输入测试号错误!" << endl; cout << "输入测试号错误!" << endl;
......
...@@ -18,7 +18,10 @@ double GenAlg::random(int min , int max) ...@@ -18,7 +18,10 @@ double GenAlg::random(int min , int max)
min++; //将 区间变为(min+1,max), min++; //将 区间变为(min+1,max),
double m2 = (double)((rand() % (max - min + 1)) + min); //计算 min+1,max 之间的随机整数,得到的值域为[min+1,max] double m2 = (double)((rand() % (max - min + 1)) + min); //计算 min+1,max 之间的随机整数,得到的值域为[min+1,max]
m2 = m2 - 1; //令值域为[min,max-1] m2 = m2 - 1; //令值域为[min,max-1]
return m1 + m2; //返回值域为(min,max),为所求随机浮点
double dd = (m1 + m2) * 100;
double res = (int)dd;
return res /100; //返回值域为(min,max),为所求随机浮点
} }
void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength, double LeftPoint, double RightPoint) void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength, double LeftPoint, double RightPoint)
...@@ -33,7 +36,7 @@ void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength, ...@@ -33,7 +36,7 @@ void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength,
mBestFitness = 0.0; mBestFitness = 0.0;
mWorstFitness = 99999999; mWorstFitness = 99999999;
mAverageFitness = 0; mAverageFitness = 0;
mMaxPerturbation = 0.001; mMaxPerturbation = 1;
mLeftPoint = LeftPoint; mLeftPoint = LeftPoint;
mRightPoint = RightPoint; mRightPoint = RightPoint;
...@@ -48,7 +51,7 @@ void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength, ...@@ -48,7 +51,7 @@ void GenAlg::init(int popsize, double MutRate, double CrossRate, int GenLength,
// 把所有的基因编码初始化为函数区间内的随机数。 // 把所有的基因编码初始化为函数区间内的随机数。
for (int j = 0; j < mChromoLength; j++) for (int j = 0; j < mChromoLength; j++)
{ {
vecPop[i].vecGenome.push_back(random(0,MAX_RANDOM) * (mRightPoint - mLeftPoint) + mLeftPoint); vecPop[i].vecGenome.push_back(random(0,1) * (mRightPoint - mLeftPoint) + mLeftPoint);
} }
} }
} }
...@@ -62,7 +65,7 @@ void GenAlg::mutate(vector<double>& chromo) ...@@ -62,7 +65,7 @@ void GenAlg::mutate(vector<double>& chromo)
if (random(0,1) < mMutationRate) if (random(0,1) < mMutationRate)
{ {
// 使该权值增加或者减少一个很小的随机数值 // 使该权值增加或者减少一个很小的随机数值
chromo[i] += ((random() - 0.05) * mMaxPerturbation); chromo[i] += ((random(0,1) - 0.2) * mMaxPerturbation);
// 左右边界 // 左右边界
if (chromo[i] < mLeftPoint) if (chromo[i] < mLeftPoint)
...@@ -79,28 +82,11 @@ void GenAlg::mutate(vector<double>& chromo) ...@@ -79,28 +82,11 @@ void GenAlg::mutate(vector<double>& chromo)
void GenAlg::select(vector<Genome>& genVec) void GenAlg::select(vector<Genome>& genVec)
{ {
// 产生一个 0 到种群总适应性评分总和之间的随机数. mTotalFitness记录了整个种群的适应性分数总和 while (genVec.size() < mPopSize)
double slice = (random(0, 1)) * mTotalFitness;
// 这个基因将承载转盘所选出来的那个个体.
Genome theChosenOne;
// 累计适应性分数的和.
double fitnessSoFar = 0;
// 遍历总种群里面的每一条染色体。
for (int i = 0; i < mPopSize; ++i)
{
//累计适应性分数.
fitnessSoFar += vecPop[i].fitness;
// 如果累计分数大于随机数,就选择此时的基因.
if (fitnessSoFar >= slice)
{ {
theChosenOne = vecPop[i]; Genome genMe = chromoRoulette();
genVec.push_back(theChosenOne); if (genMe.vecGenome.size() > 0)
continue; genVec.push_back(genMe);
}
} }
} }
...@@ -118,6 +104,7 @@ Genome GenAlg::chromoRoulette() ...@@ -118,6 +104,7 @@ Genome GenAlg::chromoRoulette()
// 遍历总种群里面的每一条染色体。 // 遍历总种群里面的每一条染色体。
for (int i = 0; i < mPopSize; ++i) for (int i = 0; i < mPopSize; ++i)
{ {
//累计适应性分数. //累计适应性分数.
fitnessSoFar += vecPop[i].fitness; fitnessSoFar += vecPop[i].fitness;
...@@ -144,12 +131,18 @@ void GenAlg::calculateBestWorstAvTot() ...@@ -144,12 +131,18 @@ void GenAlg::calculateBestWorstAvTot()
// 查找最好适应度值 // 查找最好适应度值
if (mBestFitness < fitNessTemp) if (mBestFitness < fitNessTemp)
{
mBestGenoMe = vecPop[i];
mBestFitness = fitNessTemp; mBestFitness = fitNessTemp;
}
// 查找最差适应度值 // 查找最差适应度值
if (mWorstFitness > fitNessTemp) if (mWorstFitness > fitNessTemp)
{
mWorthGenoMe = vecPop[i];
mWorstFitness = fitNessTemp; mWorstFitness = fitNessTemp;
} }
}
// 计算平均适应度 // 计算平均适应度
mAverageFitness = mTotalFitness / (double)total; mAverageFitness = mTotalFitness / (double)total;
...@@ -183,22 +176,28 @@ void GenAlg::epoch(vector<Genome>& vecNewPop) ...@@ -183,22 +176,28 @@ void GenAlg::epoch(vector<Genome>& vecNewPop)
// 根据个体自适应度进行选择 // 根据个体自适应度进行选择
select(vecNewPop); select(vecNewPop);
}
Genome GenAlg::bestFitness() vector<Genome> son;
{ crossover(vecNewPop, son);
int maxIndex = -1;
for (int i = 0; i < vecPop.size(); i++) // 基因变异
size_t sonTotal = son.size();
for (int i = 0; i < sonTotal; i++)
{ {
if (mBestFitness == vecPop[i].fitness) mutate(son[i].vecGenome);
maxIndex = i;
} }
// 没找到构造一个空的基因型对象 // 更新种群
if (maxIndex == -1) vecPop.clear();
return Genome(); vecPop = son;
return vecPop[maxIndex]; vecNewPop.clear();
vecNewPop = son;
}
Genome GenAlg::bestFitness()
{
return mBestGenoMe;
} }
double GenAlg::averageFitness() double GenAlg::averageFitness()
...@@ -223,7 +222,7 @@ void GenAlg::decoding(vector<map<string, float>>& genVals) ...@@ -223,7 +222,7 @@ void GenAlg::decoding(vector<map<string, float>>& genVals)
size_t genSize = genomeValsVec.size(); size_t genSize = genomeValsVec.size();
map<string, float> genMap; map<string, float> genMap;
for (int j = 0; j < genSize; i++) for (int j = 0; j < genSize; j++)
{ {
genMap.insert(pair<string,float>(mPumpVec[j], genomeValsVec[j])); genMap.insert(pair<string,float>(mPumpVec[j], genomeValsVec[j]));
} }
...@@ -258,12 +257,16 @@ void GenAlg::crossover(const vector<Genome>& parent, vector<Genome>& son) ...@@ -258,12 +257,16 @@ void GenAlg::crossover(const vector<Genome>& parent, vector<Genome>& son)
int indexLeft = randIndexVec[left]; int indexLeft = randIndexVec[left];
int indexRight = randIndexVec[right]; int indexRight = randIndexVec[right];
Genome genome = crossover(parent[indexLeft], parent[indexRight]); Genome genome1 = crossover(parent[indexLeft], parent[indexRight]);
son.push_back(genome); Genome genome2 = crossover(parent[indexRight], parent[indexLeft]);
son.push_back(genome1);
son.push_back(genome2);
left++; left++;
right--; right--;
} }
if (left == right)
son.push_back(parent[left]);
} }
Genome GenAlg::crossover(const Genome& gen1, const Genome& gen2) Genome GenAlg::crossover(const Genome& gen1, const Genome& gen2)
...@@ -277,10 +280,16 @@ Genome GenAlg::crossover(const Genome& gen1, const Genome& gen2) ...@@ -277,10 +280,16 @@ Genome GenAlg::crossover(const Genome& gen1, const Genome& gen2)
return geoMe; return geoMe;
size_t genSize = genVec1.size(); size_t genSize = genVec1.size();
double a = 0.15;
for (int i = 0; i < genSize; i++) for (int i = 0; i < genSize; i++)
{ {
double newGenVal = genVec1[i] + a * (genVec1[i] - genVec2[i]); double aa = random(0, 1);
double newGenVal = genVec1[i]*aa +(1- aa) * genVec2[i];
if (newGenVal < mLeftPoint)
newGenVal = mRightPoint;
if (newGenVal > mRightPoint)
newGenVal = mLeftPoint;
geoMe.vecGenome.push_back(newGenVal); geoMe.vecGenome.push_back(newGenVal);
} }
......
...@@ -77,16 +77,25 @@ public: ...@@ -77,16 +77,25 @@ public:
* @param [fitNess] 个体适应度 * @param [fitNess] 个体适应度
*/ */
void updateGenomeFitNess(int index, double fitNess); void updateGenomeFitNess(int index, double fitNess);
void setPumpVec(const vector<string>& pumpVec) { mPumpVec = pumpVec; }
private: private:
// 产生[a,b)之间的浮点数 // 产生[a,b)之间的浮点数
double random(int a=0, int b= RAND_MAX); double random(int a=0, int b= RAND_MAX);
// 交叉重组,产生新的个体 // 交叉重组,产生新的个体
Genome crossover(const Genome& gen1, const Genome& gen2); Genome crossover(const Genome& gen1, const Genome& gen2);
private: private:
// 这个容器将储存每一个个体的染色体 // 当前种群
vector <Genome> vecPop; vector <Genome> vecPop;
// 下一代种群
vector<Genome> nextPopulation;
// 中间代种群
vector<Genome> midPopulation;
// 种群数量 // 种群数量
int mPopSize; int mPopSize;
...@@ -99,6 +108,11 @@ private: ...@@ -99,6 +108,11 @@ private:
// 在所有个体当中最适应的个体的适应性评分 // 在所有个体当中最适应的个体的适应性评分
double mBestFitness; double mBestFitness;
// 记录最有个体基因值
Genome mBestGenoMe;
Genome mWorthGenoMe;
// 所有个体的适应性评分的平均值 // 所有个体的适应性评分的平均值
double mAverageFitness; double mAverageFitness;
...@@ -109,10 +123,10 @@ private: ...@@ -109,10 +123,10 @@ private:
Genome mFittestGenome; Genome mFittestGenome;
// 基因突变的概率,一般介于0.05和0.3之间 // 基因突变的概率,一般介于0.05和0.3之间
double mMutationRate; double mMutationRate = 0.2;
// 基因交叉的概率一般设为0.7 // 基因交叉的概率一般设为0.7
double mCrossoverRate; double mCrossoverRate = 0.7;
// 代数的记数器 // 代数的记数器
int mGeneration; int mGeneration;
......
...@@ -76,10 +76,10 @@ public: ...@@ -76,10 +76,10 @@ public:
protected: protected:
// 惩罚因子1 // 惩罚因子1
double C1; double C1 = 0.01;
// 惩罚因子2 // 惩罚因子2
double C2; double C2 = 0.01;
// 设置的监测点的调度最大值 // 设置的监测点的调度最大值
map<string, double> mMaxMonitorVals; map<string, double> mMaxMonitorVals;
......
...@@ -138,21 +138,25 @@ bool CivHydrCompute::hdyrCompute() ...@@ -138,21 +138,25 @@ bool CivHydrCompute::hdyrCompute()
if (errcode > 0) if (errcode > 0)
{ {
CivSysLog::getInstance()->error("ENopen 失败", "CivHydrCompute", __FUNCTION__);
ENclose(); ENclose();
return false; return false;
} }
if (ENopenH() > 0) if (ENopenH() > 0)
{ {
CivSysLog::getInstance()->error("ENopenH 失败", "CivHydrCompute", __FUNCTION__);
ENclose(); ENclose();
return false; return false;
} }
if (ENinitH(0) > 0) if (ENinitH(0) > 0)
{ {
CivSysLog::getInstance()->error("ENinitH 失败", "CivHydrCompute", __FUNCTION__);
ENclose(); ENclose();
return false; return false;
} }
float dHStep; float dHStep;
ENGetVal(4, &dHStep); ENGetVal(4, &dHStep);
do do
...@@ -185,6 +189,7 @@ bool CivHydrCompute::hdyrCompute() ...@@ -185,6 +189,7 @@ bool CivHydrCompute::hdyrCompute()
ENcloseH(); ENcloseH();
ENclose(); ENclose();
return true; return true;
} }
......
...@@ -28,6 +28,10 @@ public: ...@@ -28,6 +28,10 @@ public:
void saveResult(const std::string& uri); void saveResult(const std::string& uri);
void cacheCodeSn(const std::string& uri); void cacheCodeSn(const std::string& uri);
void setInpFile(const std::string& inpFile) { mInFile = inpFile; }
void setRptFile(const std::string& rptFile) { mRptFile = rptFile; }
void setBinFile(const std::string& binFile) { mBinFile = binFile; }
void getTrackingResult(const std::string& uri,std::string& jsonResult); void getTrackingResult(const std::string& uri,std::string& jsonResult);
void getNodeItemByInterval(int time, NodeResultItems& nodeItem); void getNodeItemByInterval(int time, NodeResultItems& nodeItem);
......
...@@ -5,21 +5,37 @@ ...@@ -5,21 +5,37 @@
#include "CivTrackingAnalysis.h" #include "CivTrackingAnalysis.h"
#include "CivProjSimulation.h" #include "CivProjSimulation.h"
#include "JsonParseObject.h" #include "JsonParseObject.h"
#include "CivOptSchedEngine.h"
bool PANDANALYSIS_API hdyrSimulation(char* uri) bool PANDANALYSIS_API hdyrSimulation(char* uri)
{ {
std::string uriStr = uri;
if (uriStr.empty())
return false;
CivHydrSimulation simulation(uri); CivHydrSimulation simulation(uri);
return simulation.hdyrSimulation(); return simulation.hdyrSimulation();
} }
bool PANDANALYSIS_API qualitySimulation(char* uri) bool PANDANALYSIS_API qualitySimulation(char* uri)
{ {
std::string uriStr = uri;
if (uriStr.empty())
return false;
CivHydrSimulation simulation(uri); CivHydrSimulation simulation(uri);
return simulation.qualitySimulation(); return simulation.qualitySimulation();
} }
bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours, char* result) bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours, char* result)
{ {
std::string uriStr = uri;
std::string sNStr = sN;
if (uriStr.empty() || sNStr.empty())
return false;
CivHydrSimulation simulation(uri); CivHydrSimulation simulation(uri);
std::string res; std::string res;
...@@ -33,8 +49,17 @@ bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours, char* r ...@@ -33,8 +49,17 @@ bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours, char* r
bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result) bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result)
{ {
std::string uriStr = uri;
std::string snStr = sn;
if (uriStr.empty() || snStr.empty())
return false;
CivTrackingAnalysis track(uri); CivTrackingAnalysis track(uri);
track.createGraphFrom(); if (!track.createGraphFrom())
{
return false;
}
std::string jsonResult; std::string jsonResult;
if (!track.upstreamTracking(sn, jsonResult)) if (!track.upstreamTracking(sn, jsonResult))
...@@ -47,6 +72,12 @@ bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result) ...@@ -47,6 +72,12 @@ bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result)
bool PANDANALYSIS_API downstreamTracking(char* uri, char* sn, char* result) bool PANDANALYSIS_API downstreamTracking(char* uri, char* sn, char* result)
{ {
std::string uriStr = uri;
std::string snStr = sn;
if (uriStr.empty() || snStr.empty())
return false;
CivTrackingAnalysis track(uri); CivTrackingAnalysis track(uri);
track.createGraphFrom(); track.createGraphFrom();
...@@ -66,6 +97,12 @@ bool PANDANALYSIS_API waterSupplyScopeAnalysis(char* uri, char* sn, char* result ...@@ -66,6 +97,12 @@ bool PANDANALYSIS_API waterSupplyScopeAnalysis(char* uri, char* sn, char* result
bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time) bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time)
{ {
std::string uriStr = uri;
std::string projCodeStr = projCode;
if (uriStr.empty() || projCodeStr.empty())
return false;
CivProjSimulation projSimulation(uri); CivProjSimulation projSimulation(uri);
if (!projSimulation.simulationProj(projCode, time)) if (!projSimulation.simulationProj(projCode, time))
...@@ -74,24 +111,58 @@ bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time) ...@@ -74,24 +111,58 @@ bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time)
return true; return true;
} }
bool PANDANALYSIS_API optimalSchedulingSimulation(char* uri, char* condition, char* timeInterval, char* result) bool PANDANALYSIS_API optimalSchedulingSimulation(char* uri, char* condition, int timeInterval, char* result)
{ {
// 类型装换 // 类型装换
string uriStr = uri; string uriStr = uri;
string conditionStr = condition; string conditionStr = condition;
string timeStr = timeInterval;
if (uriStr.empty() || conditionStr.empty())
return false;
// 解析输入的字符串转换位对应容器数据 // 解析输入的字符串转换位对应容器数据
JsonParseObject jsonObj; JsonParseObject jsonObj;
jsonObj.parse(conditionStr); jsonObj.parse(conditionStr);
map<string, string> condiTionMap; // 解析条件参数,监测点的最带和最小值的映射
map<string, vector<double>> condiTionMap;
jsonObj.read(condiTionMap); jsonObj.read(condiTionMap);
// 清楚
jsonObj.clear(); jsonObj.clear();
jsonObj.parse(timeStr); vector<string> monitorsVec;
map<string, vector<double>>::iterator iter = condiTionMap.begin();
map<string, double> maxMonitorVals;
map<string, double> minMonitorVals;
for (; iter != condiTionMap.end(); iter++)
{
string monitorSz = iter->first;
monitorsVec.push_back(monitorSz);
vector<double> monitorValVec = iter->second;
if (monitorValVec.size() < 2)
continue;
minMonitorVals.insert(pair<string, double>(monitorSz, monitorValVec[0]));
maxMonitorVals.insert(pair<string, double>(monitorSz, monitorValVec[1]));
}
// 优化调度客户端
CivOptSchedEngine schedEngine(uriStr);
schedEngine.setMonitors(monitorsVec);
schedEngine.setMaxMonitorVals(maxMonitorVals);
schedEngine.setMinMonitorVals(minMonitorVals);
schedEngine.setSchedulingPeriod(timeInterval);
if (!schedEngine.optimalScheduling(timeInterval))
return false;
std::string resultStr;
schedEngine.schedulingResultToJson(resultStr);
// 复制
strcpy(result, resultStr.c_str());
return true; return true;
} }
\ No newline at end of file
...@@ -68,7 +68,7 @@ extern "C" { ...@@ -68,7 +68,7 @@ extern "C" {
*@param [in] timeInterval:时段,格式:{"time":'1' } *@param [in] timeInterval:时段,格式:{"time":'1' }
*@param [out] result: 模拟的调度结果 *@param [out] result: 模拟的调度结果
*/ */
bool PANDANALYSIS_API optimalSchedulingSimulation(char* uri, char* condition, char* timeInterval, char* result); bool PANDANALYSIS_API optimalSchedulingSimulation(char* uri, char* condition, int timeInterval, char* result);
#if defined(__cplusplus) #if defined(__cplusplus)
} }
#endif #endif
......
...@@ -20,6 +20,10 @@ bool CivHydrSimulation::hdyrSimulation() ...@@ -20,6 +20,10 @@ bool CivHydrSimulation::hdyrSimulation()
return false; return false;
mHydrCompute.cacheCodeSn(mUri); mHydrCompute.cacheCodeSn(mUri);
mHydrCompute.setInpFile(inpFileS);
mHydrCompute.setRptFile("test.rpt");
mHydrCompute.setBinFile("test.bin");
if (!mHydrCompute.hdyrCompute()) if (!mHydrCompute.hdyrCompute())
{ {
return false; return false;
...@@ -40,6 +44,11 @@ bool CivHydrSimulation::qualitySimulation() ...@@ -40,6 +44,11 @@ bool CivHydrSimulation::qualitySimulation()
// convertor.maintainTopo(); // convertor.maintainTopo();
std::string inpFileS = convertor.convertBaseInp(); std::string inpFileS = convertor.convertBaseInp();
mHydrCompute.setInpFile(inpFileS);
mHydrCompute.setRptFile("test.rpt");
mHydrCompute.setBinFile("test.bin");
if (inpFileS.empty() || inpFileS == "") if (inpFileS.empty() || inpFileS == "")
{ {
CivSysLog::getInstance()->error("转inp文件失败", "CivSysLog", __FUNCTION__); CivSysLog::getInstance()->error("转inp文件失败", "CivSysLog", __FUNCTION__);
...@@ -60,6 +69,10 @@ bool CivHydrSimulation::qualitySimulation() ...@@ -60,6 +69,10 @@ bool CivHydrSimulation::qualitySimulation()
// 余氯计算 // 余氯计算
inpFileS = convertor.convertResidualInp(); inpFileS = convertor.convertResidualInp();
mHydrCompute.setInpFile(inpFileS);
mHydrCompute.setRptFile("test.rpt");
mHydrCompute.setBinFile("test.bin");
if (inpFileS.empty() || inpFileS == "") if (inpFileS.empty() || inpFileS == "")
{ {
CivSysLog::getInstance()->error("转inp文件失败", "CivSysLog", __FUNCTION__); CivSysLog::getInstance()->error("转inp文件失败", "CivSysLog", __FUNCTION__);
...@@ -81,6 +94,10 @@ bool CivHydrSimulation::trackingSimulation(char* snNode, int hours,std::string& ...@@ -81,6 +94,10 @@ bool CivHydrSimulation::trackingSimulation(char* snNode, int hours,std::string&
CivInpConvertor convertor(mUri); CivInpConvertor convertor(mUri);
std::string inpFileS = convertor.convertTrackInp(snNode, std::to_string(hours)); std::string inpFileS = convertor.convertTrackInp(snNode, std::to_string(hours));
mHydrCompute.setInpFile(inpFileS);
mHydrCompute.setRptFile("test.rpt");
mHydrCompute.setBinFile("test.bin");
if (inpFileS.empty()) if (inpFileS.empty())
return false; return false;
......
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
#include "CivBaseInpBuilder.h" #include "CivBaseInpBuilder.h"
#include "CivCommonUtils.h" #include "CivCommonUtils.h"
#include "CivHydrTableHelper.h" #include "CivHydrTableHelper.h"
#include "CivSysLog.h"
CivInpConvertor::CivInpConvertor(const std::string& uri) CivInpConvertor::CivInpConvertor(const std::string& uri)
:mUri(uri) :mUri(uri)
...@@ -40,7 +41,7 @@ std::string CivInpConvertor::convertPorjInp(const std::string& projCode, const s ...@@ -40,7 +41,7 @@ std::string CivInpConvertor::convertPorjInp(const std::string& projCode, const s
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\ptest.inp"; std::string inpFile = "ptest.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
...@@ -58,7 +59,7 @@ std::string CivInpConvertor::convertBaseInp() ...@@ -58,7 +59,7 @@ std::string CivInpConvertor::convertBaseInp()
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp"; std::string inpFile = "test.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
...@@ -86,7 +87,7 @@ std::string CivInpConvertor::convertTrackInp(const std::string& sn, const std::s ...@@ -86,7 +87,7 @@ std::string CivInpConvertor::convertTrackInp(const std::string& sn, const std::s
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp"; std::string inpFile = "test.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
...@@ -106,10 +107,11 @@ std::string CivInpConvertor::convertAnalysisInp() ...@@ -106,10 +107,11 @@ std::string CivInpConvertor::convertAnalysisInp()
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp"; std::string inpFile = "test.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
CivSysLog::getInstance()->error("ת" + inpFile + "ʧ", "CivInpConvertor", __FUNCTION__);
return ""; return "";
} }
...@@ -128,7 +130,7 @@ std::string CivInpConvertor::convertResidualInp() ...@@ -128,7 +130,7 @@ std::string CivInpConvertor::convertResidualInp()
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp"; std::string inpFile = "test.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
...@@ -152,7 +154,7 @@ std::string CivInpConvertor::convertNotPorjInp(const std::string& simulTime) ...@@ -152,7 +154,7 @@ std::string CivInpConvertor::convertNotPorjInp(const std::string& simulTime)
director.setBuilder(builder); director.setBuilder(builder);
director.create(); director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp"; std::string inpFile = "test.inp";
if (!builder->getNewInp(inpFile)) if (!builder->getNewInp(inpFile))
{ {
delete builder; delete builder;
......
...@@ -5,10 +5,13 @@ ...@@ -5,10 +5,13 @@
#include "CivPumpHelper.h" #include "CivPumpHelper.h"
#include "Genome.h" #include "Genome.h"
#include "CivCommonUtils.h" #include "CivCommonUtils.h"
#include "CivSysLog.h"
#include "CivSchedulingCompute.h"
CivOptSchedEngine::CivOptSchedEngine(const string& uri) CivOptSchedEngine::CivOptSchedEngine(const string& uri)
:mUri(uri),mMutRate(0.45),mCrossRate(0.07), popsize(10) :mUri(uri),mMutRate(0.45),mCrossRate(0.07), popsize(10)
{ {
// 初始化计算
} }
...@@ -23,31 +26,49 @@ bool CivOptSchedEngine::optimalScheduling(int time) ...@@ -23,31 +26,49 @@ bool CivOptSchedEngine::optimalScheduling(int time)
optScheduling->setMaxMonitorVals(mMaxMonitorVals); optScheduling->setMaxMonitorVals(mMaxMonitorVals);
GenAlg genAlg(optScheduling); GenAlg genAlg(optScheduling);
genAlg.setPumpVec(mPumpVec);
// 种群初始化 // 种群初始化
popsize = 10; popsize = 20;
genAlg.init(popsize, mMutRate, mCrossRate, mGenLength, 0, 1); genAlg.init(popsize, mMutRate, mCrossRate, mGenLength, 0, 1);
// 开始迭代计算 // 开始迭代计算
int index = 0; int index = 0;
// 迭代次数 // 迭代次数
int generation = 20; int generation = 100;
mSchedulingCompute->clearLastVals();
while (index++ < generation) while (index++ < generation)
{ {
string infoLog = "第" + to_string(index) + "迭代训练开始";
CivSysLog::getInstance()->info(infoLog, "CivOptSchedEngine", __FUNCTION__);
// 管网平差计算 // 管网平差计算
vector<map<string, float>> monitorsMap; if (index >1)
genAlg.decoding(monitorsMap); {
double gg = 0.9;
}
vector<map<string, float>> pumpSpeedMapVec;
genAlg.decoding(pumpSpeedMapVec);
// 计算种群个体的每个 // 计算种群个体的每个
size_t mSize = monitorsMap.size(); size_t mSize = pumpSpeedMapVec.size();
for (int i = 0; i < mSize; i++) for (int i = 0; i < mSize; i++)
{ {
mSchedulingCompute->updatePumpSpeed(monitorsMap[i]); map<string, float> pumpSpeedMap = pumpSpeedMapVec[i];
mSchedulingCompute->updatePumpSpeed(pumpSpeedMap);
if (!mSchedulingCompute->calculate()) if (!mSchedulingCompute->calculate())
continue; continue;
map<string, float>::const_iterator const_iter = pumpSpeedMap.cbegin();
string logStr = "第" + to_string(i) + "个体:";
for (; const_iter != pumpSpeedMap.cend(); const_iter++)
{
logStr.append(const_iter->first + ":" + to_string(const_iter->second)+" ");
}
// 获取计算的监测点的值 // 获取计算的监测点的值
map<string, double> monitorCalcMapValues; map<string, double> monitorCalcMapValues;
mSchedulingCompute->getMonitorsValue(mPeriod, monitorCalcMapValues); mSchedulingCompute->getMonitorsValue(mPeriod, monitorCalcMapValues);
...@@ -58,43 +79,72 @@ bool CivOptSchedEngine::optimalScheduling(int time) ...@@ -58,43 +79,72 @@ bool CivOptSchedEngine::optimalScheduling(int time)
// 计算个体自适度 // 计算个体自适度
double fitness = genAlg.fitnessfunction(cost, monitorCalcMapValues); double fitness = genAlg.fitnessfunction(cost, monitorCalcMapValues);
if (fitness > 1)
fitness = 0;
logStr.append(" 适应度值:" + to_string(fitness));
CivSysLog::getInstance()->info(logStr, "CivOptSchedEngine", __FUNCTION__);
// 更新个体的自适应度 // 更新个体的自适应度
genAlg.updateGenomeFitNess(i, fitness); genAlg.updateGenomeFitNess(i, fitness);
}
mSchedulingCompute->clearLastVals();
}
//
// genAlg.mutate()
// 产生下一代种群 // 产生下一代种群
std::vector<Genome> newGenmeVec; std::vector<Genome> newGenmeVec;
genAlg.epoch(newGenmeVec); genAlg.epoch(newGenmeVec);
} }
// 获取最好的 genAlg.calculateBestWorstAvTot();
Genome genome = genAlg.bestFitness(); Genome genome = genAlg.bestFitness();
vector<double> genVec = genome.vecGenome; vector<double> genVec = genome.vecGenome;
map<string, float> genMap; //
for (int i = 0; i < mMonitorsVec.size(); i++) size_t totalGenVec = genVec.size();
genMap.insert(pair<string, double>(mMonitorsVec[i], genVec[i])); size_t pumpSize = mPumpVec.size();
if (totalGenVec != pumpSize)
{
CivSysLog::getInstance()->error("水泵个数与计算的属性值不匹配", "CivOptSchedEngine", __FUNCTION__);
return false;
}
// 水泵,
string infoStr = "最优水泵组合值:";
for (int i = 0; i < totalGenVec; i++)
{
infoStr.append(mPumpVec[i] +":" + to_string(genVec[i]));
mPumpBestSpeed.insert(pair<string, double>(mPumpVec[i], genVec[i]));
}
CivSysLog::getInstance()->error(infoStr, "CivOptSchedEngine", __FUNCTION__);
mSchedulingCompute->clearLastVals();
// 再做一次水力计算,计算调度后的值 // 再做一次水力计算,计算调度后的值
mSchedulingCompute->updatePumpSpeed(genMap); mSchedulingCompute->updatePumpSpeed(mPumpBestSpeed);
mSchedulingCompute->calculate(); if (!mSchedulingCompute->calculate())
return false;
// 最调度值 // 最调度值
mSchedulingCompute->getMonitorsValue(mPeriod,mAfterSchedulingResults); mSchedulingCompute->getMonitorsValue(mPeriod,mAfterSchedulingResults);
// 结束计算
endCompute();
return true; return true;
} }
void CivOptSchedEngine::serializeToInpFile(string& inpName)
{
}
void CivOptSchedEngine::schedulingResultToJson(string& json) void CivOptSchedEngine::schedulingResultToJson(string& json)
{ {
// 水泵:组合 // 水泵:组合
json.append("{\"水泵状态\":{"); json.append("{\"水泵状态\":{");
map<string, int>::iterator iter = mPumpBestStatus.begin(); map<string, float>::iterator iter = mPumpBestSpeed.begin();
for (;iter!=mPumpBestStatus.end();iter++) for (;iter!= mPumpBestSpeed.end();iter++)
{ {
json.append(iter->first + ":" + to_string(iter->second)); json.append(iter->first + ":" + to_string(iter->second));
json.append(","); json.append(",");
...@@ -103,21 +153,16 @@ void CivOptSchedEngine::schedulingResultToJson(string& json) ...@@ -103,21 +153,16 @@ void CivOptSchedEngine::schedulingResultToJson(string& json)
json.append("},"); json.append("},");
// 调度组合 // 调度组合
json.append("\"监测点:[\""); json.append("\"监测点:\"");
int total = mBforeSchedulingResults.size();
for (int i = 0; i < total; i++)
{
map<string, double> beforeResult = mBforeSchedulingResults[i];
map<string, double> afterResult = mAfterSchedulingResults[i];
json.append("{"); json.append("{");
for (auto iter = beforeResult.begin(); iter != beforeResult.end(); iter++) for (auto iter = mBforeSchedulingResults.begin(); iter != mBforeSchedulingResults.end(); iter++)
{ {
string monitorName = iter->first; string monitorName = iter->first;
double beforeMonitorVal = iter->second; double beforeMonitorVal = iter->second;
auto afteriter = afterResult.find(monitorName); auto afteriter = mAfterSchedulingResults.find(monitorName);
if (afteriter == afterResult.end()) if (afteriter == mAfterSchedulingResults.end())
continue; continue;
double afterMonitorvVal = afteriter->second; double afterMonitorvVal = afteriter->second;
...@@ -129,10 +174,8 @@ void CivOptSchedEngine::schedulingResultToJson(string& json) ...@@ -129,10 +174,8 @@ void CivOptSchedEngine::schedulingResultToJson(string& json)
json.append("],"); json.append("],");
} }
json = json.substr(0, json.length() - 1); json = json.substr(0, json.length() - 1);
json.append("},"); json.append("}");
}
json.substr(0, json.length() - 1);
json.append("]}");
} }
void CivOptSchedEngine::updateMonitorsVals(const map<string, double>& monitorVals) void CivOptSchedEngine::updateMonitorsVals(const map<string, double>& monitorVals)
...@@ -146,19 +189,8 @@ bool CivOptSchedEngine::beginCompute() ...@@ -146,19 +189,8 @@ bool CivOptSchedEngine::beginCompute()
CivInpConvertor convertor(mUri); CivInpConvertor convertor(mUri);
string inpFile = convertor.convertBaseInp(); string inpFile = convertor.convertBaseInp();
// 初始化计算
mSchedulingCompute = std::make_shared<CivSchedulingCompute>(CivSchedulingCompute::PumpScheduling); mSchedulingCompute = std::make_shared<CivSchedulingCompute>(CivSchedulingCompute::PumpScheduling);
// 构造水力计算对象
mSchedulingCompute->setMonitors(mMonitorsVec);
mSchedulingCompute->openFile(inpFile);
// 原始管网计算一次水力,保留调度前的水力计算结果
if (!mSchedulingCompute->calculate())
return false;
// 保存原始管网监测点的模拟值
mSchedulingCompute->getMonitorsValue(mPeriod,mBforeSchedulingResults);
// 获取水泵个数,根据水泵个数确定基因编码长度 // 获取水泵个数,根据水泵个数确定基因编码长度
CivPumpHelper pumpHelper(mUri); CivPumpHelper pumpHelper(mUri);
...@@ -169,13 +201,32 @@ bool CivOptSchedEngine::beginCompute() ...@@ -169,13 +201,32 @@ bool CivOptSchedEngine::beginCompute()
pumpHelper.getMap("本点号", "code", snToCodeMap); pumpHelper.getMap("本点号", "code", snToCodeMap);
// 获取本点号集合 // 获取本点号集合
vector<string> snVec; pumpHelper.getPumpSn(mPumpVec);
pumpHelper.getPumpSn(snVec); pumpHelper.getMonitors(mMonitorsVec);
/*string temp = "{";
for (int i = 0; i < mMonitorsVec.size(); i++)
{
temp.append("\\\"" + mMonitorsVec[i] + "\\\":{\\\"min\\\":20,\\\"max\\\":48},");
}
temp = temp.substr(0, temp.length() - 1);
temp.append("}");*/
// 构造水力计算对象
mSchedulingCompute->setMonitors(mMonitorsVec);
mSchedulingCompute->openFile(inpFile);
// 原始管网计算一次水力,保留调度前的水力计算结果
if (!mSchedulingCompute->calculate())
return false;
// 保存原始管网监测点的模拟值
mSchedulingCompute->getMonitorsValue(mPeriod, mBforeSchedulingResults);
} }
void CivOptSchedEngine::endCompute() void CivOptSchedEngine::endCompute()
{ {
mmSchedulingCompute->close(); mSchedulingCompute->close();
} }
void CivOptSchedEngine::setMonitors(const vector<string>& monitor) void CivOptSchedEngine::setMonitors(const vector<string>& monitor)
......
#pragma once #pragma once
#include <string> #include <string>
#include<memory>
#include <vector> #include <vector>
#include <map> #include <map>
#include "CivSchedulingCompute.h"
using namespace std; using namespace std;
class CivSchedulingCompute; class CivSchedulingCompute;
/** /**
优化调度客户端 优化调度客户端
*/ */
...@@ -32,13 +32,27 @@ public: ...@@ -32,13 +32,27 @@ public:
*/ */
void setSchedulingPeriod(int time) { mPeriod = time; } void setSchedulingPeriod(int time) { mPeriod = time; }
protected: void setMinMonitorVals(const map<string, double>& monitorVals)
{ mMinMonitorVals = monitorVals; }
void setMaxMonitorVals(const map<string, double>& monitorVals)
{ mMaxMonitorVals = monitorVals; }
/** /**
*@brief 将计算结果转换为json字符串 *@brief 将计算结果转换为json字符串
*@param [out] json 输出结果的字符串 *@param [out] json 输出结果的字符串
*/ */
void schedulingResultToJson(string& json); void schedulingResultToJson(string& json);
/**
* @brief 序列化到inp文件
* @param [inpName] inp文件名
*/
void serializeToInpFile(string& inpName);
protected:
/** /**
*@brief 调度之前的一些初始化操作 *@brief 调度之前的一些初始化操作
*/ */
...@@ -54,10 +68,10 @@ private: ...@@ -54,10 +68,10 @@ private:
map<int, string> mStatusBit; map<int, string> mStatusBit;
// 选出的最优组合 // 选出的最优组合
map<string, double> mPumpBestSpeed; map<string, float> mPumpBestSpeed;
// 监测点编码 // 监测点编码
vector<string>& mMonitorsVec; vector<string> mMonitorsVec;
// 实时计算的当前监测点的值 // 实时计算的当前监测点的值
map<string,double> mCurrentMonitorVals; map<string,double> mCurrentMonitorVals;
...@@ -69,6 +83,9 @@ private: ...@@ -69,6 +83,9 @@ private:
map<string, double> mBforeSchedulingResults; map<string, double> mBforeSchedulingResults;
map<string, double> mAfterSchedulingResults; map<string, double> mAfterSchedulingResults;
// 水泵编号,索引位代表
vector<string> mPumpVec;
// 数据连接地址 // 数据连接地址
string mUri; string mUri;
...@@ -87,9 +104,11 @@ private: ...@@ -87,9 +104,11 @@ private:
//基因编码长度 //基因编码长度
int mGenLength; int mGenLength;
std::shared_ptr< CivSchedulingCompute> mSchedulingCompute;
// 针对浮点数编码 // 针对浮点数编码
double mLeftPoint; double mLeftPoint;
double mRightPoint; double mRightPoint;
std::shared_ptr<CivSchedulingCompute> mSchedulingCompute;
}; };
...@@ -6,8 +6,8 @@ ...@@ -6,8 +6,8 @@
CivProjSimulation::CivProjSimulation(const std::string& uri):mUri(uri) CivProjSimulation::CivProjSimulation(const std::string& uri):mUri(uri)
{ {
mRptFile = CivCommonUtils::getExePath() + "\\test.rpt"; mRptFile = "ptest.rpt";
mBinFile = CivCommonUtils::getExePath() + "\\test.bin"; mBinFile = "ptest.bin";
} }
CivProjSimulation::~CivProjSimulation() CivProjSimulation::~CivProjSimulation()
......
...@@ -38,27 +38,37 @@ bool CivSchedulingCompute::openFile(const string& inpFILE) ...@@ -38,27 +38,37 @@ bool CivSchedulingCompute::openFile(const string& inpFILE)
return false; return false;
} }
if (ENinitH(EN_SAVE) > 0)
{
CivSysLog::getInstance()->error("ENinitH 失败", "CivHydrCompute", __FUNCTION__);
ENclose();
return false;
}
return true; return true;
} }
bool CivSchedulingCompute::saveInpFile(char* inpFile)
{
int code = ENsaveinpfile(inpFile);
if (code > 0)
return false;
return true;
}
bool CivSchedulingCompute::calculate() bool CivSchedulingCompute::calculate()
{ {
short hydCode = 1; short hydCode = 1;
long t(0), tstep(0); long t(0), tstep(0);
int iTime(0); int iTime(0);
if (ENinitH(EN_SAVE) > 0)
{
CivSysLog::getInstance()->error("ENinitH 失败", "CivHydrCompute", __FUNCTION__);
ENclose();
return false;
}
float dHStep; float dHStep;
ENGetVal(4, &dHStep); ENGetVal(4, &dHStep);
do
{
int nLinkCount; int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount); ENgetcount(EN_LINKCOUNT, &nLinkCount);
for (int i = 1; i <= nLinkCount; i++) for (int i = 1; i <= nLinkCount; i++)
...@@ -67,38 +77,61 @@ bool CivSchedulingCompute::calculate() ...@@ -67,38 +77,61 @@ bool CivSchedulingCompute::calculate()
int linkType; int linkType;
ENgetlinktype(i, &linkType); ENgetlinktype(i, &linkType);
if (linkType != EN_PUMP || linkType != EN_PBV) switch (linkType)
continue;
switch (mChdulingType)
{ {
case PumpScheduling& EN_PUMP: case EN_PUMP:
{ {
if (linkType != EN_PUMP)
continue;
char id[128] = ""; char id[128] = "";
ENgetlinkid(i, id); ENgetlinkid(i, id);
map<string,float>::iterator iter = mPumpSpeed.find(id); map<string, float>::iterator iter = mPumpSpeed.find(id);
if (iter == mPumpSpeed.end()) if (iter != mPumpSpeed.end())
continue; {
// 更新水泵的转速 // 更新水泵的转速
ENsetlinkvalue(i, EN_STATUS, iter->second ); ENsetlinkvalue(i, EN_STATUS, iter->second);
} }
break;
case PBVScheduling& EN_PBV:
{
if (linkType != EN_PBV)
continue;
} }
break; break;
case EN_PIPE:
case EN_PBV:
default: default:
break; break;
} }
//if (linkType != EN_PUMP || linkType != EN_PBV)
// continue;
//switch (mChdulingType)
//{
//case PumpScheduling& EN_PUMP:
//{
// if (linkType != EN_PUMP)
// continue;
// char id[128] = "";
// ENgetlinkid(i, id);
// map<string,float>::iterator iter = mPumpSpeed.find(id);
// if (iter == mPumpSpeed.end())
// continue;
// // 更新水泵的转速
// ENsetlinkvalue(i, EN_STATUS, iter->second );
//}
// break;
//case PBVScheduling& EN_PBV:
//{
// if (linkType != EN_PBV)
// continue;
//}
// break;
//default:
// break;
//}
} }
do
{
if (ENrunH(&t) > 100) // errcode > 100 是错误 if (ENrunH(&t) > 100) // errcode > 100 是错误
{ {
...@@ -147,11 +180,15 @@ void CivSchedulingCompute::setMonitors(const vector<string>& monitor) ...@@ -147,11 +180,15 @@ void CivSchedulingCompute::setMonitors(const vector<string>& monitor)
void CivSchedulingCompute::saveResult(int time) void CivSchedulingCompute::saveResult(int time)
{ {
// 计算节点 // 计算节点
int nNodeCount; int nNodeCount;
ENgetcount(EN_NODECOUNT, &nNodeCount); ENgetcount(EN_NODECOUNT, &nNodeCount);
map<string, double> pressureMap; map<string, double> pressureMap;
mMonitorsValue.push_back(pressureMap);
for (int i = 1; i <= nNodeCount; i++) for (int i = 1; i <= nNodeCount; i++)
{ {
char szNo[256]; char szNo[256];
...@@ -159,21 +196,23 @@ void CivSchedulingCompute::saveResult(int time) ...@@ -159,21 +196,23 @@ void CivSchedulingCompute::saveResult(int time)
// 判断是不是监测点 // 判断是不是监测点
auto iter = std::find(mMonitors.begin(), mMonitors.end(), szNo); auto iter = std::find(mMonitors.begin(), mMonitors.end(), szNo);
if (iter == mMonitors.end()) if (iter != mMonitors.end())
continue; {
float pressure; float pressure;
ENgetnodevalue(i, EN_PRESSURE, &pressure); // 压力 ENgetnodevalue(i, EN_PRESSURE, &pressure); // 压力
pressureMap.insert(pair<string, double>(szNo, pressure)); mMonitorsValue[time].insert(pair<string, double>(szNo, pressure));
}
} }
mMonitorsValue[time] = pressureMap;
} }
void CivSchedulingCompute::getPumpEnergy(int time) void CivSchedulingCompute::getPumpEnergy(int time)
{ {
int nLinkCount; int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount); ENgetcount(EN_LINKCOUNT, &nLinkCount);
map<string, float> energyMap;
mPumpEnergy.push_back(energyMap);
for (int i = 0; i < nLinkCount; i++) for (int i = 0; i < nLinkCount; i++)
{ {
// 获取管段类型 // 获取管段类型
...@@ -189,7 +228,7 @@ void CivSchedulingCompute::getPumpEnergy(int time) ...@@ -189,7 +228,7 @@ void CivSchedulingCompute::getPumpEnergy(int time)
ENgetlinkvalue(i, EN_ENERGY, &energy); ENgetlinkvalue(i, EN_ENERGY, &energy);
// 存储每个时刻的消耗的能量 // 存储每个时刻的消耗的能量
mPumpEnergy[time][szNo] = energy; mPumpEnergy[time].insert(pair<string,float>(szNo, energy));
} }
} }
...@@ -209,6 +248,12 @@ float CivSchedulingCompute::totalEnergy(int index) ...@@ -209,6 +248,12 @@ float CivSchedulingCompute::totalEnergy(int index)
return totalEnergy; return totalEnergy;
} }
void CivSchedulingCompute::clearLastVals()
{
mPumpEnergy.clear();
mMonitorsValue.clear();
}
void CivSchedulingCompute::updatePBVSettings(const string& sn, double pressure) void CivSchedulingCompute::updatePBVSettings(const string& sn, double pressure)
{ {
......
...@@ -29,6 +29,9 @@ public: ...@@ -29,6 +29,9 @@ public:
// 水力计算 // 水力计算
bool calculate(); bool calculate();
// 保存为inp文件
bool saveInpFile(char* inpFile);
// 结束计算,关闭文件句柄 // 结束计算,关闭文件句柄
void close(); void close();
...@@ -48,6 +51,9 @@ public: ...@@ -48,6 +51,9 @@ public:
// 获取每个时刻消耗的总能量 // 获取每个时刻消耗的总能量
float totalEnergy(int index); float totalEnergy(int index);
// 清除上一轮的值(很重要)
void clearLastVals();
private: private:
// 保存计算的值 // 保存计算的值
void saveResult(int time); void saveResult(int time);
......
...@@ -21,11 +21,23 @@ bool CivTrackingAnalysis::createGraphFrom() ...@@ -21,11 +21,23 @@ bool CivTrackingAnalysis::createGraphFrom()
CivInpConvertor convertor(mUri); CivInpConvertor convertor(mUri);
std::string inpFile = convertor.convertAnalysisInp(); std::string inpFile = convertor.convertAnalysisInp();
if (inpFile.empty()) if (inpFile.empty())
{
CivSysLog::getInstance()->info("构造图,转inp文件失败", "CivTrackingAnalysis", __FUNCTION__);
return false; return false;
}
CivHydrCompute dyCompute; CivHydrCompute dyCompute;
dyCompute.setInpFile(inpFile);
dyCompute.setRptFile("test.rpt");
dyCompute.setBinFile("test.bin");
if (!dyCompute.hdyrCompute()) if (!dyCompute.hdyrCompute())
{
CivSysLog::getInstance()->info("构造图,水力计算失败", "CivTrackingAnalysis", __FUNCTION__);
return false; return false;
}
NodeResultItems nodeItems; NodeResultItems nodeItems;
LinkResultItems linkItems; LinkResultItems linkItems;
...@@ -124,7 +136,11 @@ bool CivTrackingAnalysis::transformJson( ...@@ -124,7 +136,11 @@ bool CivTrackingAnalysis::transformJson(
// 管段 // 管段
size_t pipesTotal = pipes.size(); size_t pipesTotal = pipes.size();
if (pipesTotal <= 0) if (pipesTotal <= 0)
{
CivSysLog::getInstance()->error("追踪管段数为0", "CivTrackingAnalysis", __FUNCTION__);
return false; return false;
}
jsonResult.append("["); jsonResult.append("[");
......
...@@ -115,3 +115,21 @@ void CivPumpHelper::getPumpStations(vector<PumpStation>& stations) ...@@ -115,3 +115,21 @@ void CivPumpHelper::getPumpStations(vector<PumpStation>& stations)
stations.push_back(station); stations.push_back(station);
} }
} }
void CivPumpHelper::getMonitors(vector<string>& monitors)
{
string sql = "select node.\"本点号\" from \"节点\" as node, \"压力监测点\" as ja where node.\"code\" = ja.\"节点id\"";
if (!mConn->execSql(sql))
return;
vector<map<string, string>> tempMapVec;
mConn->queryResult(tempMapVec);
for (int i = 0; i < tempMapVec.size(); i++)
{
map<string, string> tempMap = tempMapVec[i];
string szNo = tempMap.find("本点号")->second;
monitors.push_back(szNo);
}
}
\ No newline at end of file
...@@ -30,6 +30,7 @@ public: ...@@ -30,6 +30,7 @@ public:
// 获取泵站 // 获取泵站
void getPumpStations(vector<PumpStation>& stations); void getPumpStations(vector<PumpStation>& stations);
void getMonitors(vector<string>& monitors);
private: private:
CivConnection* mConn = nullptr; CivConnection* mConn = nullptr;
......
#include "JsonParseObject.h" #include "JsonParseObject.h"
#include "cJSON.h" #include "cJSON.h"
JsonParseObject::JsonParseObject() JsonParseObject::JsonParseObject()
{ {
...@@ -9,7 +8,6 @@ JsonParseObject::JsonParseObject() ...@@ -9,7 +8,6 @@ JsonParseObject::JsonParseObject()
JsonParseObject::~JsonParseObject() JsonParseObject::~JsonParseObject()
{ {
cJSON_Delete(mResultJson);
} }
bool JsonParseObject::getKeys(vector<string>& keys) bool JsonParseObject::getKeys(vector<string>& keys)
...@@ -29,6 +27,37 @@ void JsonParseObject::read(map<string, string>& resMap) ...@@ -29,6 +27,37 @@ void JsonParseObject::read(map<string, string>& resMap)
} }
void JsonParseObject::read(map<string, vector<double>>& resMap)
{
if (!mResultJson)
return;
cJSON* parent = mResultJson->child;
if (!parent)
return;
while (parent)
{
string key = parent->string;
cJSON* child = parent->child;
if (child && child->next)
{
vector<double> minMaxValVec;
double minVal = child->valuedouble;
double maxVal = child->next->valuedouble;
minMaxValVec.push_back(minVal);
minMaxValVec.push_back(maxVal);
resMap.insert(pair<string, vector<double>>(key, minMaxValVec));
printf("key:%s, min: %f ,max: %f \n", key, minVal, maxVal);
}
parent = parent->next;
}
}
void JsonParseObject::clear() void JsonParseObject::clear()
{ {
cJSON_Delete(mResultJson); cJSON_Delete(mResultJson);
......
...@@ -2,15 +2,14 @@ ...@@ -2,15 +2,14 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include <map> #include <map>
#include "pandaLog.h" #include "pandaLog.h"
using namespace std; using namespace std;
class cJSON; class cJSON;
/** /**
json解析对象 json解析对象
*/ */
class PANDALOG_API JsonParseObject class PANDALOG_API JsonParseObject
{ {
...@@ -24,6 +23,8 @@ public: ...@@ -24,6 +23,8 @@ public:
void read(map<string, string>& resMap); void read(map<string, string>& resMap);
void read(map<string, vector<double>>& resMap);
// 主动销毁已读取的数据 // 主动销毁已读取的数据
void clear(); void clear();
private: private:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment