#pragma once #include <string> #include <vector> #include <map> #include <chrono> #include "Jikan.h" #ifdef INCLUDE_GPU_TIMER #include <cuda_runtime.h> #endif typedef std::chrono::steady_clock::time_point chrono_time_type; class EventData{ public: #ifdef INCLUDE_GPU_TIMER cudaEvent_t gpu_start, gpu_end; #endif bool if_mode_set; bool ifCUDAinit; chrono_time_type start; double elapsed_time, double_start; // seconds int count, ifCUDA; bool ifStart, ifEnd; std::vector<double> time_series; std::string event_name; std::vector<bool> mode; // order: mode[0] ~ if MPI, mode[1] ~ if OpenMP, mode[2] ~ if CUDA EventData(); ~EventData(); EventData(const std::string& name); EventData& operator=(const EventData& src); double GetMeanElapsedTime(); void GetModeVals(const int& mode); std::string GetEventModeName(); private: void InitEventsCUDA(); void DeinitEventsCUDA(); };