VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
TimeImp.cpp
Go to the documentation of this file.
1//=======================================================================================
2// ____ ____ __ ______ __________ __ __ __ __
3// \ \ | | | | | _ \ |___ ___| | | | | / \ | |
4// \ \ | | | | | |_) | | | | | | | / \ | |
5// \ \ | | | | | _ / | | | | | | / /\ \ | |
6// \ \ | | | | | | \ \ | | | \__/ | / ____ \ | |____
7// \ \ | | |__| |__| \__\ |__| \________/ /__/ \__\ |_______|
8// \ \ | | ________________________________________________________________
9// \ \ | | | ______________________________________________________________|
10// \ \| | | | __ __ __ __ ______ _______
11// \ | | |_____ | | | | | | | | | _ \ / _____)
12// \ | | _____| | | | | | | | | | | \ \ \_______
13// \ | | | | |_____ | \_/ | | | | |_/ / _____ |
14// \ _____| |__| |________| \_______/ |__| |______/ (_______/
15//
16// This file is part of VirtualFluids. VirtualFluids is free software: you can
17// redistribute it and/or modify it under the terms of the GNU General Public
18// License as published by the Free Software Foundation, either version 3 of
19// the License, or (at your option) any later version.
20//
21// VirtualFluids is distributed in the hope that it will be useful, but WITHOUT
22// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
23// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
24// for more details.
25//
26// SPDX-License-Identifier: GPL-3.0-or-later
27// SPDX-FileCopyrightText: Copyright © VirtualFluids Project contributors, see AUTHORS.md in root folder
28//
32//=======================================================================================
33#include "TimeImp.h"
34
35#include <sstream>
36
37std::shared_ptr<TimeImp> TimeImp::getNewInstance()
38{
39 return std::shared_ptr<TimeImp>(new TimeImp());
40}
41
42TimeImp::TimeImp()
43{
44
45}
46
48{
49 simulationStartTime = time(NULL);
50}
51
53{
54 simulationEndTime = time(NULL);
55}
56
58{
59 testStartTime = clock();
60}
61
63{
64 testEndTime = clock();
65}
66
68{
69 analyticalResultWriteStartTime = time(NULL);
70}
71
73{
74 analyticalResultWriteEndTime = time(NULL);
75}
76
78{
79 resultCheckStartTime = clock();
80}
81
83{
84 resultCheckEndTime = clock();
85}
86
88{
89 std::ostringstream oss;
90 oss << calcSimulationTime() << "sec";
91 return oss.str();
92}
93
95{
96 std::ostringstream oss;
97 oss << calcResultCheckTime() << "sec";
98 return oss.str();
99}
100
102{
103 std::ostringstream oss;
104 oss << calcTestTime() << "sec";
105 return oss.str();
106}
107
109{
110 std::ostringstream oss;
111 oss << calcAnalyticalResultWriteTime() << "sec";
112 return oss.str();
113}
114
115double TimeImp::calcSimulationTime()
116{
117 return difftime(simulationEndTime, simulationStartTime);
118}
119
120float TimeImp::calcResultCheckTime()
121{
122 float timeInMiliSec = ((float)(resultCheckEndTime - resultCheckStartTime) / CLOCKS_PER_SEC);
123 return timeInMiliSec;
124}
125
126float TimeImp::calcTestTime()
127{
128 float timeInMiliSec = ((float)(testEndTime - testStartTime) / CLOCKS_PER_SEC);
129 return timeInMiliSec;
130}
131
132double TimeImp::calcAnalyticalResultWriteTime()
133{
134 return difftime(analyticalResultWriteEndTime, analyticalResultWriteStartTime);
135}
136
static std::shared_ptr< TimeImp > getNewInstance()
Definition TimeImp.cpp:37
void setResultCheckEndTime() override
Definition TimeImp.cpp:82
std::string getResultCheckTime() override
Definition TimeImp.cpp:94
void setTestEndTime() override
Definition TimeImp.cpp:62
std::string getSimulationTime() override
Definition TimeImp.cpp:87
std::string getTestTime() override
Definition TimeImp.cpp:101
void setResultCheckStartTime() override
Definition TimeImp.cpp:77
void setAnalyticalResultWriteStartTime() override
Definition TimeImp.cpp:67
std::string getAnalyticalResultWriteTime() override
Definition TimeImp.cpp:108
void setSimulationStartTime() override
Definition TimeImp.cpp:47
void setTestStartTime() override
Definition TimeImp.cpp:57
void setSimulationEndTime() override
Definition TimeImp.cpp:52
void setAnalyticalResultWriteEndTime() override
Definition TimeImp.cpp:72
std::shared_ptr< T > SPtr