Commit d85a6654 authored by 刘乐's avatar 刘乐

1, 修改

parent 69423e9b
......@@ -102,7 +102,7 @@
<TargetName Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">$(ProjectName)_d</TargetName>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<OutDir>..\..\hModelProgram\lib\</OutDir>
<OutDir>$(ProjectDir)..\libs\x64\</OutDir>
<IntDir>$(ProjectDir)..\tmp\$(PlatformName)\$(ProjectName)\$(Configuration)\</IntDir>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
......
......@@ -81,3 +81,17 @@ void CivWaterSupplyScopeTest::test(char* uri)
std::cout << result << std::endl;
std::cout << "测试结果:" << isSucc << std::endl;
}
void CivProjSimulationTest::test(char* uri)
{
// 追踪节点编号
char projCode[512];
strcpy(projCode, "57cae198-838d-4776-8ec1-c195df12b00b");
char time[512];
strcpy(time, "2020-09-16 09:00:00");
bool isSucc = projSimulation(uri, projCode, time);
std::cout << "测试结果:" << isSucc << std::endl;
}
......@@ -64,3 +64,12 @@ class CivWaterSupplyScopeTest :public CivHydrTest
public:
virtual void test(char* uri);
};
/**
方案模拟接口
*/
class CivProjSimulationTest :public CivHydrTest
{
public:
virtual void test(char* uri);
};
\ No newline at end of file
......@@ -130,7 +130,7 @@
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<PreprocessorDefinitions>NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS;PANDANALYSIS_DLL;PANDANALYSIS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
<AdditionalIncludeDirectories>$(OUTDIR)..\include</AdditionalIncludeDirectories>
</ClCompile>
......@@ -139,7 +139,7 @@
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
<GenerateDebugInformation>false</GenerateDebugInformation>
<AdditionalDependencies>pandaAnalysis.lib;%(AdditionalDependencies)</AdditionalDependencies>
<AdditionalDependencies>pandaAnalysis.lib;pandaLog.lib;%(AdditionalDependencies)</AdditionalDependencies>
<AdditionalLibraryDirectories>$(OUTDIR)..\lib</AdditionalLibraryDirectories>
</Link>
</ItemDefinitionGroup>
......
......@@ -9,16 +9,15 @@
#include "CivHydrTest.h"
#include <vector>
#include <string>
#include <windows.h>
#include <consoleapi2.h>
using namespace std;
int main(int argc, char* argv[])
{
while (true)
{
const char* uri = "host=192.168.19.100 port=5432 dbname=JinXian user=postgres password=admin";
......@@ -32,6 +31,7 @@ int main(int argc, char* argv[])
cout << "\t4.上游追踪\n";
cout << "\t5.下游追踪\n";
cout << "\t6.水源供水范围分析\n";
cout << "\t7.方案模拟\n";
SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_INTENSITY | FOREGROUND_RED);
int test_no;
......@@ -72,6 +72,10 @@ int main(int argc, char* argv[])
context.setHydrTest(new CivWaterSupplyScopeTest());
context.contextTest(findUri);
break;
case 7://6.测试水源供水范围
context.setHydrTest(new CivProjSimulationTest());
context.contextTest(findUri);
break;
default:
cout << "输入测试号错误!" << endl;
break;
......
[2020-09-15 17:13:46][Info] CivSimulResultCache::save 开始存入数据
[2020-09-15 17:16:52][Info] CivSimulResultCache::save 开始存入数据
......@@ -17,6 +17,12 @@ CivBaseInpBuilder::~CivBaseInpBuilder()
delete mHelper;
}
void CivBaseInpBuilder::preHandleLikelyPipe()
{
mHelper->handleValve();
mHelper->handlePump();
}
void CivBaseInpBuilder::buildNode()
{
CivNode node;
......
......@@ -10,6 +10,7 @@ public:
explicit CivBaseInpBuilder(const std::string& uri);
~CivBaseInpBuilder();
virtual void preHandleLikelyPipe();
virtual void buildNode();
virtual void buildPipe();
virtual void buildTank();
......
......@@ -8,7 +8,6 @@
#define OUT
#define INOUT
#define ALGRAPHEXPORT __declspec(dllexport)
class CivDbConn;
......
......@@ -481,7 +481,6 @@ void CivHydrCompute::getLinkChlorine(short time)
void CivHydrCompute::saveResult(const std::string& uri)
{
mResultCache.save(uri);
}
......
......@@ -32,6 +32,7 @@ public:
void getNodeItemByInterval(int time, NodeResultItems& nodeItem);
void getPipeItemByInterval(int time, LinkResultItems& linkItem);
private:
void getNodeResult(short time);
void getLinkResult(short time);
......
......@@ -3,20 +3,21 @@
#include "CivHydrSimulation.h"
#include "CivTrackingAnalysis.h"
#include "CivProjSimulation.h"
bool FUNEXPORT hdyrSimulation(char* uri)
bool PANDANALYSIS_API hdyrSimulation(char* uri)
{
CivHydrSimulation simulation(uri);
return simulation.hdyrSimulation();
}
bool FUNEXPORT qualitySimulation(char* uri)
bool PANDANALYSIS_API qualitySimulation(char* uri)
{
CivHydrSimulation simulation(uri);
return simulation.qualitySimulation();
}
bool FUNEXPORT trackingSimulation(char* uri, char* sN, int hours, char* result)
bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours, char* result)
{
CivHydrSimulation simulation(uri);
......@@ -29,7 +30,7 @@ bool FUNEXPORT trackingSimulation(char* uri, char* sN, int hours, char* result)
return true;
}
bool FUNEXPORT upstreamTracking(char* uri, char* sn, char* result)
bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result)
{
CivTrackingAnalysis track(uri);
track.createGraphFrom();
......@@ -43,7 +44,7 @@ bool FUNEXPORT upstreamTracking(char* uri, char* sn, char* result)
return true;
}
bool FUNEXPORT downstreamTracking(char* uri, char* sn, char* result)
bool PANDANALYSIS_API downstreamTracking(char* uri, char* sn, char* result)
{
CivTrackingAnalysis track(uri);
track.createGraphFrom();
......@@ -56,13 +57,18 @@ bool FUNEXPORT downstreamTracking(char* uri, char* sn, char* result)
return true;
}
bool FUNEXPORT waterSupplyScopeAnalysis(char* uri, char* sn, char* result)
bool PANDANALYSIS_API waterSupplyScopeAnalysis(char* uri, char* sn, char* result)
{
return true;
}
bool FUNEXPORT projSimulation(char* uri, char* projCode, char* time)
bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time)
{
CivProjSimulation projSimulation(uri);
if (!projSimulation.simulationProj(projCode, time))
return false;
return true;
}
\ No newline at end of file
#ifndef CIVHYDRFUNCINTER_H
#define CIVHYDRFUNCINTER_H
#define FUNEXPORT __declspec(dllexport)
#include "pandaAnalysis.h"
#if defined(__cplusplus)
extern "C" {
......@@ -12,7 +11,7 @@ extern "C" {
*@param sn 追踪节点本点号
*@param result 追踪结果
*/
bool FUNEXPORT upstreamTracking(char* uri, char* sn, char* result);
bool PANDANALYSIS_API upstreamTracking(char* uri, char* sn, char* result);
/**
*@brief 下游追踪
......@@ -20,7 +19,7 @@ extern "C" {
*@param sn 追踪节点本点号
*@param result 追踪结果
*/
bool FUNEXPORT downstreamTracking(char* uri, char* sn, char* result);
bool PANDANALYSIS_API downstreamTracking(char* uri, char* sn, char* result);
/**
*@brief 供水范围追踪
......@@ -28,21 +27,21 @@ extern "C" {
*@param sn 追踪节点本点号
*@param result 追踪结果
*/
bool FUNEXPORT waterSupplyScopeAnalysis(char* uri, char* sn, char* result);
bool PANDANALYSIS_API waterSupplyScopeAnalysis(char* uri, char* sn, char* result);
/**
*@brief 水力计算服务
*@param uri:数据库连接地址
*@return 1:成功,其他值失败
*/
bool FUNEXPORT hdyrSimulation(char* uri);
bool PANDANALYSIS_API hdyrSimulation(char* uri);
/**
*@brief 水质计算
*@param uri:数据库连接地址
*@return 1:成功,其他值失败
*/
bool FUNEXPORT qualitySimulation(char* uri);
bool PANDANALYSIS_API qualitySimulation(char* uri);
/**
*@brief 水质追踪分析,扩散分析
......@@ -52,7 +51,7 @@ extern "C" {
*@param result:输出结果:json字符串
*@return 1:成功,其他值失败
*/
bool FUNEXPORT trackingSimulation(char* uri, char* sN, int hours,char* result);
bool PANDANALYSIS_API trackingSimulation(char* uri, char* sN, int hours,char* result);
/**
*@brief 方案模拟
......@@ -60,7 +59,7 @@ extern "C" {
*@param sN:追踪节点
*@param time:追踪小时
*/
bool FUNEXPORT projSimulation(char* uri, char* projCode, char* time);
bool PANDANALYSIS_API projSimulation(char* uri, char* projCode, char* time);
#if defined(__cplusplus)
......
......@@ -69,10 +69,6 @@ void CivInpBuilder::buildParamter()
}
}
void CivInpBuilder::resetAllToZero()
{
mResetToZero = true;
}
void CivInpBuilder::setQuality(const std::string& name, const std::string& val)
{
......@@ -107,3 +103,13 @@ void CivInpBuilder::buildVertices()
{
}
void CivInpBuilder::setPatternTime(const std::string& patternTime)
{
mHelper->setPatternTime(patternTime);
}
void CivInpBuilder::isDelayTimeSmuli(bool isDelay)
{
mHelper->isDelayTimeSimul(isDelay);
}
\ No newline at end of file
......@@ -2,6 +2,7 @@
#define _CIVINPEXPOTER_H
#include "CivNewInp.h"
#include "CivInpHelperAbs.h"
#include "pandaAnalysis.h"
#define ASSERT(A,B) if ((A) == nullptr || (B) == nullptr) return
/**
......@@ -23,6 +24,11 @@ public:
*/
void setTimes(const std::string& name, const std::string& val);
/**
*@brief 是否延时模拟
*/
void isDelayTimeSmuli(bool isDelay);
/**
*@brief 设置输出报告选项
*/
......@@ -35,7 +41,10 @@ public:
void setQuality(const std::string& name, const std::string& val);
void setQualityType(CivInpHelperAbs::QualityType type);
void resetAllToZero();
void resetAllToZero() { mResetToZero = true; }
void setPatternTime(const std::string& patternTime);
/**
*@brief 返回装成的inp文件名
*/
......@@ -48,6 +57,8 @@ public:
virtual void buildLabels();
virtual void buildVertices();
// 预处理,阀门,水泵等类管段类型的组件
virtual void preHandleLikelyPipe() = 0;
virtual void buildNode()=0;
virtual void buildPipe()=0;
virtual void buildTank()=0;
......@@ -64,9 +75,7 @@ public:
virtual void buildControls()=0;
virtual void buildRules()=0;
virtual void buildDemands()=0;
protected:
CivParameter mOptions;
CivParameter mTimes;
CivParameter mReactions;
......@@ -76,7 +85,10 @@ protected:
CivNewInp* mNewInp;
CivInpHelperAbs* mHelper;
std::string mPattenTime;
bool mResetToZero = false;
std::string mUri;
};
......
......@@ -26,21 +26,22 @@ bool CivInpConvertor::maintainTopo()
return true;
}
std::string CivInpConvertor::convertPorjInp(
const std::string& projCode,
const std::string& start)
std::string CivInpConvertor::convertPorjInp(const std::string& projCode, const std::string& start)
{
CivProjInpBuilder* builder = new CivProjInpBuilder(mUri);
builder->setProjCode(projCode);
builder->setTimes("Duration", "0");
builder->setTimes("Start Clocktime", start);
builder->isDelayTimeSmuli(false);
builder->setPatternTime(start);
CivInpDirector director;
director.setBuilder(builder);
director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp";
if (builder->getNewInp(inpFile))
std::string inpFile = CivCommonUtils::getExePath() + "\\ptest.inp";
if (!builder->getNewInp(inpFile))
{
delete builder;
return "";
......@@ -52,7 +53,6 @@ std::string CivInpConvertor::convertPorjInp(
std::string CivInpConvertor::convertBaseInp()
{
CivInpBuilder* builder = new CivBaseInpBuilder(mUri);
CivInpDirector director;
director.setBuilder(builder);
......@@ -69,14 +69,10 @@ std::string CivInpConvertor::convertBaseInp()
return inpFile;
}
std::string CivInpConvertor::convertTrackInp(const std::string& sn,
const std::string& hours)
std::string CivInpConvertor::convertTrackInp(const std::string& sn, const std::string& hours)
{
CivHydrTableHelper helper(mUri);
//if (!helper.mainTain())
//{
// return "";
//}
std::string codeTosn;
helper.getCodeToSn(sn, codeTosn);
......@@ -142,3 +138,27 @@ std::string CivInpConvertor::convertResidualInp()
delete builder;
return inpFile;
}
std::string CivInpConvertor::convertNotPorjInp(const std::string& simulTime)
{
CivInpBuilder* builder = new CivBaseInpBuilder(mUri);
builder->setTimes("Duration", "0");
builder->setTimes("Start Clocktime", simulTime);
builder->isDelayTimeSmuli(false);
builder->setPatternTime(simulTime);
CivInpDirector director;
director.setBuilder(builder);
director.create();
std::string inpFile = CivCommonUtils::getExePath() + "\\test.inp";
if (!builder->getNewInp(inpFile))
{
delete builder;
return "";
}
delete builder;
return inpFile;
}
\ No newline at end of file
......@@ -8,19 +8,23 @@
class CivInpConvertor
{
public:
explicit CivInpConvertor(const std::string& uri);
~CivInpConvertor();
bool maintainTopo();
/**
*@brief 转成方案模拟的inp文件
*@param projCode 方案编码
*@param startTime 模拟时间
*/
std::string convertPorjInp(const std::string& projCode,
const std::string& startTime);
std::string convertPorjInp(const std::string& projCode, const std::string& startTime);
/**
*@brief 根据模拟的时刻值转inp文件
*@param [std::string] simulTime 模拟时间
*/
std::string convertNotPorjInp(const std::string& simulTime);
/**
*@brief 转成方案普通inp
......@@ -32,7 +36,7 @@ public:
*@param sn 追踪的节点
*@param hours 追踪小时数
*/
std::string convertTrackInp(const std::string& sn,const std::string& hours);
std::string convertTrackInp(const std::string& sn, const std::string& hours);
std::string convertAnalysisInp();
......
......@@ -12,14 +12,15 @@ void CivInpDirector::create()
if (mBuilder == NULL)
return;
mBuilder->preHandleLikelyPipe(); // 增加预处理阀门,水泵等类管网类型
mBuilder->buildTank();
mBuilder->buildReservoir();
mBuilder->buildPatterns();
mBuilder->buildNode();
mBuilder->buildPipe();
mBuilder->buildPump();
mBuilder->buildVavle();
mBuilder->buildEmitter();
mBuilder->buildPatterns();
mBuilder->buildParamter();
mBuilder->buildCoordnates();
mBuilder->buildVertices();
......
......@@ -230,3 +230,9 @@ void CivProjInpBuilder::setProjCode(const std::string& projCode)
if (helper != nullptr)
helper->setProjCode(projCode);
}
void CivProjInpBuilder::preHandleLikelyPipe()
{
mHelper->handleValve();
mHelper->handlePump();
}
......@@ -4,7 +4,7 @@
/**
方案模拟转inp文件构造器
*/
class CivProjInpBuilder:public CivInpBuilder
class CivProjInpBuilder: public CivInpBuilder
{
public:
explicit CivProjInpBuilder(const std::string& uri);
......@@ -12,7 +12,8 @@ public:
/**/
void setProjCode(const std::string& projCode);
// 预处理,阀门,水泵等类管段类型的组件
void preHandleLikelyPipe() override;
void buildNode() override;
void buildPipe()override;
void buildTank()override;
......
#include "CivProjSimulation.h"
#include "CivCommonUtils.h"
#include "epanet2.h"
#include "CivInpConvertor.h"
#include "CivHydrTableHelper.h"
CivProjSimulation::CivProjSimulation()
CivProjSimulation::CivProjSimulation(const std::string& uri):mUri(uri)
{
mRptFile = CivCommonUtils::getExePath() + "\\test.rpt";
mBinFile = CivCommonUtils::getExePath() + "\\test.bin";
}
CivProjSimulation::~CivProjSimulation()
......@@ -10,7 +15,284 @@ CivProjSimulation::~CivProjSimulation()
}
bool CivProjSimulation::simulationProj()
bool CivProjSimulation::simulationProj(const std::string& projCode, const std::string& time)
{
mSimulTime = time;
mProjCode = projCode;
// 转inp之前先拓扑维护
CivHydrTableHelper helper(mUri);
if (!helper.mainTain())
return false;
// 缓存编码和code的映射
mProjCache.getCodeToSnMap(mUri);
// 转普通inp文件
CivInpConvertor conventor(mUri);
std::string baseInp = conventor.convertNotPorjInp(time);
// 转方案inp文件
std::string projInp = conventor.convertPorjInp(projCode, time);
char baseInpFile[256];
strcpy(baseInpFile, baseInp.c_str());
char projInpFile[256];
strcpy(projInpFile, projInp.c_str());
if (!projBeforeHydrCompute(baseInpFile))
return false;
if (!projHydrCompute(projInpFile))
return false;
if (!saveToDb())
return false;
return true;
}
bool CivProjSimulation::saveToDb()
{
return mProjCache.saveToUri(mUri,mSimulTime,mProjCode);
}
bool CivProjSimulation::projBeforeHydrCompute(char* inp)
{
short hydCode = 1;
long t(0), tstep(0);
int iTime(0);
int errcode = 0;
char rptFile[128];
strcpy_s(rptFile, mRptFile.c_str());
char binFile[128];
strcpy_s(binFile, mBinFile.c_str());
errcode = ENopen(inp, rptFile, binFile);
if (errcode > 0)
{
ENclose();
return false;
}
if (ENopenH() > 0)
{
ENclose();
return false;
}
if (ENinitH(0) > 0)
{
ENclose();
return false;
}
float dHStep;
ENGetVal(4, &dHStep);
do
{
int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount);
/*for (int i = 1; i <= nLinkCount; i++)
{
int linkType;
char id[128] = "";
ENgetlinktype(i, &linkType);
ENgetlinkid(i, id);
}*/
if (ENrunH(&t) > 100) // errcode > 100 是错误
{
ENclose();
return false;
}
// 获取计算结果
getNodeResult();
getLinkResult();
ENnextH(&tstep);
iTime++;
} while (tstep > 0);
ENcloseH();
ENclose();
return true;
}
bool CivProjSimulation::projHydrCompute(char* inp)
{
short hydCode = 1;
long t(0), tstep(0);
int iTime(0);
int errcode = 0;
char rptFile[128];
strcpy_s(rptFile, mRptFile.c_str());
char binFile[128];
strcpy_s(binFile, mBinFile.c_str());
errcode = ENopen(inp, rptFile, binFile);
if (errcode > 0)
{
ENclose();
return false;
}
if (ENopenH() > 0)
{
ENclose();
return false;
}
if (ENinitH(0) > 0)
{
ENclose();
return false;
}
float dHStep;
ENGetVal(4, &dHStep);
do
{
int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount);
/*for (int i = 1; i <= nLinkCount; i++)
{
int linkType;
char id[128] = "";
ENgetlinktype(i, &linkType);
ENgetlinkid(i, id);
}*/
if (ENrunH(&t) > 100) // errcode > 100 是错误
{
ENclose();
return false;
}
// 存储方案模拟结果数据
getProjNodeResult();
getProjLinkResult();
ENnextH(&tstep);
iTime++;
} while (tstep > 0);
ENcloseH();
ENclose();
return true;
}
void CivProjSimulation::getProjNodeResult()
{
// 计算节点
int nNodeCount;
ENgetcount(EN_NODECOUNT, &nNodeCount);
int* typeCode = (int*)malloc(sizeof(int));
for (int i = 1; i <= nNodeCount; i++)
{
ENgetnodetype(i, typeCode);
if (*typeCode != EN_JUNCTION)
continue;
NodeResultItem nodeItem;
ENgetnodeid(i, nodeItem.szNo);// 编号
ENgetnodevalue(i, EN_HEAD, &nodeItem.dHead);// 水头
mProjCache.addProjNodeHead(nodeItem.szNo, nodeItem.dHead);
ENgetnodevalue(i, EN_PRESSURE, &nodeItem.dPressure); // 压力
mProjCache.addProjNodePressure(nodeItem.szNo, nodeItem.dPressure);
}
free(typeCode);
}
void CivProjSimulation::getProjLinkResult()
{
int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount);
int* typeCode = (int*)malloc(sizeof(int));
for (int i = 1; i <= nLinkCount; i++)
{
LinkResultItem linkItem;
ENgetlinktype(i, typeCode);
if (*typeCode != EN_PIPE)
continue;
ENgetlinkid(i, linkItem.szNo); // 编号
ENgetlinkvalue(i, EN_FLOW, &linkItem.dFlow);// 流量
mProjCache.addProjPipeFlow(linkItem.szNo, linkItem.dFlow);
ENgetlinkvalue(i, EN_VELOCITY, &linkItem.dVelocity);// 流速
mProjCache.addProjPipeVelcoity(linkItem.szNo, linkItem.dVelocity);
ENgetlinkvalue(i, EN_HEADLOSS, &linkItem.dHeadloss);// 水头损失
mProjCache.addPipeHeadLoss(linkItem.szNo, linkItem.dHeadloss);
}
free(typeCode);
}
void CivProjSimulation::getNodeResult()
{
// 计算节点
int nNodeCount;
ENgetcount(EN_NODECOUNT, &nNodeCount);
int* typeCode = (int*)malloc(sizeof(int));
for (int i = 1; i <= nNodeCount; i++)
{
ENgetnodetype(i, typeCode);
if (*typeCode != EN_JUNCTION)
continue;
ProjNodeResultItem nodeItem;
ENgetnodeid(i, nodeItem.szNo);// 编号
ENgetnodevalue(i, EN_HEAD, &nodeItem.dHead);// 水头
ENgetnodevalue(i, EN_PRESSURE, &nodeItem.dPressure); // 压力
nodeItem.dDateTime =CivCommonUtils::currentTime(); // 当前时间
nodeItem.dTime = mSimulTime;
nodeItem.projCode = mProjCode;
mProjCache.addNodeItem(nodeItem);
}
free(typeCode);
}
void CivProjSimulation::getLinkResult()
{
int nLinkCount;
ENgetcount(EN_LINKCOUNT, &nLinkCount);
int* typeCode = (int*)malloc(sizeof(int));
for (int i = 1; i <= nLinkCount; i++)
{
PorjPipeResultItem linkItem;
ENgetlinktype(i, typeCode);
if (*typeCode != EN_PIPE)
continue;
ENgetlinkid(i, linkItem.szNo); // 编号
ENgetlinkvalue(i, EN_FLOW, &linkItem.dFlow);// 流量
ENgetlinkvalue(i, EN_VELOCITY, &linkItem.dVelocity);// 流速
ENgetlinkvalue(i, EN_HEADLOSS, &linkItem.dHeadLoss);// 水头损失
linkItem.dDateTime = CivCommonUtils::currentTime(); // 当前时间
linkItem.dTime =mSimulTime ;
linkItem.projCode = mProjCode;
mProjCache.addPipeItem(linkItem);
}
free(typeCode);
}
\ No newline at end of file
......@@ -2,6 +2,7 @@
#include <map>
#include <vector>
#include <string>
#include "CivProjSmulResultCache.h"
/**
方案模拟
......@@ -9,14 +10,49 @@
class CivProjSimulation
{
public:
explicit CivProjSimulation();
explicit CivProjSimulation(const std::string& uri);
~CivProjSimulation();
/**
*@brief 方案模拟
*@param [std::string] projCode 方案编码
*@param [std::string] time 模拟的时段
*/
bool simulationProj(const std::string& projCode,const std::string& time);
bool simulationProj();
/**
*@brief 计算数据刷进数据库
*/
bool saveToDb();
private:
/**
*@brief 不加方案的水力计算
*@param [char*] inp 计算inp格式文件
*/
bool projBeforeHydrCompute(char* inp);
/**
*@brief 方案的水力计算
*@param [char*] inp 计算inp格式文件
*/
bool projHydrCompute(char* inp);
void getNodeResult();
void getLinkResult();
void getProjNodeResult();
void getProjLinkResult();
private:
std::map<std::string, std::string> m;
std::string mUri;
CivProjSmulResultCache mProjCache; //方案模拟结果缓存
std::string mRptFile;
std::string mBinFile;
std::string mSimulTime; // 模拟的时刻
std::string mProjCode; // 方案编码
};
#include "CivProjSmulResultCache.h"
#include "CIvProjSimulResHelper.h"
CivProjSmulResultCache::CivProjSmulResultCache()
{
}
CivProjSmulResultCache::~CivProjSmulResultCache()
{
}
void CivProjSmulResultCache::addNodeItem(ProjNodeResultItem& nodeItem)
{
std::map<std::string, std::string>::iterator iter = mNodeCodeSnMap.find(nodeItem.szNo);
if (iter == mNodeCodeSnMap.end())
return;
std::string code = iter->second;
nodeItem.code = code;
mNodeCache.insert(std::pair<std::string, ProjNodeResultItem>(code,nodeItem));
}
void CivProjSmulResultCache::addPipeItem(PorjPipeResultItem& pipeItem)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeItem.szNo);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
pipeItem.code = code;
mPipeCache.insert(std::pair<std::string, PorjPipeResultItem>(code, pipeItem));
}
bool CivProjSmulResultCache::saveToUri(const std::string& dbUri,const std::string& time,const std::string& projCode)
{
CIvProjSimulResHelper simulResHelper(dbUri);
simulResHelper.deleteByTimeAndPorjcode(time, projCode);
std::vector< ProjNodeResultItem> nodeVec;
for (auto iter = mNodeCache.begin(); iter != mNodeCache.end(); iter++)
{
ProjNodeResultItem nodeItem = iter->second;
nodeVec.push_back(nodeItem);
}
std::vector<PorjPipeResultItem> pipeVec;
for (auto iter = mPipeCache.begin(); iter != mPipeCache.end(); iter++)
{
PorjPipeResultItem pipeItem = iter->second;
pipeVec.push_back(pipeItem);
}
simulResHelper.saveNodeToDb(nodeVec);
simulResHelper.savePipeToDb(pipeVec);
return true;
}
void CivProjSmulResultCache::addNodeHead(const std::string& nodeCode, float head)
{
std::map<std::string, std::string>::iterator iter = mNodeCodeSnMap.find(nodeCode);
if (iter == mNodeCodeSnMap.end())
return;
std::string code = iter->second;
mNodeCache[code].dHead = head;
}
void CivProjSmulResultCache::addNodePressure(const std::string& nodeCode, float pressure)
{
std::map<std::string, std::string>::iterator iter = mNodeCodeSnMap.find(nodeCode);
if (iter == mNodeCodeSnMap.end())
return;
std::string code = iter->second;
mNodeCache[code].dPressure = pressure;
}
void CivProjSmulResultCache::addPipeFlow(const std::string& pipeSn, float flow)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dFlow = flow;
}
void CivProjSmulResultCache::addPipeVelcoity(const std::string& pipeSn, float velcocity)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dVelocity = velcocity;
}
void CivProjSmulResultCache::addPipeHeadLoss(const std::string& pipeSn, float headLoss)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dHeadLoss = headLoss;
}
void CivProjSmulResultCache::addProjNodeHead(const std::string& nodeCode, float head)
{
std::map<std::string, std::string>::iterator iter = mNodeCodeSnMap.find(nodeCode);
if (iter == mNodeCodeSnMap.end())
return;
std::string code = iter->second;
mNodeCache[code].dProjHead = head;
}
void CivProjSmulResultCache::addProjNodePressure(const std::string& nodeCode, float pressure)
{
std::map<std::string, std::string>::iterator iter = mNodeCodeSnMap.find(nodeCode);
if (iter == mNodeCodeSnMap.end())
return;
std::string code = iter->second;
mNodeCache[code].dProjPressure = pressure;
}
void CivProjSmulResultCache::addProjPipeFlow(const std::string& pipeSn, float flow)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dProjFlow = flow;
}
void CivProjSmulResultCache::addProjPipeVelcoity(const std::string& pipeSn, float velcocity)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dProjVelocity = velcocity;
}
void CivProjSmulResultCache::addProjPipeHeadLoss(const std::string& pipeSn, float headLoss)
{
std::map<std::string, std::string>::iterator iter = mLineCodeSnMap.find(pipeSn);
if (iter == mLineCodeSnMap.end())
return;
std::string code = iter->second;
mPipeCache[code].dPorjHeadLoss = headLoss;
}
void CivProjSmulResultCache::getCodeToSnMap(const std::string& uri)
{
CivSimulResHelperAbs* helper = new CIvProjSimulResHelper(uri);
helper->getNodeCodeSnMap(mNodeCodeSnMap);
helper->getLinCodeSnMap(mLineCodeSnMap);
delete helper;
}
\ No newline at end of file
#pragma once
#include<string>
#include "CivSimuResStruct.h"
/**
*@brief 方案模拟结果缓存
*/
class CivProjSmulResultCache
{
public:
CivProjSmulResultCache();
~CivProjSmulResultCache();
void setProjCode(const std::string& projCode) { mProjCode = projCode; }
void addNodeHead(const std::string& nodeCode, float head);
void addNodePressure(const std::string& nodeCode, float pressure);
void addPipeFlow(const std::string& pipeSn, float flow);
void addPipeVelcoity(const std::string& pipeSn, float velcocity);
void addPipeHeadLoss(const std::string& pipeSn, float headLoss);
void addProjNodeHead(const std::string& nodeCode, float head);
void addProjNodePressure(const std::string& nodeCode, float pressure);
void addProjPipeFlow(const std::string& pipeSn, float flow);
void addProjPipeVelcoity(const std::string& pipeSn, float velcocity);
void addProjPipeHeadLoss(const std::string& pipeSn, float headLoss);
void addNodeItem(ProjNodeResultItem& nodeItem);
void addPipeItem(PorjPipeResultItem& pipeItem);
bool saveToUri(const std::string& dbUri, const std::string& time, const std::string& projCode);
// 缓存code到sn的映射
void getCodeToSnMap(const std::string& uri);
private:
std::string mProjCode; // 方案编码
std::map<std::string, ProjNodeResultItem> mNodeCache;
std::map<std::string, PorjPipeResultItem> mPipeCache;
std::map<std::string, std::string> mNodeCodeSnMap;
std::map<std::string, std::string> mLineCodeSnMap;
};
......@@ -5,9 +5,9 @@
#include <string>
#include <map>
#define ALGORITHMEXPORT __declspec(dllexport)
#include "pandaAnalysis.h"
class ALGORITHMEXPORT CivTrackingAnalysis
class CivTrackingAnalysis
{
public:
explicit CivTrackingAnalysis(const std::string& uri);
......
#pragma once
#if defined(PANDANALYSIS_DLL)
#if defined(PANDANALYSIS_EXPORTS)
#if defined(_MSC_VER)
#define PANDANALYSIS_API __declspec(dllexport)
#else
#define PANDADBMANAGER_API
#endif
#else
#if defined(_MSC_VER)
#define PANDADBMANAGER_API __declspec(dllimport)
#else
#define PANDADBMANAGER_API
#endif
#endif
#else
#define PANDADBMANAGER_API
#endif
......@@ -133,7 +133,7 @@
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;NDEBUG;PANDANALYSIS_DLL;PANDANALYSIS_EXPORTS;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
<AdditionalIncludeDirectories>$(SolutionDir)pandaDbManager;$(OUTDIR)..\include</AdditionalIncludeDirectories>
<Optimization>Disabled</Optimization>
......@@ -148,7 +148,8 @@
<ImportLibrary>$(OutDir)..\lib\$(TargetName).lib</ImportLibrary>
</Link>
<PostBuildEvent>
<Command>copy CivHydrFuncInter.h $(OutDir)..\include /y</Command>
<Command>copy CivHydrFuncInter.h $(OutDir)..\include /y
copy pandaAnalysis.h $(OutDir)..\include /y</Command>
</PostBuildEvent>
</ItemDefinitionGroup>
<ItemGroup>
......@@ -168,6 +169,7 @@
<ClCompile Include="CivProjInpBuilder.cpp" />
<ClCompile Include="CivProjManager.cpp" />
<ClCompile Include="CivProjSimulation.cpp" />
<ClCompile Include="CivProjSmulResultCache.cpp" />
<ClCompile Include="CivSimulResultCache.cpp" />
<ClCompile Include="CivStopWaterAnalysis.cpp" />
<ClCompile Include="CivTrackingAnalysis.cpp" />
......@@ -190,9 +192,11 @@
<ClInclude Include="CivProjInpBuilder.h" />
<ClInclude Include="CivProjManager.h" />
<ClInclude Include="CivProjSimulation.h" />
<ClInclude Include="CivProjSmulResultCache.h" />
<ClInclude Include="CivSimulResultCache.h" />
<ClInclude Include="CivStopWaterAnalysis.h" />
<ClInclude Include="CivTrackingAnalysis.h" />
<ClInclude Include="pandaAnalysis.h" />
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
......
......@@ -72,6 +72,9 @@
<ClCompile Include="CivStopWaterAnalysis.cpp">
<Filter>源文件</Filter>
</ClCompile>
<ClCompile Include="CivProjSmulResultCache.cpp">
<Filter>源文件</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="CivHydrFuncInter.h">
......@@ -134,5 +137,11 @@
<ClInclude Include="CivBreakPipeAnalysis.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="CivProjSmulResultCache.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="pandaAnalysis.h">
<Filter>头文件</Filter>
</ClInclude>
</ItemGroup>
</Project>
\ No newline at end of file
#include "CIvProjSimulResHelper.h"
#include "CivPgDbConnection.h"
CIvProjSimulResHelper::CIvProjSimulResHelper(const std::string& uri)
{
mConn = new CivPgDbConnection();
mConn->connect(uri);
mPreNodeSQL = "insert into \"方案模拟点表\"(\"code\",\"方案编码\",\"时间点\",\"水头\",\"压力\",\"方案水头\",\"方案压力\",\"修改时间\")";
mPrePipeSQL = "insert into \"方案模拟线表\" (\"code\",\"方案编码\",\"时间点\",\"流量\",\"流速\",\"单位水损\",\"方案流量\",\"方案流速\",\"方案单位水损\",\"修改时间\")";
}
CIvProjSimulResHelper::~CIvProjSimulResHelper()
{
mConn->disconnect();
delete mConn;
}
void CIvProjSimulResHelper::saveNodeToDb(const std::vector<ProjNodeResultItem>& nodeItems)
{
size_t total = nodeItems.size();
std::string nodeSql;
nodeSql.append(" values");
for (int i = 0; i < total; i++)
{
ProjNodeResultItem nodeItem = nodeItems[i];
if (nodeItem.dProjHead == 0 && nodeItem.dProjPressure == 0)
continue;
nodeSql.append("('");
nodeSql.append(nodeItem.code);
nodeSql.append("','");
nodeSql.append(nodeItem.projCode);
nodeSql.append("','");
nodeSql.append(nodeItem.dTime);
nodeSql.append("',");
nodeSql.append(std::to_string(nodeItem.dHead));
nodeSql.append(",");
nodeSql.append(std::to_string(nodeItem.dPressure));
nodeSql.append(",");
nodeSql.append(std::to_string(nodeItem.dProjHead));
nodeSql.append(",");
nodeSql.append(std::to_string(nodeItem.dProjPressure));
nodeSql.append(",'");
nodeSql.append(nodeItem.dDateTime);
nodeSql.append("'),");
}
nodeSql = nodeSql.substr(0, nodeSql.length() - 1);
std::string finalSql = mPreNodeSQL + nodeSql;
if (!mConn->execSql(finalSql))
return;
}
void CIvProjSimulResHelper::savePipeToDb(const std::vector<PorjPipeResultItem>& pipeItems)
{
std::string pipeSql;
pipeSql.append(" values");
size_t total = pipeItems.size();
for (int i = 0; i < total; i++)
{
PorjPipeResultItem pipItem = pipeItems[i];
if (pipItem.dProjFlow == 0 && pipItem.dProjVelocity == 0)
continue;
pipeSql.append("('");
pipeSql.append(pipItem.code);
pipeSql.append("','");
pipeSql.append(pipItem.projCode);
pipeSql.append("','");
pipeSql.append(pipItem.dTime);
pipeSql.append("',");
pipeSql.append(std::to_string(pipItem.dFlow));
pipeSql.append(",");
pipeSql.append(std::to_string(pipItem.dVelocity));
pipeSql.append(",");
pipeSql.append(std::to_string(pipItem.dHeadLoss));
pipeSql.append(",");
pipeSql.append(std::to_string(pipItem.dProjFlow));
pipeSql.append(",");
pipeSql.append(std::to_string(pipItem.dProjVelocity));
pipeSql.append(",");
pipeSql.append(std::to_string(pipItem.dPorjHeadLoss));
pipeSql.append(",'");
pipeSql.append(pipItem.dDateTime);
pipeSql.append("'),");
}
pipeSql = pipeSql.substr(0,pipeSql.length()-1);
std::string finalSql = mPrePipeSQL + pipeSql;
mConn->execSql(finalSql);
}
void CIvProjSimulResHelper::deleteByTimeAndPorjcode( const std::string& time,const std::string& projCode)
{
std::string nodeDelsql = "delete from \"方案模拟点表\" where \"时间点\"='" + time + "' and \"方案编码\" = '"+projCode+"'";
mConn->execSql(nodeDelsql);
std::string lineDelsql = "delete from \"方案模拟线表\" where \"时间点\"='" + time + "' and \"方案编码\" = '" + projCode + "'";
mConn->execSql(lineDelsql);
}
#pragma once
#include<string>
#include<vector>
#include "CivSimuResStruct.h"
#include "pandaDbManager.h"
#include "CivSimulResHelperAbs.h"
class CivConnection;
/**
*@brief 方案模拟结果操作类型
*/
class PANDADBMANAGER_API CIvProjSimulResHelper:public CivSimulResHelperAbs
{
public:
explicit CIvProjSimulResHelper(const std::string& uri);
~CIvProjSimulResHelper();
/**
*@brief 保存方案模拟的节点数据
*@param [ProjNodeResultItem] nodeItem 模拟的节点值
*/
virtual void saveNodeToDb(const std::vector<ProjNodeResultItem>& nodeItem);
/**
*@brief 保存方案模拟的管段数据
*@param [PorjPipeResultItem] nodeItem 模拟的节点值
*/
virtual void savePipeToDb(const std::vector<PorjPipeResultItem>& pipeItem);
// 根据时间点字段删除数据
void deleteByTimeAndPorjcode(const std::string& time, const std::string& projCode);
private:
std::string mPreNodeSQL;
std::string mPrePipeSQL;
};
......@@ -2,9 +2,9 @@
#define CIVASSEMBLY_H
#include "CivTypes.h"
#include <list>
#pragma warning(disable:4251)
#include "pandaDbManager.h"
#define DBEXPORT __declspec(dllexport)
#pragma warning(disable:4251)
#define Str std::string
......@@ -30,7 +30,7 @@ class CivAssembly
/**
节点类型
*/
class DBEXPORT CivNode: public CivAssembly
class PANDADBMANAGER_API CivNode: public CivAssembly
{
public:
typedef struct Table
......@@ -49,7 +49,7 @@ public:
/**
* 管线类型
*/
class DBEXPORT CivPipe: public CivAssembly
class PANDADBMANAGER_API CivPipe: public CivAssembly
{
public:
typedef struct Table
......@@ -74,7 +74,7 @@ public:
/*
水池类型
*/
class DBEXPORT CivTank:public CivAssembly
class PANDADBMANAGER_API CivTank:public CivAssembly
{
public:
typedef struct Table
......@@ -97,7 +97,7 @@ public:
/*
定义包含在管网中所有控制阀门。
*/
class DBEXPORT CivValve :public CivAssembly
class PANDADBMANAGER_API CivValve :public CivAssembly
{
public:
typedef struct Table
......@@ -119,7 +119,7 @@ public:
/**
水泵
*/
class DBEXPORT CivPumps :public CivAssembly
class PANDADBMANAGER_API CivPumps :public CivAssembly
{
public:
typedef struct Table
......@@ -138,7 +138,7 @@ public:
/*
定义管网中包含的所有水库节点
*/
class DBEXPORT CivReservoirs :public CivAssembly
class PANDADBMANAGER_API CivReservoirs :public CivAssembly
{
public:
typedef struct Table
......@@ -161,7 +161,7 @@ public:
/**
EMITTERS将模拟节点定义为扩散器(喷嘴或者孔口)。
*/
class DBEXPORT CivEmitters :public CivAssembly
class PANDADBMANAGER_API CivEmitters :public CivAssembly
{
public:
typedef struct Table
......@@ -181,7 +181,7 @@ public:
/**
坐标
*/
class DBEXPORT CivCoordinates :public CivAssembly
class PANDADBMANAGER_API CivCoordinates :public CivAssembly
{
public:
typedef struct Table
......@@ -201,7 +201,7 @@ public:
/**
参数控制选项
*/
class DBEXPORT CivMixing :public CivAssembly
class PANDADBMANAGER_API CivMixing :public CivAssembly
{
public:
typedef struct Table
......@@ -223,7 +223,7 @@ public:
/**
确定控制蓄水池混合的模型。
*/
class DBEXPORT CivParameter :public CivAssembly
class PANDADBMANAGER_API CivParameter :public CivAssembly
{
public:
typedef struct Table
......@@ -274,7 +274,7 @@ public:
/**
模式
*/
class DBEXPORT CivPatterns :public CivAssembly
class PANDADBMANAGER_API CivPatterns :public CivAssembly
{
public:
typedef struct Table
......@@ -290,7 +290,7 @@ public:
/*
定义数据曲线及其X、Y点。
*/
class DBEXPORT CivCurves :public CivAssembly
class PANDADBMANAGER_API CivCurves :public CivAssembly
{
public:
typedef struct Table
......@@ -307,7 +307,7 @@ public:
/**
定义连接节点的多模式需水,是对[JUNCTIONS]的补充。
*/
class DBEXPORT CivDemands :public CivAssembly
class PANDADBMANAGER_API CivDemands :public CivAssembly
{
public:
typedef struct Table
......@@ -329,7 +329,7 @@ public:
};
// 定义水质源头的位置。
class DBEXPORT CivSources :public CivAssembly
class PANDADBMANAGER_API CivSources :public CivAssembly
{
public:
typedef struct Table
......@@ -351,7 +351,7 @@ public:
};
// 定义模拟开始时被选管段的初始状态。
class DBEXPORT CivStatus :public CivAssembly
class PANDADBMANAGER_API CivStatus :public CivAssembly
{
public:
typedef struct Table
......@@ -369,7 +369,7 @@ public:
};
// 定义节点的初始水质。
class DBEXPORT CivQuality :public CivAssembly
class PANDADBMANAGER_API CivQuality :public CivAssembly
{
public:
typedef struct Table
......@@ -387,7 +387,7 @@ public:
};
// 给地图标签赋以坐标值。
class DBEXPORT CivLabels :public CivAssembly
class PANDADBMANAGER_API CivLabels :public CivAssembly
{
public:
typedef struct Table
......@@ -410,7 +410,7 @@ public:
};
// 将类型标签与特定节点和管段相连。
class DBEXPORT CivTags :public CivAssembly
class PANDADBMANAGER_API CivTags :public CivAssembly
{
public:
typedef struct Table
......
......@@ -21,17 +21,25 @@ CivHydrTableHelper::~CivHydrTableHelper()
bool CivHydrTableHelper::mainTain()
{
//unTopoMaintain();
// 节点
// 管网组件
updateAssem(TABLE_NODE, std::string("本点号"), "JD");
updateAssem(TABLE_PIPE, std::string("编号"), "GD");
updateAssem(TABLE_TANK, std::string("本点号"), "TK");
updateAssem(TABLE_VALVEE, std::string("本点号"), "VA");
updateAssem(TABLE_VALVE, std::string("本点号"), "VA");
updateAssem(TABLE_RESERVOIR, std::string("本点号"), "RE");
updateAssem(TABLE_PUMP, std::string("本点号"), "PU");
// 方案管网组件
updateAssem(PROJ_TABLE_NODE, std::string("本点号"), "PJD");
updateAssem(PROJ_TABLE_PIPE, std::string("编号"), "PGD");
updateAssem(PROJ_TABLE_TANK, std::string("本点号"), "PTK");
updateAssem(PROJ_TABLE_VALVE, std::string("本点号"), "PVA");
updateAssem(PROJ_TABLE_RESERVOIR, std::string("本点号"), "PRE");
updateAssem(PROJ_TABLE_PUMP, std::string("本点号"), "PPU");
if (!topoMaintain())
return false;
return true;
}
......@@ -65,8 +73,7 @@ void CivHydrTableHelper::updateAssem(const std::string& table, const std::string
sql = sql.substr(0, sql.length() - 1);
sql += ") as tmp(id, \""+ filed +"\") where "+ table +".id = tmp.id; ";
std::string utfsql = CivCommonUtils::string_To_UTF8(sql);
if (mConn && mConn->execSql(utfsql))
if (mConn && mConn->execSql(sql))
{
mErrInfo = mConn->getLastError();
return;
......@@ -75,18 +82,47 @@ void CivHydrTableHelper::updateAssem(const std::string& table, const std::string
bool CivHydrTableHelper::topoMaintain()
{
// 管段与
topoMainTable(TABLE_PIPE, TABLE_NODE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_NODE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(TABLE_PIPE, TABLE_RESERVOIR, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_TANK, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_VALVEE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_VALVEE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoValve(std::string("起始节点"),std::string("from_code"),std::string("to_code"));
topoValve(std::string("终止节点"), std::string("to_code"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_VALVE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, TABLE_VALVE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_NODE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_NODE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_RESERVOIR, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_TANK, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_VALVE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(TABLE_PIPE, PROJ_TABLE_VALVE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_NODE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_NODE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_RESERVOIR, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_TANK, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_VALVE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, TABLE_VALVE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_NODE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_NODE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_RESERVOIR, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_TANK, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_VALVE, std::string("起始节点"), std::string("本点号"), std::string("from_code"));
topoMainTable(PROJ_TABLE_PIPE, PROJ_TABLE_VALVE, std::string("终止节点"), std::string("本点号"), std::string("to_code"));
// 处理方案和阀门的拓扑关系
topoLikelyPipe(TABLE_PIPE, TABLE_VALVE, std::string("起始节点"), std::string("to_code"));
topoLikelyPipe(TABLE_PIPE, TABLE_VALVE, std::string("终止节点"), std::string("from_code"));
topoLikelyPipe(PROJ_TABLE_PIPE, TABLE_VALVE, std::string("起始节点"), std::string("to_code"));
topoLikelyPipe(PROJ_TABLE_PIPE, TABLE_VALVE, std::string("终止节点"), std::string("from_code"));
topoLikelyPipe(TABLE_PIPE, PROJ_TABLE_VALVE, std::string("起始节点"), std::string("to_code"));
topoLikelyPipe(TABLE_PIPE, PROJ_TABLE_VALVE, std::string("终止节点"), std::string("from_code"));
return true;
}
bool CivHydrTableHelper::unTopoMaintain()
......@@ -95,7 +131,7 @@ bool CivHydrTableHelper::unTopoMaintain()
unTopoTable(TABLE_PIPE, { std::string("编号"),std::string("起始节点"),std::string("终止节点") });
unTopoTable(TABLE_RESERVOIR, { std::string("本点号")});
unTopoTable(TABLE_TANK, { std::string("本点号") });
unTopoTable(TABLE_VALVEE, { std::string("本点号"),std::string("起始节点"),std::string("终止节点") });
unTopoTable(TABLE_VALVE, { std::string("本点号"),std::string("起始节点"),std::string("终止节点") });
return true;
}
......@@ -119,15 +155,30 @@ bool CivHydrTableHelper::topoMainTable(const std::string& sourceTable,
return true;
}
bool CivHydrTableHelper::topoLikelyPipe(const std::string& pipeTable, const std::string& nodeTable, const std::string& filed, const std::string& tocode)
{
std::string sql = "update \""+nodeTable+"\" as pu set \""+filed+"\" = \
(select pipe.\"编号\" from \""+pipeTable+"\" as pipe where pipe.\""+tocode+"\"=pu.\"code\") where exists (select 1 from \""+pipeTable+"\" as pipe1 where pipe1.\""+tocode+"\"=pu.\"code\")";
if (mConn && !mConn->execSql(sql))
{
mErrInfo = mConn->getLastError();
return false;
}
return true;
}
bool CivHydrTableHelper::topoValve(const std::string& sn,
const std::string& fromcode,
const std::string& tocode)
{
std::string sql = "update \"";
sql.append(TABLE_VALVEE);
sql.append(TABLE_VALVE);
sql.append("\" set \"" + sn + "\" = dd.\"本点号\"\
from(select node.\"本点号\" \"本点号\", node.\"code\" \"nodecode\", tt.\"code\" \"vacode\" from \
\""+TABLE_NODE+"\" node, (select t2.\""+tocode+"\" \""+tocode+"\", t1.\"code\" \"code\" from \""+TABLE_PIPE+"\" t2, \""+TABLE_VALVEE+"\" t1 where t2.\""+fromcode+"\" = t1.\"code\") tt\
\""+TABLE_NODE+"\" node, (select t2.\""+tocode+"\" \""+tocode+"\", t1.\"code\" \"code\" from \""+TABLE_PIPE+"\" t2, \""+TABLE_VALVE+"\" t1 where t2.\""+fromcode+"\" = t1.\"code\") tt\
where node.\"code\" = tt.\""+tocode+"\") dd\
where \"code\" = dd.\"vacode\"");
......
......@@ -2,12 +2,12 @@
#include<string>
#include<vector>
#include<map>
#include "pandaDbManager.h"
#include "CivConnection.h"
#define HYDRTABLEEXPORT __declspec(dllexport)
class HYDRTABLEEXPORT CivHydrTableHelper
class PANDADBMANAGER_API CivHydrTableHelper
{
public:
......@@ -39,6 +39,9 @@ private:
*@brief 拓扑维护阀门,需要特殊处理
*/
bool topoValve(const std::string& sn,const std::string& fromcode,const std::string& tocode );
bool topoLikelyPipe(const std::string& pipeTable, const std::string& nodeTable,
const std::string& filed, const std::string& tocode);
private:
std::vector<std::string> mNecessTables;
std::map<std::string, std::string> mNeedTableMap;
......
#include "CivInp.h"
#include<time.h>
bool CivInp::writeToFile(const char* fileName)
{
FILE* file;
std::string ss;
if (file = fopen(fileName, "wb"))
{
fprintf(file, mTextStream.str().c_str());
return true;
}
return false;
}
std::string CivInp::currentTime()
{
time_t timep;
struct tm* p;
time(&timep);
p = gmtime(&timep);
std::string currTime = std::to_string(1900 + p->tm_year) + "/" + std::to_string(1 + p->tm_mon) + \
"/" + std::to_string(p->tm_mday) + " " + std::to_string(p->tm_hour) + ":" + std::to_string(p->tm_min) + ":" + \
std::to_string(p->tm_sec);
return currTime;
}
void CivInp::writeTitles()
{
writeString("[TITLE]"); // дǩ
writeString("Scenario: Base");
writeString("Date:"+currentTime());
writeString("");
writeString("");
}
void CivInp::writeJunctions(Civitems items)
{
writeString("[JUNCTIONS]");
writeString(";ID Elev Demand Pattern ");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeItems(const Civitems& items)
{
size_t rows = items.size();
for (int i = 0; i < rows; i++)
{
CivItem item = items[i];
size_t itemSize = item.size();
int index = 0;
std::string itemStr = item[0] + " ";
while ((++index) < itemSize)
itemStr = item[index] + " ";
writeString(itemStr);
}
}
void CivInp::writePipes(Civitems items)
{
writeString("[PIPES]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeTanks(Civitems items)
{
writeString("[TANKS]");
writeString(";ID Elevation InitLevel MinLevel MaxLevel Diameter MinVol VolCurve");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeReservoirs(Civitems items)
{
writeString("[RESERVOIRS]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writePumps(Civitems items)
{
writeString("[PUMPS]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeValves(Civitems items)
{
writeString("[VALVES]");
writeString(";ID Node1 Node2 Diameter Type Setting MinorLoss ");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeCoordinates(Civitems items)
{
writeString("[PIPES]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeLabels(Civitems items)
{
writeString("[PIPES]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeVertices(Civitems items)
{
writeString("[PIPES]");
writeString(";ID Node1 Node2 Length Diameter Roughness MinorLoss Status");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeDemand(Civitems items)
{
writeString("[DEMANDS]");
writeString(";Junction Demand Pattern Category");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeOptions(const Civitems& items)
{
writeString("[OPTIONS]");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writePatterns(Civitems items)
{
writeString("[PATTERNS]");
writeString(";ID Multipliers");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeBackdrop(Civitems items)
{
writeString("[BACKDROP]");
writeItems(items);
writeString("");
writeString("");
}
void CivInp::writeEnd()
{
writeString("[END]");
}
void CivInp::writeString(const std::string& s)
{
mTextStream << s << "\n";
}
\ No newline at end of file
#pragma once
#include <string>
#include <sstream>
#include <vector>
#define CivItem std::vector<std::string>
#define Civitems std::vector<CivItem>
/**
inp文件对象模型
*/
class CivInp
{
public:
/**
*@brief 保存inp文件
*@fileName: 文件名
*/
bool writeToFile(const char* fileName);
void writeTitles();
void writeJunctions(Civitems items);
void writePipes(Civitems items);
void writeTanks(Civitems items);
void writeReservoirs(Civitems items);
void writePumps(Civitems items);
void writeValves(Civitems items);
void writeCoordinates(Civitems items);
void writeLabels(Civitems items);
void writeVertices(Civitems items);
void writeBackdrop(Civitems items);
void writeEnd();
void writeString(const std::string& s);
void writeItems(const Civitems& items);
void writeOptions(const Civitems& items);
void writePatterns(Civitems items);
void writeDemand(Civitems items);
std::string currentTime();
private:
std::ostringstream mTextStream;
};
......@@ -5,12 +5,11 @@
#include <algorithm>
CivInpDbHelper::CivInpDbHelper(const std::string& uri)
:CivInpHelperAbs(uri)
{
mCondtion = "1=1 ";
isDelayTime = true;
}
CivInpDbHelper::~CivInpDbHelper()
......@@ -39,11 +38,47 @@ bool CivInpDbHelper::getNode(CivNode& node)
nodeTable.ID = map.find(nodeTableFields.sn)->second;
nodeTable.Elev = map.find(nodeTableFields.elev)->second;
nodeTable.Demand = map.find(nodeTableFields.baseDemand)->second;
nodeTable.PatternId = map.find(nodeTableFields.demandPattern)->second;
std::string patternID = map.find(nodeTableFields.demandPattern)->second;
std::string demand = map.find(nodeTableFields.baseDemand)->second;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
//// 是否做延时模拟
//if (isDelayTime)
//{
// nodeTable.Demand = demand;
// nodeTable.PatternId = patternID;
//}
//else
//{
// auto iter = mPatterns.find(patternID);
// if (iter != mPatterns.end())
// {
// std::vector<std::string> mulitiers = iter->second;
// if (mPatternTime > mulitiers.size())
// mPatternTime = mulitiers.size() - 1;
// if (mPatternTime < 0)
// mPatternTime = 0;
// std::string mulitier = mulitiers[mPatternTime];
// float intMul = std::atof(mulitier.c_str());
// float dem = std::atof(demand.c_str());
// demand = std::to_string(dem * intMul);
// nodeTable.Demand = demand;
// }
//}
node.addItem(nodeTable);
}
// 添加处理的阀门产生的节点
size_t size = mNodeVec.size();
for (int i = 0; i < size; i++)
{
node.addItem(mNodeVec[i]);
}
return true;
}
......@@ -51,86 +86,6 @@ bool CivInpDbHelper::getPipe(CivPipe& pipes)
{
PipeTable pipeTable;
// 注意去重
// 查找与阀门像连的管段
std::string sql = "select pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", \
pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\",pipe.\"局损系数\",\
pipe.\"初始状态\",va.\"本点号\", pipe.\"code\",\
va.\"类型\" from \"管段\" as pipe, \"阀门\" as va where pipe.\"起始节点\" = va.\"本点号\" \
or pipe.\"终止节点\" = va.\"本点号\" order by \"本点号\"";
if (!mDbConn->execSql(sql))
{
return false;
}
std::vector<std::map<std::string, std::string>> resultMap;
mDbConn->queryResult(resultMap);
int toal = resultMap.size();
std::string repeatSn;
std::string repeatVaType;
std::string starNode;
std::string endNode;
// 存储已拼接的管段CODE,为下面去重
std::set<std::string> filterSet;
for (int i = 0; i < toal; i++)
{
std::map<std::string, std::string> tempMap = resultMap[i];
std::string sn = tempMap.find("本点号")->second;
std::string vaType = tempMap.find("类型")->second;
std::string pipeCode = tempMap.find(pipeTable.code)->second;
filterSet.insert(pipeCode);
if (repeatVaType == "BV") // 止回阀,是管段的一部分,需要合并管段
{
if (sn == repeatSn && repeatVaType == vaType)
{
CivPipe::PipesTable pipe;
pipe.ID = tempMap.find(pipeTable.snNo)->second;
std::string secondStartNode = tempMap.find(pipeTable.startPoint)->second;
std::string secondEndNode = tempMap.find(pipeTable.endPoint)->second;
if (starNode == repeatSn)
{
pipe.Node1 = secondStartNode;
pipe.Node2 = endNode;
}
else if (endNode == repeatSn)
{
pipe.Node1 = starNode;
pipe.Node2 = secondEndNode;
}
pipe.Length = tempMap.find(pipeTable.length)->second;
pipe.Diameter = tempMap.find(pipeTable.diameter)->second;
pipe.Roughness = tempMap.find(pipeTable.friction)->second;
pipe.MinorLoss = tempMap.find(pipeTable.localLoss)->second;
pipe.Status = tempMap.find(pipeTable.status)->second;
pipes.addItem(pipe);
}
repeatVaType = vaType;
repeatSn = sn;
starNode = tempMap.find(pipeTable.startPoint)->second;
endNode = tempMap.find(pipeTable.endPoint)->second;
} // 其他独立阀门处理
else
{
}
}
std::vector<std::string> fields;
fields.push_back(pipeTable.snNo);
fields.push_back(pipeTable.startPoint);
......@@ -143,19 +98,10 @@ bool CivInpDbHelper::getPipe(CivPipe& pipes)
fields.push_back(pipeTable.code);
std::vector<std::map<std::string, std::string>> resultVector;
std::string condition = " \"code\" not in (";
for (auto iter = filterSet.begin(); iter != filterSet.end(); iter++)
{
std::string code = *iter;
condition.append("'"+code+"'");
condition.append(",");
}
condition = condition.substr(0, condition.length() - 1);
condition.append(")");
std::string condition = "\"from_layer\" not in ('阀门','水泵' ) and \"to_layer\" not in ('阀门','水泵' )";
mDbConn->query(PIPELINE, fields, resultVector, condition);
size_t total = resultVector.size();
for (int i = 0; i < total; i++)
{
......@@ -173,6 +119,12 @@ bool CivInpDbHelper::getPipe(CivPipe& pipes)
pipe.Status = map.find(pipeTable.status)->second;
pipe.code = map.find(pipeTable.code)->second;
pipes.addItem(pipe);
}
// 构造的管段
size_t size = mPipesVec.size();
for (int i = 0; i < size; i++)
{
pipes.addItem(mPipesVec[i]);
}
return true;
}
......@@ -217,7 +169,7 @@ bool CivInpDbHelper::getTank(CivTank& tanks)
bool CivInpDbHelper::getValve(CivValve& valves)
{
ValveTable vaveTable;
/*ValveTable vaveTable;
std::vector<std::string> fields;
fields.push_back(vaveTable.sn);
......@@ -250,7 +202,14 @@ bool CivInpDbHelper::getValve(CivValve& valves)
vave.MinorLoss = map.find(vaveTable.lossCoeff)->second;
valves.addItem(vave);
}*/
size_t size = mValuvesVec.size();
for (int i = 0; i < size; i++)
{
valves.addItem(mValuvesVec[i]);
}
return true;
}
......@@ -350,6 +309,12 @@ bool CivInpDbHelper::getCoordinates(CivCoordinates& coord)
coord.addItem(coordTable);
}
// 加入阀门处理的节点坐标
size_t size = mCoords.size();
for (int i = 0; i < size; i++)
{
coord.addItem(mCoords[i]);
}
return true;
}
......@@ -396,119 +361,275 @@ bool CivInpDbHelper::getQuality(CivQuality& quality)
bool CivInpDbHelper::getStatus(CivStatus& status)
{
ValveTable vaTable;
//ValveTable vaTable;
std::vector<std::string> fields;
fields.push_back(vaTable.sn);
fields.push_back(vaTable.fixedState);
fields.push_back(vaTable.type);
//std::vector<std::string> fields;
//fields.push_back(vaTable.sn);
//fields.push_back(vaTable.fixedState);
//fields.push_back(vaTable.type);
std::vector<std::map<std::string, std::string>> resultVector;
//std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(VALVE, fields, resultVector);
//mDbConn->query(VALVE, fields, resultVector);
size_t total = resultVector.size();
for (int i = 0; i < total; i++)
{
CivStatus::StatusTable statTable;
auto resMap = resultVector[i];
//size_t total = resultVector.size();
//for (int i = 0; i < total; i++)
//{
// CivStatus::StatusTable statTable;
std::string state = resMap.find(vaTable.fixedState)->second;
std::string type = resMap.find(vaTable.type)->second;
// auto resMap = resultVector[i];
//
// std::string state = resMap.find(vaTable.fixedState)->second;
// std::string type = resMap.find(vaTable.type)->second;
std::transform(state.begin(), state.end(), state.begin(), ::toupper);
if (type == "BV")
continue;
// std::transform(state.begin(), state.end(), state.begin(), ::toupper);
// if (type == "BV")
// continue;
statTable.ID = resMap.find(vaTable.sn)->second;
statTable.Setting = state;
// statTable.ID = resMap.find(vaTable.sn)->second;
// statTable.Setting = state;
status.addItem(statTable);
// status.addItem(statTable);
//}
// 阀门状态值,
size_t statuSize = mStatusVec.size();
for (int i = 0; i < statuSize; i++)
{
status.addItem(mStatusVec[i]);
}
return true;
}
void CivInpDbHelper::handleValves()
void CivInpDbHelper::handlePump()
{
PipeTable pipeTable;
// 注意去重
// 查找与阀门像连的管段
std::string sql = "select pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", \
pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\",pipe.\"局损系数\",\
pipe.\"初始状态\",va.\"本点号\", pipe.\"code\", va.\"类型\" from \"管段\" as pipe,\
\"阀门\" as va where pipe.\"起始节点\" = va.\"本点号\" \
or pipe.\"终止节点\" = va.\"本点号\" order by \"本点号\"";
}
void CivInpDbHelper::handleValve()
{
//阀门的下游管段
std::string dwPipeSql = "select pipe.\"编号\", ('UP' || pipe.\"起始节点\") as \"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\",\
pipe.\"摩阻系数\" ,pipe.\"局损系数\" from \"管段\" as pipe where pipe.\"from_layer\" = '阀门'";
if (!mDbConn->execSql(sql))
{
if (!mDbConn->execSql(dwPipeSql))
return;
std::vector<std::map<std::string, std::string>> upPipes;
mDbConn->queryResult(upPipes);
size_t total = upPipes.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> pipe = upPipes[i];
CivPipe::Table pipeStruct;
pipeStruct.ID = pipe.find("编号")->second;
pipeStruct.code = pipe.find("code")->second;
pipeStruct.Node1 = pipe.find("起始节点")->second;
pipeStruct.Node2 = pipe.find("终止节点")->second;
pipeStruct.Length = pipe.find("管长")->second;
pipeStruct.Diameter = pipe.find("管径")->second;
pipeStruct.Roughness = pipe.find("摩阻系数")->second;
pipeStruct.Status = "Open";
pipeStruct.MinorLoss = pipe.find("局损系数")->second;
mPipesVec.push_back(pipeStruct);
}
std::vector<std::map<std::string, std::string>> resultMap;
mDbConn->queryResult(resultMap);
// 阀门的上游管段
std::string upPipeSql = "select pipe.\"编号\", pipe.\"起始节点\", ('DW' || pipe.\"终止节点\") as \"终止节点\", pipe.\"管长\", pipe.\"管径\", \
pipe.\"摩阻系数\",pipe.\"局损系数\" from \"管段\" as pipe where pipe.\"to_layer\" = '阀门'";
int toal = resultMap.size();
if (!mDbConn->execSql(upPipeSql))
return;
std::string repeatSn;
std::string repeatVaType;
std::string starNode;
std::string endNode;
std::vector<std::map<std::string, std::string>> downPipes;
mDbConn->queryResult(downPipes);
// 存储已拼接的管段CODE,为下面去重
std::set<std::string> filterSet;
for (int i = 0; i < toal; i++)
size_t dtotal = downPipes.size();
for (int i = 0; i < dtotal; i++)
{
std::map<std::string, std::string> tempMap = resultMap[i];
std::map<std::string, std::string> pipe = downPipes[i];
CivPipe::Table pipeStruct;
pipeStruct.ID = pipe.find("编号")->second;
pipeStruct.code = pipe.find("code")->second;
pipeStruct.Node1 = pipe.find("起始节点")->second;
pipeStruct.Node2 = pipe.find("终止节点")->second;
pipeStruct.Length = pipe.find("管长")->second;
pipeStruct.Diameter = pipe.find("管径")->second;
pipeStruct.Roughness = pipe.find("摩阻系数")->second;
pipeStruct.Status = "Open";
pipeStruct.MinorLoss = pipe.find("局损系数")->second;
mPipesVec.push_back(pipeStruct);
}
std::string sn = tempMap.find("本点号")->second;
std::string vaType = tempMap.find("类型")->second;
std::string pipeCode = tempMap.find(pipeTable.code)->second;
//-- 阀门信息--
// 构造阀门起始节点
std::string vaStartSql = "SELECT \
'UP' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\" \
, (va.\"横坐标\" - 1) AS \"横坐标\", (va.\"纵坐标\" - 1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\",\
va.\"类型\" as \"阀门类型\", ('UP' || va.\"本点号\") as \"阀门起始节点\", \
va.\"直径\" as \"阀门直径\",va.\"固定状态\" as \"阀门状态\",va.\"设置\" as \"阀门设置\",va.\"水损系数\"\
FROM \"阀门\" va, ( \
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\"\
, node.\"纵坐标\", va.\"终止节点\"\
FROM \"节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\"\
, pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"to_layer\" = '阀门'\
) va\
WHERE node.\"本点号\" = va.\"起始节点\"\
) vnode \
WHERE vnode.\"终止节点\" = va.\"本点号\"";
if (!mDbConn->execSql(vaStartSql))
return;
filterSet.insert(pipeCode);
std::vector<std::map<std::string, std::string>> valvesVec;
mDbConn->queryResult(valvesVec);
if (repeatVaType == "BV") // 止回阀,是管段的一部分,需要合并管段
{
if (sn == repeatSn && repeatVaType == vaType)
std::map<std::string, CivValve::ValveTable> valveTableMap;
std::map<std::string, CivPipe::PipesTable> pipeTableMap;
size_t valvsSize = valvesVec.size();
for (int i = 0; i < valvsSize; i++)
{
CivPipe::PipesTable pipe;
pipe.ID = tempMap.find(pipeTable.snNo)->second;
std::map<std::string, std::string> valveMap = valvesVec[i];
// 构造节点
CivNode::NodeTable nodeTable;
std::string szNo = valveMap.find("本点号")->second;
nodeTable.ID = szNo;
nodeTable.Elev = valveMap.find("高程")->second;
std::string patternID = valveMap.find("需水量模式")->second;
std::string demand = valveMap.find("基本需水量")->second;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
std::string secondStartNode = tempMap.find(pipeTable.startPoint)->second;
std::string secondEndNode = tempMap.find(pipeTable.endPoint)->second;
mNodeVec.push_back(nodeTable);
if (starNode == repeatSn)
// 节点坐标
CivCoordinates::CoordTable coordTable;
coordTable.ID = szNo;
coordTable.XCoord = valveMap.find("横坐标")->second;
coordTable.YCoord = valveMap.find("纵坐标")->second;
mCoords.push_back(coordTable);
std::string valveSn = valveMap.find("阀门本点号")->second;
std::string valveType = valveMap.find("阀门类型")->second;
if (valveType == "BV") // 止回阀,转成管段
{
pipe.Node1 = secondStartNode;
pipe.Node2 = endNode;
CivPipe::Table pipeStruct;
pipeStruct.ID = valveSn;
pipeStruct.Node1 = szNo;
pipeStruct.Length = "2";
pipeStruct.Diameter = valveMap.find("阀门直径")->second;
pipeStruct.Roughness =std::string("130");//valveMap.find("摩阻系数")->second;
pipeStruct.Status = (valveMap.find("阀门状态")->second == "Open")?"Open":"CV";
pipeStruct.MinorLoss = "0";
auto pter = std::make_pair(valveSn, pipeStruct);
pipeTableMap.insert(pter);
}
else if (endNode == repeatSn)
else
{
pipe.Node1 = starNode;
pipe.Node2 = secondEndNode;
// 阀门
CivValve::ValveTable valveTable;
valveTable.ID = valveSn;
valveTable.Node1 = szNo;
valveTable.Diameter = valveMap.find("阀门直径")->second;
valveTable.Type = valveType;
valveTable.Setting = valveMap.find("阀门设置")->second;
valveTable.MinorLoss = valveMap.find("水损系数")->second;
valveTableMap.insert(std::make_pair(szNo, valveTable));
// 阀门状态组件
CivStatus::StatusTable statusTable;
statusTable.ID = valveSn;
statusTable.Setting = valveMap.find("固定状态")->second;
mStatusVec.push_back(statusTable);
}
pipe.Length = tempMap.find(pipeTable.length)->second;
pipe.Diameter = tempMap.find(pipeTable.diameter)->second;
pipe.Roughness = tempMap.find(pipeTable.friction)->second;
pipe.MinorLoss = tempMap.find(pipeTable.localLoss)->second;
pipe.Status = tempMap.find(pipeTable.status)->second;
}
repeatVaType = vaType;
repeatSn = sn;
//--构造阀门终止节点
std::string vaEndSql = "SELECT\
'DW' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\"\
, (va.\"横坐标\" + 1) AS \"横坐标\", (va.\"纵坐标\" + 1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\",\
va.\"类型\" as \"阀门类型\", ('DW' || va.\"本点号\") as \"阀门终止节点\"\
FROM \"阀门\" va, (\
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\"\
, node.\"纵坐标\", va.\"起始节点\"\
FROM \"节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\"\
, pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门'\
) va\
WHERE node.\"本点号\" = va.\"终止节点\"\
) vnode\
WHERE vnode.\"起始节点\" = va.\"本点号\"";
if (!mDbConn->execSql(vaEndSql))
return;
starNode = tempMap.find(pipeTable.startPoint)->second;
endNode = tempMap.find(pipeTable.endPoint)->second;
std::vector<std::map<std::string, std::string>> valvesEndVec;
mDbConn->queryResult(valvesEndVec);
} // 其他独立阀门处理
else
size_t endVecSize = valvesEndVec.size();
for (int i = 0; i < endVecSize; i++)
{
std::map<std::string, std::string> valveMap = valvesEndVec[i];
}
// 构造节点
CivNode::NodeTable nodeTable;
std::string szNo = valveMap.find("本点号")->second;
nodeTable.ID = szNo;
nodeTable.Elev = valveMap.find("高程")->second;
std::string patternID = valveMap.find("需水量模式")->second;
std::string demand = valveMap.find("基本需水量")->second;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
mNodeVec.push_back(nodeTable);
// 节点坐标
CivCoordinates::CoordTable coordTable;
coordTable.ID = szNo;
coordTable.XCoord = valveMap.find("横坐标")->second;
coordTable.YCoord = valveMap.find("纵坐标")->second;
mCoords.push_back(coordTable);
std::string valveSn = valveMap.find("阀门本点号")->second;
std::string valveType = valveMap.find("阀门类型")->second;
if (valveType == "BV") // 止回阀,转成管段
{
auto iter = pipeTableMap.find(valveSn);
if (iter != pipeTableMap.end())
{
pipeTableMap[valveSn].Node2 = szNo;
mPipesVec.push_back(iter->second);
}
}
else
{
// 阀门
auto iter = valveTableMap.find(valveSn);
if (iter != valveTableMap.end())
{
valveTableMap[valveSn].Node2 = szNo;
mValuvesVec.push_back(iter->second);
}
}
}
}
\ No newline at end of file
......@@ -2,16 +2,19 @@
#include "CivAssembly.h"
#include "CivInpHelperAbs.h"
#include <memory>
#include "pandaDbManager.h"
/**
从数据库获取inp文件相关的类
*/
class INPDLLEXPORT CivInpDbHelper:public CivInpHelperAbs
class PANDADBMANAGER_API CivInpDbHelper:public CivInpHelperAbs
{
public:
explicit CivInpDbHelper(const std::string& uri);
~CivInpDbHelper();
void handlePump() override;
void handleValve() override;
bool getNode(CivNode& node)override;
bool getPipe(CivPipe& pipe) override;
bool getTank(CivTank& tank) override;
......@@ -22,12 +25,4 @@ public:
bool getQuality(CivQuality& quality) override;
bool getStatus(CivStatus& status) override;
private:
// 处理阀门
void handleValves();
std::string mCondtion;
std::multimap<std::string,std::string> mValvePipeMap;
std::multimap<std::string, CivPipe::PipesTable> mPipesMap;
std::multimap<std::string, CivNode::NodeTable> mNodeMap; // 处理与阀门相连的管段
};
......@@ -2,6 +2,7 @@
#include "CivConnection.h"
#include "CivPgDbConnection.h"
#include "CivTableFields.h"
#include "StringUtils.h"
CivInpHelperAbs::CivInpHelperAbs(const std::string& uri)
{
......@@ -72,6 +73,14 @@ bool CivInpHelperAbs::getParameter(std::vector<CivParameter>& params)
bool CivInpHelperAbs::getPatterns(CivPatterns& patterns)
{
//延时不需要需水量模式
if (!isDelayTime)
{
convertPatterns();
return true;
}
PatternTable patternTable;
std::vector<std::string> fields = {
......@@ -137,7 +146,6 @@ bool CivInpHelperAbs::getSources(CivSources& sources)
return true;
}
bool CivInpHelperAbs::getLabels(CivLabels& labels)
{
return true;
......@@ -182,3 +190,86 @@ void CivInpHelperAbs::setQualityType(QualityType qualiType)
{
mQualityType = qualiType;
}
void CivInpHelperAbs::setPatternTime(std::string time)
{
std::vector<std::string> vec;
StringUtils::split(time, vec);
if (vec.size() < 2)
return;
std::string pattern = vec[1];
std::vector<std::string> timeVec;
StringUtils::split(pattern, timeVec, ":");
if (timeVec.size() < 3)
return;
std::string timetemp = timeVec[0];
mPatternTime = std::atoi(timetemp.c_str());
}
void CivInpHelperAbs::convertPatterns()
{
PatternTable patternTable;
std::vector<std::string> fields = {
patternTable.modelName,
patternTable.modelData,
};
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(PATTERNTABLE, fields, resultVector);
size_t totals = resultVector.size();
for (int i = 0; i < totals; i++)
{
std::map<std::string, std::string> map = resultVector[i];
CivPatterns::PatternTable pTable;
std::string name = map.find(patternTable.modelName)->second;
std::string val = map.find(patternTable.modelData)->second;
// 解析模式
std::vector<std::string> res;
StringUtils::split(val, res);
mPatterns.insert(std::pair<std::string, std::vector<std::string>>(name, res));
}
}
void CivInpHelperAbs::isDelayTimeSimul(bool isDelay)
{
isDelayTime = isDelay;
}
void CivInpHelperAbs::handleDelayPattern(const std::string& demand, const std::string& patternID, std::string& destDemand, std::string& pattern)
{
// 是否做延时模拟
if (isDelayTime)
{
destDemand = demand;
pattern = patternID;
}
else
{
auto iter = mPatterns.find(patternID);
if (iter != mPatterns.end())
{
std::vector<std::string> mulitiers = iter->second;
if (mPatternTime > mulitiers.size())
mPatternTime = mulitiers.size() - 1;
if (mPatternTime < 0)
mPatternTime = 0;
std::string mulitier = mulitiers[mPatternTime];
float intMul = std::atof(mulitier.c_str());
float dem = std::atof(demand.c_str());
destDemand = std::to_string(dem * intMul);
}
}
}
\ No newline at end of file
#pragma once
#include "CivAssembly.h"
#include "pandaDbManager.h"
class CivConnection;
#define INPDLLEXPORT __declspec(dllexport)
/**
转inp操作数据库类
*/
class INPDLLEXPORT CivInpHelperAbs
class PANDADBMANAGER_API CivInpHelperAbs
{
public:
// 水质模拟时间
......@@ -20,6 +20,8 @@ public:
explicit CivInpHelperAbs(const std::string& uri);
virtual ~CivInpHelperAbs();
virtual void handlePump() = 0;
virtual void handleValve() = 0;
// 组件需要重载
virtual bool getNode(CivNode& node)=0 ;
virtual bool getPipe(CivPipe& pipe)=0 ;
......@@ -35,6 +37,10 @@ public:
void getSnToCode(std::map<std::string, std::string>& coord);
// 不要重载函数
void setPatternTime(std::string time); // 解析模式时刻
void convertPatterns();
void isDelayTimeSimul(bool isDelay);
bool getPatterns(CivPatterns& patterns) ;
bool getCurves(CivCurves& curves) ;
bool getDemands(CivDemands& demands) ;
......@@ -48,4 +54,18 @@ public:
protected:
QualityType mQualityType;
CivConnection* mDbConn;
bool isDelayTime; // 是否做延时模拟
int mPatternTime; // 模式
std::map<std::string,std::vector<std::string>> mPatterns; // 需水量模式乘子
void handleDelayPattern(const std::string& sourceDemand, const std::string& patternID, std::string& demand, std::string& pattern);
std::string mCondtion;
std::vector<CivPipe::PipesTable> mPipesVec; //
std::vector<CivNode::NodeTable> mNodeVec; // 处理与阀门相连的管段
std::vector<CivValve::ValveTable> mValuvesVec; // 阀门
std::vector<CivStatus::StatusTable> mStatusVec; // 状态组件
std::vector<CivPumps::PumpTable> mPumpTables; // 水泵
std::vector<CivCoordinates::CoordTable> mCoords;
};
#include "CivMaintainModel.h"
CivMaintainModel::CivMaintainModel()
{
}
void CivMaintainModel::maintain()
{
}
void CivMaintainModel::addNecessaryTable(const std::string& table)
{
}
bool CivMaintainModel::checkTable(const std::string& table)
{
return true;
}
bool CivMaintainModel::checkTableFiled(const std::string& talbe, const std::string& filed, const std::string& filedType)
{
return true;
}
void CivMaintainModel::addTableFiled(const std::string& table, const std::string& filed, const std::string& filedType)
{
}
void CivMaintainModel::deleteTableFiled(const std::string& table, const std::string& filed)
{
}
\ No newline at end of file
#pragma once
#include "CivDbConn.h"
#include <vector>
/**
维护水力模型必要的表
*/
class DBEXPORT CivMaintainModel
{
public:
CivMaintainModel();
/**
*@brief 维护模型必要的表
*/
void maintain();
/**
*@brief 添加模型所必须的表
*@param table 表名
*/
void addNecessaryTable(const std::string& table);
private:
/**
*@brief 检查表是否存在
*/
bool checkTable(const std::string& table);
/**
*@brief 检查表字段
*@param table 表名
*@param filed 表字段
*@param filedType 表字段类型
*/
bool checkTableFiled(const std::string& table, const std::string& filed, const std::string& filedType);
/**
*@brief 添加表字段
*@param table 表名
*@param filed 表字段
*@param filedType 表字段类型
*/
void addTableFiled(const std::string& table, const std::string& filed, const std::string& filedType);
/**
*@brief 删除表字段
*@param table 表名
*@param filed 表字段
*/
void deleteTableFiled(const std::string& table, const std::string& filed);
private:
std::vector<std::string> mNecessTables;
};
......@@ -69,6 +69,7 @@ bool CivPgDbConnection::execSql(const std::string& sql)
if (!errorStr.empty())
{
mLastError = errorStr;
std::cout << sql << std::endl;
std::cout << mLastError << std::endl;
PQclear(mResult);
return false;
......
......@@ -16,23 +16,439 @@ CivProjInpDbHelper::~CivProjInpDbHelper()
void CivProjInpDbHelper::setProjCode(const std::string& projCode)
{
mPorjCode = projCode;
std::string mCondition = PROJFILED + " = " + projCode;
}
void CivProjInpDbHelper::handlePump()
{
}
void CivProjInpDbHelper::sortProjDeatil()
{
// 查找方案详情表修改的属性
std::string detailSql = "select detail.\"code\",detail.\"图层\",detail.\"属性\",detail.\"属性原值\",detail.\"属性新值\"\
from \"方案详情表\" as detail where \"方案编码\"='" + mPorjCode +"' and \"操作类型\"=1";
if (!mDbConn->execSql(detailSql))
return;
std::vector<std::map<std::string, std::string>> detailVec;
mDbConn->queryResult(detailVec);
size_t detailVecSize = detailVec.size();
// 将方案详情表查出来的数据
for (int i = 0; i < detailVecSize; i++)
{
std::map<std::string, std::string> tempMap = detailVec[i];
std::string layerName = tempMap.find("图层")->second;
mDetailMap[layerName].push_back(tempMap);
}
}
std::string CivProjInpDbHelper::splicingConditions(const std::string& layer)
{
std::string condition = "\"code\" not in(select \"code\" from \"方案详情表\" \
where \"方案编码\" = '" + mPorjCode + "' and \"图层\" = '"+ layer +"' and \"操作类型\"=0)";
return condition;
}
void CivProjInpDbHelper::handleValve()
{
// 查出方案详情表的信息
sortProjDeatil();
// 抽取相同字符串部分
std::string baseSql = "select pipe.\"编号\", ('UP' || pipe.\"起始节点\") as \"起始节点\", pipe.\"终止节点\", \
pipe.\"管长\", pipe.\"管径\",\
pipe.\"摩阻系数\" ,pipe.\"局损系数\"";
//阀门的下游管段
std::string dwPipeSql = baseSql + "from \"管段\" as pipe where "+splicingConditions("阀门")+" and (pipe.\"from_layer\" ='阀门' or pipe.\"from_layer\" ='方案阀门' ) \
union "+baseSql+" from \"方案管段\" as pipe where pipe.\"方案编码\" ='"+mPorjCode+"' and (pipe.\"from_layer\" ='阀门' or pipe.\"from_layer\" ='方案阀门' ) ";
if (!mDbConn->execSql(dwPipeSql))
return;
std::vector<std::map<std::string, std::string>> upPipes;
mDbConn->queryResult(upPipes);
size_t total = upPipes.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> pipe = upPipes[i];
CivPipe::Table pipeStruct;
pipeStruct.ID = pipe.find("编号")->second;
pipeStruct.code = pipe.find("code")->second;
pipeStruct.Node1 = pipe.find("起始节点")->second;
pipeStruct.Node2 = pipe.find("终止节点")->second;
pipeStruct.Length = pipe.find("管长")->second;
pipeStruct.Diameter = pipe.find("管径")->second;
pipeStruct.Roughness = pipe.find("摩阻系数")->second;
pipeStruct.Status = "Open";
pipeStruct.MinorLoss = pipe.find("局损系数")->second;
mPipesVec.push_back(pipeStruct);
}
// 阀门的上游管段
std::string baseSql2 = "select pipe.\"编号\", pipe.\"起始节点\", ('DW' || pipe.\"终止节点\") as \"终止节点\", \
pipe.\"管长\", pipe.\"管径\", \pipe.\"摩阻系数\",pipe.\"局损系数\"";
std::string upPipeSql = baseSql2 + " from \"管段\" as pipe where " +splicingConditions("阀门")+" and (pipe.\"to_layer\" = '阀门' or pipe.\"to_layer\" = '方案阀门') \
union " +baseSql2 + " from \"方案管段\" as pipe where pipe.\"方案编码\" ='" + mPorjCode + "' and (pipe.\"to_layer\" = '阀门' or pipe.\"to_layer\" = '方案阀门') " ;
if (!mDbConn->execSql(upPipeSql))
return;
std::vector<std::map<std::string, std::string>> downPipes;
mDbConn->queryResult(downPipes);
size_t dtotal = downPipes.size();
for (int i = 0; i < dtotal; i++)
{
std::map<std::string, std::string> pipe = downPipes[i];
CivPipe::Table pipeStruct;
pipeStruct.ID = pipe.find("编号")->second;
pipeStruct.code = pipe.find("code")->second;
pipeStruct.Node1 = pipe.find("起始节点")->second;
pipeStruct.Node2 = pipe.find("终止节点")->second;
pipeStruct.Length = pipe.find("管长")->second;
pipeStruct.Diameter = pipe.find("管径")->second;
pipeStruct.Roughness = pipe.find("摩阻系数")->second;
pipeStruct.Status = "Open";
pipeStruct.MinorLoss = pipe.find("局损系数")->second;
mPipesVec.push_back(pipeStruct);
}
// 阀门信息
std::string startSql = "SELECT va.\"code\",'UP' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\" \
, (va.\"横坐标\" + 1) AS \"横坐标\", (va.\"纵坐标\" + 1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\", \
va.\"类型\" as \"阀门类型\", ('UP' || va.\"本点号\") as \"阀门起始节点\",\
va.\"直径\" as \"阀门直径\", va.\"固定状态\" as \"阀门状态\", va.\"设置\" as \"阀门设置\", va.\"水损系数\"\
FROM \"阀门\" va, ( \
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"终止节点\" \
FROM \"节点\" node, ( \
SELECT pipe.\"起始节点\", pipe.\"终止节点\" FROM \"管段\" pipe \
WHERE pipe.\"to_layer\" = '阀门' \
and \"code\" not in( \
select \"code\" from \"方案详情表\" \
where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "' \
) \
union \
select pipe.\"起始节点\", pipe.\"终止节点\" FROM \"方案管段\" pipe where pipe.\"to_layer\" = '阀门' and \"方案编码\" = '" + mPorjCode + "' \
) va \
WHERE node.\"本点号\" = va.\"起始节点\" and node.\"code\" not in(select \"code\" from \"方案详情表\" \
where \"图层\" = '节点' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "') \
union \
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"终止节点\" \
FROM \"方案节点\" node, ( \
SELECT pipe.\"起始节点\", pipe.\"终止节点\" FROM \"管段\" pipe \
WHERE pipe.\"to_layer\" = '阀门' \
and \"code\" not in( \
select \"code\" from \"方案详情表\" \
where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "' \
) \
union \
select pipe.\"起始节点\", pipe.\"终止节点\" FROM \"方案管段\" pipe where pipe.\"to_layer\" = '阀门' and \"方案编码\" = '" + mPorjCode + "' \
) va \
WHERE node.\"本点号\" = va.\"起始节点\" and node.\"方案编码\" = '" + mPorjCode + "' \
) vnode \
WHERE vnode.\"终止节点\" = va.\"本点号\" and va.\"code\" not in(select \"code\" from \"方案详情表\" \
where \"图层\" = '阀门' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "') \
union \
SELECT va.\"code\", 'UP' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\" \
, (va.\"横坐标\" +1) AS \"横坐标\", (va.\"纵坐标\" + 1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\", \
va.\"类型\" as \"阀门类型\", ('UP' || va.\"本点号\") as \"阀门起始节点\", \
va.\"直径\" as \"阀门直径\", va.\"固定状态\" as \"阀门状态\", va.\"设置\" as \"阀门设置\", va.\"水损系数\" \
FROM \"方案阀门\" va, ( \
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"终止节点\" \
FROM \"节点\" node, ( \
SELECT pipe.\"起始节点\", pipe.\"终止节点\" FROM \"管段\" pipe \
WHERE pipe.\"to_layer\" = '阀门' \
and \"code\" not in( \
select \"code\" from \"方案详情表\" \
where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "' \
) \
union \
select pipe.\"起始节点\", pipe.\"终止节点\" FROM \"方案管段\" pipe where pipe.\"to_layer\" = '阀门' and \"方案编码\" = '" + mPorjCode + "' \
) va \
WHERE node.\"本点号\" = va.\"起始节点\" and node.\"code\" not in(select \"code\" from \"方案详情表\" \
where \"图层\" = '节点' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "') \
union \
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"终止节点\" \
FROM \"方案节点\" node, ( \
SELECT pipe.\"起始节点\", pipe.\"终止节点\" FROM \"管段\" pipe \
WHERE pipe.\"to_layer\" = '阀门' \
and \"code\" not in( \
select \"code\" from \"方案详情表\" \
where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '" + mPorjCode + "' \
) \
union \
select pipe.\"起始节点\", pipe.\"终止节点\" FROM \"方案管段\" pipe where pipe.\"to_layer\" = '阀门' and \"方案编码\" = '" + mPorjCode + "' \
) va \
WHERE node.\"本点号\" = va.\"起始节点\" and node.\"方案编码\" = '" + mPorjCode + "' \
) vnode \
WHERE vnode.\"终止节点\" = va.\"本点号\" and va.\"方案编码\" = '" + mPorjCode + "'";
if (!mDbConn->execSql(startSql))
return;
std::vector<std::map<std::string, std::string>> valvesVec;
mDbConn->queryResult(valvesVec);
// 找出节点图层修改的值
std::vector<std::map<std::string, std::string>> valvesDetailVec;
auto iter = mDetailMap.find("阀门");
if (iter != mDetailMap.end())
valvesDetailVec = iter->second;
std::map<std::string, CivValve::ValveTable> valveTableMap;
std::map<std::string, CivPipe::PipesTable> pipeTableMap;
size_t valvsSize = valvesVec.size();
for (int i = 0; i < valvsSize; i++)
{
std::map<std::string, std::string> valveMap = valvesVec[i];
// 构造节点
CivNode::NodeTable nodeTable;
std::string szNo = valveMap.find("本点号")->second;
nodeTable.ID = szNo;
nodeTable.Elev = valveMap.find("高程")->second;
std::string patternID = valveMap.find("需水量模式")->second;
std::string demand = valveMap.find("基本需水量")->second;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
mNodeVec.push_back(nodeTable);
// 节点坐标
CivCoordinates::CoordTable coordTable;
coordTable.ID = szNo;
coordTable.XCoord = valveMap.find("横坐标")->second;
coordTable.YCoord = valveMap.find("纵坐标")->second;
mCoords.push_back(coordTable);
std::string valveSn = valveMap.find("阀门本点号")->second;
std::string valveType = valveMap.find("阀门类型")->second;
std::string valveStatus = valveMap.find("阀门状态")->second;
std::string code = valveMap.find("code")->second;
// 根据code匹配
for (int i = 0; i < valvesDetailVec.size(); i++)
{
auto detailMap = valvesDetailVec[i];
//code 不匹配,继续下一次循环查找
auto codeIter = detailMap.find("code");
if (codeIter == detailMap.end())
continue;
// 详情表code 与原管网code不想等, 不符合条件
if (codeIter->second == code)
continue;
// 根据属性修改对应的值
std::string attri = detailMap.find("属性")->second;
std::string newValue = detailMap.find("属性新值")->second;
if (attri == "固定状态")
{
valveStatus = newValue;
}
}
if (valveType == "BV") // 止回阀,转成管段
{
CivPipe::Table pipeStruct;
pipeStruct.ID = valveSn;
pipeStruct.Node1 = szNo;
pipeStruct.Length = "2";
pipeStruct.Diameter = valveMap.find("阀门直径")->second;
pipeStruct.Roughness = std::string("130");//valveMap.find("摩阻系数")->second;
pipeStruct.Status = (valveStatus== "开") ? "Open" : "CV";
pipeStruct.MinorLoss = "0";
auto pter = std::make_pair(valveSn, pipeStruct);
pipeTableMap.insert(pter);
}
else
{
// 阀门
CivValve::ValveTable valveTable;
valveTable.ID = valveSn;
valveTable.Node1 = szNo;
valveTable.Diameter = valveMap.find("阀门直径")->second;
valveTable.Type = valveType;
valveTable.Setting = valveMap.find("阀门设置")->second;
valveTable.MinorLoss = valveMap.find("水损系数")->second;
valveTableMap.insert(std::make_pair(szNo, valveTable));
// 阀门状态组件
CivStatus::StatusTable statusTable;
statusTable.ID = valveSn;
statusTable.Setting = valveStatus;
mStatusVec.push_back(statusTable);
}
}
//--构造阀门终止节点
std::string vaEndSql = "SELECT 'DW' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\"\
, (va.\"横坐标\" - 1) AS \"横坐标\", (va.\"纵坐标\" - 1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\",\
va.\"类型\" as \"阀门类型\", ('DW' || va.\"本点号\") as \"阀门终止节点\"\
FROM \"阀门\" va, (\
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"起始节点\"\
FROM \"节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"方案管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"方案编码\" = '"+mPorjCode +"'\
) va \
WHERE node.\"本点号\" = va.\"终止节点\" and node.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"起始节点\"\
FROM \"方案节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"方案管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"方案编码\" = '"+mPorjCode +"'\
) va\
WHERE node.\"本点号\" = va.\"终止节点\" and node.\"方案编码\" = '"+mPorjCode +"'\
) vnode\
WHERE vnode.\"起始节点\" = va.\"本点号\"\
and va.\"code\" not in(select \"code\" from \"方案详情表\" where \"图层\" = '阀门' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT 'DW' || va.\"本点号\" AS \"本点号\", vnode.\"高程\", vnode.\"基本需水量\", vnode.\"需水量模式\"\
, (va.\"横坐标\" - 1) AS \"横坐标\", (va.\"纵坐标\" -1) AS \"纵坐标\", va.\"本点号\" as \"阀门本点号\",\
va.\"类型\" as \"阀门类型\", ('DW' || va.\"本点号\") as \"阀门终止节点\"\
FROM \"方案阀门\" va, (\
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"起始节点\"\
FROM \"节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"方案管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"方案编码\" = '"+mPorjCode +"'\
) va\
WHERE node.\"本点号\" = va.\"终止节点\" and node.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT node.\"本点号\", node.\"高程\", node.\"基本需水量\", node.\"需水量模式\", node.\"横坐标\", node.\"纵坐标\", va.\"起始节点\"\
FROM \"方案节点\" node, (\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"code\"\
not in(select \"code\" from \"方案详情表\" where \"图层\" = '管段' and \"操作类型\" = 0 and \"方案编码\" = '"+mPorjCode +"')\
union\
SELECT pipe.\"编号\", pipe.\"起始节点\", pipe.\"终止节点\", pipe.\"管长\", pipe.\"管径\", pipe.\"摩阻系数\"\
FROM \"方案管段\" pipe\
WHERE pipe.\"from_layer\" = '阀门' and pipe.\"方案编码\" = '"+mPorjCode +"'\
) va\
WHERE node.\"本点号\" = va.\"终止节点\" and node.\"方案编码\" = '"+mPorjCode +"'\
) vnode\
WHERE vnode.\"起始节点\" = va.\"本点号\" and va.\"方案编码\" = '"+mPorjCode +"'";
if (!mDbConn->execSql(vaEndSql))
return;
std::vector<std::map<std::string, std::string>> valvesEndVec;
mDbConn->queryResult(valvesEndVec);
size_t endVecSize = valvesEndVec.size();
for (int i = 0; i < endVecSize; i++)
{
std::map<std::string, std::string> valveMap = valvesEndVec[i];
// 构造节点
CivNode::NodeTable nodeTable;
std::string szNo = valveMap.find("本点号")->second;
nodeTable.ID = szNo;
nodeTable.Elev = valveMap.find("高程")->second;
std::string patternID = valveMap.find("需水量模式")->second;
std::string demand = valveMap.find("基本需水量")->second;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
mNodeVec.push_back(nodeTable);
// 节点坐标
CivCoordinates::CoordTable coordTable;
coordTable.ID = szNo;
coordTable.XCoord = valveMap.find("横坐标")->second;
coordTable.YCoord = valveMap.find("纵坐标")->second;
mCoords.push_back(coordTable);
std::string valveSn = valveMap.find("阀门本点号")->second;
std::string valveType = valveMap.find("阀门类型")->second;
if (valveType == "BV") // 止回阀,转成管段
{
auto iter = pipeTableMap.find(valveSn);
if (iter != pipeTableMap.end())
{
pipeTableMap[valveSn].Node2 = szNo;
mPipesVec.push_back(iter->second);
}
}
else
{
// 阀门
auto iter = valveTableMap.find(valveSn);
if (iter != valveTableMap.end())
{
valveTableMap[valveSn].Node2 = szNo;
mValuvesVec.push_back(iter->second);
}
}
}
}
bool CivProjInpDbHelper::getNode(CivNode& node)
{
// 查找,节点表数据
JunctionTable nodeTableFields;
std::vector<std::string> fields;
fields.push_back(nodeTableFields.sn);
fields.push_back(nodeTableFields.elev);
fields.push_back(nodeTableFields.baseDemand);
fields.push_back(nodeTableFields.demandPattern);
std::string sql = "select \"code\", \"本点号\", \"高程\", \"基本需水量\", \"需水量模式\", \"横坐标\",\"纵坐标\" \
from \"节点\" where\
\"code\" not in(select det.\"code\" from \"方案详情表\" as det where det.\"方案编码\" = '"+mPorjCode+"' and \"图层\" = '节点' and \"操作类型\"=0)\
union select \"code\", \"本点号\", \"高程\", \"基本需水量\", \"需水量模式\", \"横坐标\",\"纵坐标\" \
from \"方案节点\" where \"方案编码\" = '"+ mPorjCode +"' ";
if (!mDbConn->execSql(sql))
return false;
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(PIPENODE, fields, resultVector);
mDbConn->query(PROJ_PIPENODE, fields, resultVector, mCondition);
mDbConn->queryResult(resultVector);
// 找出节点图层修改的值
std::vector<std::map<std::string, std::string>> nodeDetailVec;
auto iter = mDetailMap.find(PIPENODE);
if (iter != mDetailMap.end())
nodeDetailVec = iter->second;
// 编辑包装结果
size_t total = resultVector.size();
......@@ -41,33 +457,84 @@ bool CivProjInpDbHelper::getNode(CivNode& node)
std::map<std::string, std::string> map = resultVector[i];
CivNode::NodeTable nodeTable;
nodeTable.ID = map.find(nodeTableFields.sn)->second;
nodeTable.Elev = map.find(nodeTableFields.elev)->second;
nodeTable.Demand = map.find(nodeTableFields.baseDemand)->second;
nodeTable.PatternId = map.find(nodeTableFields.demandPattern)->second;
std::string code = map.find(nodeTableFields.code)->second;
std::string elev = map.find(nodeTableFields.elev)->second;
std::string patternID = map.find(nodeTableFields.demandPattern)->second;
std::string demand = map.find(nodeTableFields.baseDemand)->second;
// 根据code匹配
for (int i = 0; i < nodeDetailVec.size(); i++)
{
auto detailMap = nodeDetailVec[i];
//code 不匹配,继续下一次循环查找
auto codeIter = detailMap.find(nodeTableFields.code);
if (codeIter == detailMap.end())
continue;
// 详情表code 与原管网code不想等, 不符合条件
if (codeIter->second == code)
continue;
// 根据属性修改对应的值
std::string attri = detailMap.find("属性")->second;
std::string newValue = detailMap.find("属性新值")->second;
if (attri == nodeTableFields.elev)
{
elev = newValue;
}
else if (attri == nodeTableFields.demandPattern)
{
patternID = newValue;
}
else if (attri == nodeTableFields.baseDemand)
{
demand = newValue;
}
}
nodeTable.ID = map.find("本点号")->second;
nodeTable.Elev = elev;
handleDelayPattern(demand, patternID, nodeTable.Demand, nodeTable.PatternId);
node.addItem(nodeTable);
}
// 添加处理的阀门产生的节点
size_t size = mNodeVec.size();
for (int i = 0; i < size; i++)
{
node.addItem(mNodeVec[i]);
}
return true;
}
bool CivProjInpDbHelper::getPipe(CivPipe& pipes)
{
PipeTable pipeTable;
std::vector<std::string> fields;
fields.push_back(pipeTable.snNo);
fields.push_back(pipeTable.startPoint);
fields.push_back(pipeTable.endPoint);
fields.push_back(pipeTable.length);
fields.push_back(pipeTable.diameter);
fields.push_back(pipeTable.friction);
fields.push_back(pipeTable.localLoss);
fields.push_back(pipeTable.status);
std::string sql = "select \"code\",\"编号\",\"起始节点\",\"终止节点\",\"管长\",\"管径\",\"摩阻系数\",\"局损系数\",\"初始状态\"\
from \"管段\" \
where \"from_layer\" not in('阀门','方案阀门','水泵','方案水泵') \
and \"to_layer\" not in('阀门','方案阀门','水泵','方案水泵') \
and \"code\" not in(select det.\"code\" from \"方案详情表\" as det where det.\"方案编码\" = '"+mPorjCode+"' and \"图层\"='管段')\
union select \
\"code\",\"编号\",\"起始节点\",\"终止节点\",\"管长\",\"管径\",\"摩阻系数\",\"局损系数\",\"初始状态\" from \"方案管段\" where \
\"方案编码\" = '"+mPorjCode+"'";
if (!mDbConn->execSql(sql))
return false;
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(PIPELINE, fields, resultVector);
mDbConn->query(PROJ_PIPELINE, fields, resultVector, mCondition);
mDbConn->queryResult(resultVector);
// 找出管段图层修改的值
std::vector<std::map<std::string, std::string>> lineDetailVec;
auto iter = mDetailMap.find(PIPELINE);
if (iter != mDetailMap.end())
lineDetailVec = iter->second;
size_t total = resultVector.size();
for (int i = 0; i < total; i++)
......@@ -76,39 +543,87 @@ bool CivProjInpDbHelper::getPipe(CivPipe& pipes)
std::map<std::string, std::string> map = resultVector[i];
std::string code = map.find("code")->second;
pipe.ID = map.find(pipeTable.snNo)->second;
pipe.Node1 = map.find(pipeTable.startPoint)->second;
pipe.Node2 = map.find(pipeTable.endPoint)->second;
pipe.Length = map.find(pipeTable.length)->second;
pipe.Diameter = map.find(pipeTable.diameter)->second;
pipe.Roughness = map.find(pipeTable.friction)->second;
pipe.MinorLoss = map.find(pipeTable.localLoss)->second;
pipe.Status = map.find(pipeTable.status)->second;
std::string Length = map.find(pipeTable.length)->second;
std::string Diameter = map.find(pipeTable.diameter)->second;
std::string Roughness = map.find(pipeTable.friction)->second;
std::string MinorLoss = map.find(pipeTable.localLoss)->second;
for (int i = 0; i < lineDetailVec.size(); i++)
{
std::map<std::string, std::string> detailMap = lineDetailVec[i];
//code 不匹配,继续下一次循环查找
auto codeIter = detailMap.find("code");
if (codeIter == detailMap.end())
continue;
// 详情表code 与原管网code不想等, 不符合条件
if (codeIter->second != code)
continue;
// 根据属性修改对应的值
std::string attri = detailMap.find("属性")->second;
if (attri == pipeTable.length)
{
Length = detailMap.find("属性新值")->second;
}
else if (attri == pipeTable.diameter)
{
Diameter = detailMap.find("属性新值")->second;
}
else if (attri == pipeTable.friction)
{
Roughness = detailMap.find("属性新值")->second;
}
else if (attri == pipeTable.localLoss)
{
MinorLoss = detailMap.find("属性新值")->second;
}
}
pipe.Length = Length;
pipe.Diameter = Diameter;
pipe.Roughness = Roughness;
pipe.MinorLoss = MinorLoss;
pipes.addItem(pipe);
}
// 加上处理阀门和水泵产生的虚拟管段
for (int i = 0; i < mPipesVec.size(); i++)
{
pipes.addItem(mPipesVec[i]);
}
return true;
}
bool CivProjInpDbHelper::getTank(CivTank& tanks)
{
TankTable tankTable;
std::string sql = "select \"code\",\"本点号\",\"高程\",\"初始水位\",\"最低水位\",\"最高水位\",\"直径\",\
\"最小容积\",\"容积曲线\" from \"水池\"\
where \"code\" not in(select det.\"code\" from \"方案详情表\" as det\
where det.\"方案编码\" = '"+mPorjCode+"' and det.\"图层\" = '水池') \
union select \"code\",\"本点号\",\"高程\",\"初始水位\",\"最低水位\",\
\"最高水位\",\"直径\", \"最小容积\",\"容积曲线\" from \"方案水池\"\
where \"方案编码\"='"+mPorjCode+"'";
std::vector<std::string> fields;
fields.push_back(tankTable.sn);
fields.push_back(tankTable.elev);
fields.push_back(tankTable.initLevel);
fields.push_back(tankTable.minLevel);
fields.push_back(tankTable.maxLevel);
fields.push_back(tankTable.diametor);
fields.push_back(tankTable.minVolume);
fields.push_back(tankTable.volumeCurve);
if (!mDbConn->execSql(sql))
return false;
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(TANK, fields, resultVector);
mDbConn->query(PROJ_TANK, fields, resultVector, mCondition);
mDbConn->queryResult(resultVector);
// 找出节点图层修改的值
std::vector<std::map<std::string, std::string>> tankDetailVec;
auto iter = mDetailMap.find(PIPENODE);
if (iter != mDetailMap.end())
tankDetailVec = iter->second;
size_t total = resultVector.size();
for (int i = 0; i < total; i++)
......@@ -116,23 +631,82 @@ bool CivProjInpDbHelper::getTank(CivTank& tanks)
CivTank::TankTable tank;
std::map<std::string, std::string>map = resultVector[i];
std::string code = map.find("code")->second;
tank.ID = map.find(tankTable.sn)->second;
tank.Elev = map.find(tankTable.elev)->second;
tank.InitLevel = map.find(tankTable.initLevel)->second;
tank.MinLevel = map.find(tankTable.minLevel)->second;
tank.MaxLevel = map.find(tankTable.maxLevel)->second;
tank.Diameter = map.find(tankTable.diametor)->second;
tank.MinVol = map.find(tankTable.minVolume)->second;
tank.VolCurve = map.find(tankTable.volumeCurve)->second;
std::string Elev = map.find(tankTable.elev)->second;
std::string InitLevel = map.find(tankTable.initLevel)->second;
std::string MinLevel = map.find(tankTable.minLevel)->second;
std::string MaxLevel = map.find(tankTable.maxLevel)->second;
std::string Diameter = map.find(tankTable.diametor)->second;
std::string MinVol = map.find(tankTable.minVolume)->second;
std::string VolCurve = map.find(tankTable.volumeCurve)->second;
// 根据code匹配
for (int i = 0; i < tankDetailVec.size(); i++)
{
auto detailMap = tankDetailVec[i];
//code 不匹配,继续下一次循环查找
auto codeIter = detailMap.find("code");
if (codeIter == detailMap.end())
continue;
// 详情表code 与原管网code不想等, 不符合条件
if (codeIter->second == code)
continue;
// 根据属性修改对应的值
std::string attri = detailMap.find("属性")->second;
std::string newValue = detailMap.find("属性新值")->second;
if (attri == tankTable.elev)
{
Elev = newValue;
}
else if (attri == tankTable.initLevel)
{
InitLevel = newValue;
}
else if (attri == tankTable.minLevel)
{
MinLevel = newValue;
}
else if (attri == tankTable.maxLevel)
{
MaxLevel = newValue;
}
else if (attri == tankTable.diametor)
{
Diameter = newValue;
}
else if (attri == tankTable.minVolume)
{
MinVol = newValue;
}
else if (attri == tankTable.volumeCurve)
{
VolCurve = newValue;
}
}
tank.Elev = Elev;
tank.InitLevel = InitLevel;
tank.MinLevel = MinLevel;
tank.MaxLevel = MaxLevel;
tank.Diameter = Diameter;
tank.MinVol = MinVol;
tank.VolCurve = VolCurve;
tanks.addItem(tank);
}
return true;
}
bool CivProjInpDbHelper::getValve(CivValve& valves)
{
ValveTable vaveTable;
/*ValveTable vaveTable;
std::vector<std::string> fields;
fields.push_back(vaveTable.sn);
......@@ -162,6 +736,10 @@ bool CivProjInpDbHelper::getValve(CivValve& valves)
vave.MinorLoss = map.find(vaveTable.lossCoeff)->second;
valves.addItem(vave);
}*/
for (int i = 0; i < mValuvesVec.size(); i++)
{
valves.addItem(mValuvesVec[i]);
}
return true;
}
......@@ -178,8 +756,11 @@ bool CivProjInpDbHelper::getPumps(CivPumps& pumps)
fields.push_back(pmTable.power);
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(PUMP, fields, resultVector);
mDbConn->query(PROJ_PUMP, fields, resultVector,mCondition);
std::string condition1 = splicingConditions(PUMP);
mDbConn->query(PUMP, fields, resultVector, condition1);
std::string condition2 = " \"方案编码\" = '" + mPorjCode + "'";
mDbConn->query(PROJ_PUMP, fields, resultVector, condition2);
size_t totals = resultVector.size();
for (int i = 0; i < totals; i++)
......@@ -210,13 +791,23 @@ bool CivProjInpDbHelper::getReservoirs(CivReservoirs& reservoirs)
{
ResourcesTable restemTable;
std::vector<std::string> fields;
fields.push_back(restemTable.sn);
fields.push_back(restemTable.headPattern);
std::string sql = "select \"code\",\"本点号\",\"总水头\",\"水头模式\" from \"水库\" \
where code not in(select \"code\" from \"方案详情表\" \
where \"方案编码\"='"+mPorjCode+"' and \"图层\"='水库' and \"操作类型\" =0) \
union select \"code\",\"本点号\",\"总水头\",\"水头模式\" from \"方案水库\" where \"方案编码\" = '"+mPorjCode+"'";
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(RESIVOIR, fields, resultVector);
mDbConn->query(PROJ_RESIVOIR, fields, resultVector, mCondition);
if (!mDbConn->execSql(sql))
return false;
mDbConn->queryResult(resultVector);
// 找出节点图层修改的值
std::vector<std::map<std::string, std::string>> resourceDetailVec;
auto iter = mDetailMap.find(PIPENODE);
if (iter != mDetailMap.end())
resourceDetailVec = iter->second;
size_t totals = resultVector.size();
for (int i = 0; i < totals; i++)
......@@ -224,9 +815,39 @@ bool CivProjInpDbHelper::getReservoirs(CivReservoirs& reservoirs)
CivReservoirs::ReservoirsTable resTable;
std::map<std::string, std::string> map = resultVector[i];
std::string code = map.find("code")->second;
std::string totalHead = map.find(restemTable.totalHead)->second;
std::string Pattern = map.find(restemTable.headPattern)->second;
for (int i = 0; i < resourceDetailVec.size(); i++)
{
std::map<std::string, std::string> detailMap = resourceDetailVec[i];
//code 不匹配,继续下一次循环查找
auto codeIter = detailMap.find("code");
if (codeIter == detailMap.end())
continue;
// 详情表code 与原管网code不想等, 不符合条件
if (codeIter->second != code)
continue;
// 根据属性修改对应的值
std::string attri = detailMap.find("属性")->second;
std::string newValue = detailMap.find("属性新值")->second;
if (attri == restemTable.totalHead)
{
totalHead = newValue;
}
else if (attri == restemTable.headPattern)
{
Pattern = newValue;
}
}
resTable.ID = map.find(restemTable.sn)->second;
resTable.Head = map.find(restemTable.totalHead)->second;
resTable.Pattern = map.find(restemTable.headPattern)->second;
resTable.Head = totalHead;
resTable.Pattern = Pattern;
reservoirs.addItem(resTable);
}
......@@ -244,12 +865,21 @@ bool CivProjInpDbHelper::getCoordinates(CivCoordinates& coord)
fields.push_back(nodeTable.yCoord);
std::vector<std::map<std::string, std::string>> resultVector;
mDbConn->query(PIPENODE, fields, resultVector);
mDbConn->query(PROJ_PIPENODE, fields, resultVector, mCondition);
mDbConn->query(PROJ_PIPELINE, fields, resultVector, mCondition);
mDbConn->query(PROJ_RESIVOIR, fields, resultVector, mCondition);
mDbConn->query(TANK, fields, resultVector);
mDbConn->query(RESIVOIR, fields, resultVector);
std::string condition1 = splicingConditions(PIPENODE);
mDbConn->query(PIPENODE, fields, resultVector, condition1);
std::string condition2 = splicingConditions(TANK);
mDbConn->query(TANK, fields, resultVector,condition2);
std::string condition3 = splicingConditions(RESIVOIR);
mDbConn->query(RESIVOIR, fields, resultVector, condition3);
std::string condition = " \"方案编码\" = '"+mPorjCode+"'";
mDbConn->query(PROJ_PIPENODE, fields, resultVector, condition);
mDbConn->query(PROJ_TANK, fields, resultVector, condition);
mDbConn->query(PROJ_RESIVOIR, fields, resultVector, condition);
size_t totals = resultVector.size();
for (int i = 0; i < totals; i++)
......@@ -264,6 +894,11 @@ bool CivProjInpDbHelper::getCoordinates(CivCoordinates& coord)
coord.addItem(coordTable);
}
// 虚拟点坐标
for (int i = 0; i < mCoords.size(); i++)
{
coord.addItem(mCoords[i]);
}
return true;
}
......@@ -299,5 +934,15 @@ bool CivProjInpDbHelper::getQuality(CivQuality& quality)
bool CivProjInpDbHelper::getStatus(CivStatus& status)
{
// 阀门状态
for (int i = 0; i < mStatusVec.size(); i++)
{
status.addItem(mStatusVec[i]);
}
return true;
}
std::string CivProjInpDbHelper::genSql(const std::string& table)
{
return "";
}
\ No newline at end of file
......@@ -5,12 +5,15 @@
/**
* 增加
*/
class INPDLLEXPORT CivProjInpDbHelper: public CivInpHelperAbs
class PANDADBMANAGER_API CivProjInpDbHelper: public CivInpHelperAbs
{
public:
explicit CivProjInpDbHelper(const std::string& uri);
~CivProjInpDbHelper();
void handlePump() override;
void handleValve() override;
bool getNode(CivNode& node)override;
bool getPipe(CivPipe& pipe) override;
bool getTank(CivTank& tank) override;
......@@ -24,6 +27,19 @@ public:
void setProjCode(const std::string& projCode);
private:
// 将方案详情表查出的数据按图层分类
void sortProjDeatil();
/**
*@brief 根据图层动态生成需要查询详情表条件
*/
std::string inline splicingConditions(const std::string& layer);
std::string inline genSql(const std::string& table);
std::string mPorjCode;
std::string mCondition;
// 根据方案编码做详情表的数据缓存
std::map<std::string,std::vector<std::map<std::string,std::string>>> mDetailMap;
};
......@@ -46,6 +46,37 @@ struct TankResultItem :public ResultItem
float dTankLevel;
};
// 方案结果
struct ProjResultItem
{
char szNo[64];
std::string code; // 编码,管段或者节点的数据标识
std::string projCode; // 方案编码,标识是哪一个方案
std::string dDateTime; // 存储数据的当前时间
std::string dTime; // 模拟的是哪一个时刻的值
};
// 方案点结果
struct ProjNodeResultItem : public ProjResultItem
{
float dHead; // 水头
float dPressure; // 压力
float dProjHead; // 方案水头
float dProjPressure;// 方案压力
};
// 方案线结果
struct PorjPipeResultItem : public ProjResultItem
{
float dFlow; // 流量
float dVelocity; //流速
float dHeadLoss;// 单位水头损失
float dPorjHeadLoss;// 方案单位水头损失
float dProjFlow; // 方案的流量
float dProjVelocity; // 方案的流速
};
#define NodeResultItems std::map<std::string,NodeResultItem>
#define LinkResultItems std::map<std::string,LinkResultItem>
#define TankResultItems std::map<std::string,TankResultItem>
......@@ -66,6 +97,9 @@ typedef struct PipeCoord
std::string endY;// 终止节点Y
}PipeCoord;
// 方案详情表信息结构
#define NodeCoords std::map<std::string,NodeCoord>
#define PipeCoords std::map<std::string,PipeCoord>
......@@ -93,7 +93,7 @@ bool CivSimulResDbHelper::insertLinksBulk(const std::map<int, LinkResultItems>&
sql.append("\'" + CurrentTime + "\'");
sql.append(",");
sql.append(std::to_string(linkItem.dChlorine));
sql.append("),");
sql.append("),");currentTime
condition = "\'" + linkItem.dTime + "\'";
}
......@@ -244,112 +244,3 @@ bool CivSimulResDbHelper::insertTanks(const TankResultItems& tankMap)
{
return true;
}
\ No newline at end of file
void CivSimulResDbHelper::getAllNodeCoords(NodeCoords& nodeCoords)
{
std::vector<std::string> fileds = {
"本点号","横坐标","纵坐标"
};
std::vector<std::map<std::string, std::string>> res;
if (!mConn->query(PIPENODE, fileds, res))
return;
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
NodeCoord nodeCoord;
std::string key = nodeInfo.find(fileds[0])->second;
nodeCoord.xCoord = nodeInfo.find(fileds[1])->second;
nodeCoord.yCoord = nodeInfo.find(fileds[2])->second;
nodeCoords[key] = nodeCoord;
}
}
void CivSimulResDbHelper::getAllPipeCoords(PipeCoords& pipeCoords)
{
std::vector<std::string> fileds = {
"ST_X(ST_StartPoint(ST_GeometryN(geom,1))) as startx",
"ST_Y(ST_StartPoint(ST_GeometryN(geom,1))) as starty",
"ST_X(ST_EndPoint(ST_GeometryN(geom,1))) as endX" ,
"ST_Y(ST_EndPoint(ST_GeometryN(geom,1))) as endY",
"编号"
};
std::vector<std::map<std::string, std::string>> res;
if (!mConn->query(PIPELINE, fileds, res))
return;
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string key = nodeInfo.find("编号")->second;
pipeCoord.startX = nodeInfo.find("startx")->second;
pipeCoord.startY = nodeInfo.find("starty")->second;
pipeCoord.endX = nodeInfo.find("endx")->second;
pipeCoord.endY = nodeInfo.find("endy")->second;
pipeCoords[key] = pipeCoord;
}
}
void CivSimulResDbHelper::getLinCodeSnMap(std::map<std::string, std::string>& map)
{
std::vector<std::string> fileds = {
"\"编号\"",
"\"code\""
};
std::vector<std::map<std::string, std::string>> res;
mConn->query(PIPELINE, fileds, res);
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string sn = nodeInfo.find("编号")->second;
std::string code = nodeInfo.find("code")->second;
map[sn] = code;
}
}
void CivSimulResDbHelper::getNodeCodeSnMap(std::map<std::string, std::string>& map)
{
std::vector<std::string> fileds = {
"\"本点号\"",
"\"code\""
};
std::vector<std::map<std::string, std::string>> res;
mConn->query(PIPENODE, fileds, res);
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string sn = nodeInfo.find("本点号")->second;
std::string code = nodeInfo.find("code")->second;
map[sn] = code;
}
}
bool CivSimulResDbHelper::beginTransaction()
{
return mConn->beginTransaction();
}
bool CivSimulResDbHelper::commitTransaction()
{
return mConn->commitTransaction();
}
\ No newline at end of file
......@@ -2,29 +2,20 @@
#include "CivSimulResHelperAbs.h"
#include<vector>
#include<string>
#include "pandaDbManager.h"
#define RESDBHELPER __declspec(dllexport)
class RESDBHELPER CivSimulResDbHelper :public CivSimulResHelperAbs
class PANDADBMANAGER_API CivSimulResDbHelper :public CivSimulResHelperAbs
{
public:
explicit CivSimulResDbHelper(const std::string& uri);
~CivSimulResDbHelper();
virtual bool beginTransaction();
virtual bool commitTransaction();
virtual bool insertNodes(const NodeResultItems& nodeitems);
virtual bool insertLinks(const LinkResultItems& linkMap);
virtual bool insertTanks(const TankResultItems& tankMap);
virtual bool insertLinksBulk(const std::map<int,LinkResultItems>& linksMap);
virtual bool insertNodeBulk(const std::map<int, NodeResultItems>& nodesMap);
virtual void getAllNodeCoords(NodeCoords& nodeCoords);
virtual void getAllPipeCoords(PipeCoords& pipeCoords);
virtual void getLinCodeSnMap(std::map<std::string, std::string>& map);
virtual void getNodeCodeSnMap(std::map<std::string, std::string>& map);
private:
std::vector<std::string> mNodeFields;
std::vector<std::string> mLinkFileds;
......
......@@ -11,19 +11,19 @@ CivSimulResHelperAbs::~CivSimulResHelperAbs()
{
}
bool CivSimulResHelperAbs::beginTransaction()
bool CivSimulResHelperAbs::insertNodes(const NodeResultItems& nodeMap)
{
return true;
}
bool CivSimulResHelperAbs::commitTransaction()
void CivSimulResHelperAbs::saveNodeToDb(const std::vector<ProjNodeResultItem>& nodeItems)
{
return true;
}
bool CivSimulResHelperAbs::insertNodes(const NodeResultItems& nodeMap)
void CivSimulResHelperAbs::savePipeToDb(const std::vector<PorjPipeResultItem>& pipeItems)
{
return true;
}
bool CivSimulResHelperAbs::insertLinks(const LinkResultItems& linkMap)
......@@ -48,22 +48,115 @@ bool CivSimulResHelperAbs::insertNodeBulk(const std::map<int, TankResultItems>&
void CivSimulResHelperAbs::getAllNodeCoords(NodeCoords& nodeCoords)
{
if (!mConn)
return;
std::vector<std::string> fileds = {
"本点号","横坐标","纵坐标"
};
std::vector<std::map<std::string, std::string>> res;
if (!mConn->query(PIPENODE, fileds, res))
return;
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
NodeCoord nodeCoord;
std::string key = nodeInfo.find(fileds[0])->second;
nodeCoord.xCoord = nodeInfo.find(fileds[1])->second;
nodeCoord.yCoord = nodeInfo.find(fileds[2])->second;
nodeCoords[key] = nodeCoord;
}
}
void CivSimulResHelperAbs::getAllPipeCoords(PipeCoords& pipeCoords)
{
if (!mConn)
return;
std::vector<std::string> fileds = {
"ST_X(ST_StartPoint(ST_GeometryN(geom,1))) as startx",
"ST_Y(ST_StartPoint(ST_GeometryN(geom,1))) as starty",
"ST_X(ST_EndPoint(ST_GeometryN(geom,1))) as endX" ,
"ST_Y(ST_EndPoint(ST_GeometryN(geom,1))) as endY",
"编号"
};
std::vector<std::map<std::string, std::string>> res;
if (!mConn->query(PIPELINE, fileds, res))
return;
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string key = nodeInfo.find("编号")->second;
pipeCoord.startX = nodeInfo.find("startx")->second;
pipeCoord.startY = nodeInfo.find("starty")->second;
pipeCoord.endX = nodeInfo.find("endx")->second;
pipeCoord.endY = nodeInfo.find("endy")->second;
pipeCoords[key] = pipeCoord;
}
}
void CivSimulResHelperAbs::getLinCodeSnMap(std::map<std::string, std::string>& map)
{
if (!mConn)
return;
std::vector<std::string> fileds = {
"\"编号\"",
"\"code\""
};
std::vector<std::map<std::string, std::string>> res;
mConn->query(PIPELINE, fileds, res);
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string sn = nodeInfo.find("编号")->second;
std::string code = nodeInfo.find("code")->second;
map[sn] = code;
}
}
void CivSimulResHelperAbs::getNodeCodeSnMap(std::map<std::string, std::string>& map)
{
if (!mConn)
return;
std::vector<std::string> fileds = {
"\"本点号\"",
"\"code\""
};
std::vector<std::map<std::string, std::string>> res;
mConn->query(PIPENODE, fileds, res);
size_t total = res.size();
for (int i = 0; i < total; i++)
{
std::map<std::string, std::string> nodeInfo = res[i];
PipeCoord pipeCoord;
std::string sn = nodeInfo.find("本点号")->second;
std::string code = nodeInfo.find("code")->second;
map[sn] = code;
}
}
#pragma once
#include <string>
#include <map>
#include <vector>
#include "CivSimuResStruct.h"
#include "pandaDbManager.h"
#define SIMULABSEXPORT __declspec(dllexport)
class CivConnection;
/**
ģ
*/
class SIMULABSEXPORT CivSimulResHelperAbs
class PANDADBMANAGER_API CivSimulResHelperAbs
{
public:
explicit CivSimulResHelperAbs();
virtual ~CivSimulResHelperAbs();
virtual bool beginTransaction();
virtual bool commitTransaction();
virtual bool insertNodes(const NodeResultItems& nodeitems);
virtual bool insertLinks(const LinkResultItems& linkMap);
virtual bool insertTanks(const TankResultItems& tankMap);
virtual bool insertLinksBulk(const std::map<int, LinkResultItems>& linksMap);
virtual bool insertNodeBulk(const std::map<int, TankResultItems>& nodesMap);
virtual void getAllNodeCoords(NodeCoords& nodeCoords);
virtual void getAllPipeCoords(PipeCoords& pipeCoords);
virtual void getLinCodeSnMap(std::map<std::string, std::string>& map);
virtual void getNodeCodeSnMap(std::map<std::string, std::string>& map);
virtual void saveNodeToDb(const std::vector<ProjNodeResultItem>& nodeItems);
virtual void savePipeToDb(const std::vector<PorjPipeResultItem>& pipeItems);
void getLinCodeSnMap(std::map<std::string, std::string>& map);
void getNodeCodeSnMap(std::map<std::string, std::string>& map);
void getAllNodeCoords(NodeCoords& nodeCoords);
void getAllPipeCoords(PipeCoords& pipeCoords);
protected:
CivConnection* mConn = nullptr;
......
......@@ -12,8 +12,18 @@
#define TABLE_NODE "节点"
#define TABLE_PIPE "管段"
#define TABLE_TANK "水池"
#define TABLE_VALVEE "阀门"
#define TABLE_VALVE "阀门"
#define TABLE_RESERVOIR "水库"
#define TABLE_PUMP "水泵"
#define PROJ_TABLE_NODE "方案节点"
#define PROJ_TABLE_PIPE "方案管段"
#define PROJ_TABLE_TANK "方案水池"
#define PROJ_TABLE_VALVE "方案阀门"
#define PROJ_TABLE_RESERVOIR "方案水库"
#define PROJ_TABLE_PUMP "方案水泵"
#define TABLE_PROJ "方案表"
#define TABLE_PIPESIMUL "管段模拟值"
#define TABLE_NODESIMUL "节点模拟值"
......
#pragma once
#if defined(PANDADBMANAGER_DLL)
#if defined(PANDADBMANAGER_EXPORTS)
#if defined(_MSC_VER)
#define PANDADBMANAGER_API __declspec(dllexport)
#else
#define PANDADBMANAGER_API
#endif
#else
#if defined(_MSC_VER)
#define PANDADBMANAGER_API __declspec(dllimport)
#else
#define PANDADBMANAGER_API
#endif
#endif
#else
#define PANDADBMANAGER_API
#endif
......@@ -134,7 +134,7 @@
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>_CRT_SECURE_NO_WARNINGS;WINDOWS</PreprocessorDefinitions>
<PreprocessorDefinitions>_CRT_SECURE_NO_WARNINGS;WINDOWS;PANDADBMANAGER_DLL;PANDADBMANAGER_EXPORTS;PANDALOG_DLL;PANDALOG_EXPORTS</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
<AdditionalIncludeDirectories>$(OUTDIR)..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
<Optimization>MaxSpeed</Optimization>
......@@ -158,6 +158,7 @@ copy CivSimuResStruct.h $(OutDir)..\include /y
copy CivSimulResHelperAbs.h $(OutDir)..\include /y
copy CivSimulResDbHelper.h $(OutDir)..\include /y
copy CivHydrTableHelper.h $(OutDir)..\include /y
copy CIvProjSimulResHelper.h $(OutDir)..\include /y
</Command>
</PostBuildEvent>
</ItemDefinitionGroup>
......@@ -169,11 +170,13 @@ copy CivHydrTableHelper.h $(OutDir)..\include /y
<ClInclude Include="CivInpHelperAbs.h" />
<ClInclude Include="CivPgDbConnection.h" />
<ClInclude Include="CivProjInpDbHelper.h" />
<ClInclude Include="CIvProjSimulResHelper.h" />
<ClInclude Include="CivSimulResDbHelper.h" />
<ClInclude Include="CivSimulResHelperAbs.h" />
<ClInclude Include="CivSimuResStruct.h" />
<ClInclude Include="CivTableFields.h" />
<ClInclude Include="CivTypes.h" />
<ClInclude Include="pandaDbManager.h" />
</ItemGroup>
<ItemGroup>
<ClCompile Include="CivAssembly.cpp" />
......@@ -183,6 +186,7 @@ copy CivHydrTableHelper.h $(OutDir)..\include /y
<ClCompile Include="CivInpHelperAbs.cpp" />
<ClCompile Include="CivPgDbConnection.cpp" />
<ClCompile Include="CivProjInpDbHelper.cpp" />
<ClCompile Include="CIvProjSimulResHelper.cpp" />
<ClCompile Include="CivSimulResDbHelper.cpp" />
<ClCompile Include="CivSimulResHelperAbs.cpp" />
</ItemGroup>
......
......@@ -51,6 +51,12 @@
<ClInclude Include="CivHydrTableHelper.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="CIvProjSimulResHelper.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="pandaDbManager.h">
<Filter>头文件</Filter>
</ClInclude>
</ItemGroup>
<ItemGroup>
<ClCompile Include="CivAssembly.cpp">
......@@ -80,5 +86,8 @@
<ClCompile Include="CivHydrTableHelper.cpp">
<Filter>源文件</Filter>
</ClCompile>
<ClCompile Include="CIvProjSimulResHelper.cpp">
<Filter>源文件</Filter>
</ClCompile>
</ItemGroup>
</Project>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<ShowAllFiles>false</ShowAllFiles>
<ShowAllFiles>true</ShowAllFiles>
</PropertyGroup>
</Project>
\ No newline at end of file
......@@ -2,9 +2,7 @@
#include<string>
#include<map>
#include<vector>
#define UTILSEXPORT __declspec(dllexport)
#include "pandaLog.h"
// 字符串转编码
#define TransUTFCoding(name) CivCommonUtils::string_To_UTF8(name)
......@@ -17,7 +15,7 @@
#define CurrentHour CivCommonUtils::currentHour()
class UTILSEXPORT CivCommonUtils
class PANDALOG_API CivCommonUtils
{
public:
......
......@@ -4,11 +4,11 @@
#include <sstream>
#include <string>
#include <vector>
#include "pandaLog.h"
#define CSVEXPORT __declspec(dllexport)
using namespace std;
class CSVEXPORT CivCsvReader
class PANDALOG_API CivCsvReader
{
public:
explicit CivCsvReader(const char*);
......
#pragma once
#include <string>
#include "pandaLog.h"
#define CDATEEXPORT __declspec(dllexport)
class CDATEEXPORT CivDate
class PANDALOG_API CivDate
{
private:
int year;
......
......@@ -4,13 +4,12 @@
#include <string>
#include<iostream>
#include<fstream>
#define SYSLOGEXPORT __declspec(dllexport)
#include "pandaLog.h"
/**
日志记录接口
*/
class SYSLOGEXPORT CivSysLog {
class PANDALOG_API CivSysLog {
private:
CivSysLog();
......
#include "StringUtils.h"
void StringUtils::split(std::string sourceStr, std::vector<std::string>& res, const std::string& delim)
{
char source[512];
strcpy(source,sourceStr.c_str());
char deli[32];
strcpy(deli, delim.c_str());
char* token;
char* ptr = source;
while ((token = strtok(ptr, deli)) != NULL)
{
std::string temp = token;
res.push_back(temp);
ptr = NULL;
}
}
\ No newline at end of file
#pragma once
#include <string>
#include <vector>
#include "pandaLog.h"
/**
字符串分割
*/
class PANDALOG_API StringUtils
{
public:
/**
*@brief 将字符串按照分隔符分割成字符串数组
*@param [std::string] 源字符串
*@param [std::vector] 分割后的字符串数组
*@param [std::string] delim 分割符,默认空格分割
*/
static void split(std::string sourceStr, std::vector<std::string>& res, const std::string& delim =" ");
};
#pragma once
#if defined(PANDALOG_DLL)
#if defined(PANDALOG_EXPORTS)
#if defined(_MSC_VER)
#define PANDALOG_API __declspec(dllexport)
#else
#define PANDALOG_API
#endif
#else
#if defined(_MSC_VER)
#define PANDALOG_API __declspec(dllimport)
#else
#define PANDALOG_API
#endif
#endif
#else
#define PANDALOG_API
#endif
......@@ -130,7 +130,7 @@
<FunctionLevelLinking>true</FunctionLevelLinking>
<IntrinsicFunctions>true</IntrinsicFunctions>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<PreprocessorDefinitions>_CRT_SECURE_NO_WARNINGS;PANDALOG_DLL;PANDALOG_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<ConformanceMode>true</ConformanceMode>
</ClCompile>
<Link>
......@@ -145,16 +145,20 @@
<Command>copy CivSysLog.h $(OutDir)..\include /y
copy CivCsvReader.h $(OutDir)..\include /y
copy CivCommonUtils.h $(OutDir)..\include /y
copy CivDate.h $(OutDir)..\include /y</Command>
copy CivDate.h $(OutDir)..\include /y
copy StringUtils.h $(OutDir)..\include /y
copy pandaLog.h $(OutDir)..\include /y</Command>
</PostBuildEvent>
</ItemDefinitionGroup>
<ItemGroup>
<ClInclude Include="CivCommonUtils.h" />
<ClInclude Include="CivCsvReader.h" />
<ClInclude Include="CivDate.h" />
<ClInclude Include="pandaLog.h" />
<ClInclude Include="CivSysLog.h" />
<ClInclude Include="cJSON.h" />
<ClInclude Include="JsonParseObject.h" />
<ClInclude Include="StringUtils.h" />
</ItemGroup>
<ItemGroup>
<ClCompile Include="CivCommonUtils.cpp" />
......@@ -163,6 +167,7 @@ copy CivDate.h $(OutDir)..\include /y</Command>
<ClCompile Include="CivSysLog.cpp" />
<ClCompile Include="cJSON.c" />
<ClCompile Include="JsonParseObject.cpp" />
<ClCompile Include="StringUtils.cpp" />
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
......
......@@ -33,6 +33,12 @@
<ClInclude Include="JsonParseObject.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="StringUtils.h">
<Filter>头文件</Filter>
</ClInclude>
<ClInclude Include="pandaLog.h">
<Filter>头文件</Filter>
</ClInclude>
</ItemGroup>
<ItemGroup>
<ClCompile Include="CivSysLog.cpp">
......@@ -53,5 +59,8 @@
<ClCompile Include="JsonParseObject.cpp">
<Filter>源文件</Filter>
</ClCompile>
<ClCompile Include="StringUtils.cpp">
<Filter>源文件</Filter>
</ClCompile>
</ItemGroup>
</Project>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup />
<PropertyGroup>
<ShowAllFiles>true</ShowAllFiles>
</PropertyGroup>
</Project>
\ No newline at end of file
......@@ -78,7 +78,7 @@
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
<LinkIncremental>true</LinkIncremental>
<IntDir>$(ProjectDir)..\tmp\$(PlatformName)\$(ProjectName)\$(Configuration)\</IntDir>
<OutDir>..\..\hModelProgram\lib\</OutDir>
<OutDir>$(ProjectDir)..\libs\x64\</OutDir>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
......
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