/* XMRig * Copyright (c) 2018-2020 SChernykh * Copyright (c) 2016-2020 XMRig , * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "backend/common/benchmark/Benchmark.h" #include "backend/common/benchmark/BenchState.h" #include "base/io/log/Log.h" #include "base/io/log/Tags.h" #include "base/tools/Chrono.h" #include xmrig::Benchmark::Benchmark(size_t workers, const IBackend *backend) : m_backend(backend), m_workers(workers) { } bool xmrig::Benchmark::finish(uint64_t totalHashCount) { m_current = totalHashCount; return BenchState::isDone(); } void xmrig::Benchmark::start() { m_startTime = BenchState::start(m_workers, m_backend); } void xmrig::Benchmark::printProgress() const { if (!m_startTime || !m_current) { return; } const double dt = static_cast(Chrono::steadyMSecs() - m_startTime) / 1000.0; const double percent = static_cast(m_current) / BenchState::size() * 100.0; LOG_NOTICE("%s " MAGENTA_BOLD("%5.2f%% ") CYAN_BOLD("%" PRIu64) CYAN("/%u") BLACK_BOLD(" (%.3fs)"), Tags::bench(), percent, m_current, BenchState::size(), dt); }