// MIT License // // Copyright (c) 2023-2025 Advanced Micro Devices, Inc. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in all // copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE // SOFTWARE. #pragma once #include "lib/common/mpl.hpp" #include #include #include #include #include #include #include namespace rocprofiler { namespace tool { namespace csv { struct numerical_formatter { template std::ostream& operator()(std::ostream& ofs, const Tp& _val) const { using value_type = common::mpl::unqualified_type_t; if constexpr(std::is_floating_point::value) { constexpr value_type one = 1; if(_val >= one) ofs << std::setprecision(6) << std::fixed; else ofs << std::setprecision(8) << std::scientific; } return ofs; } }; template std::ostream& write_csv_entry(std::ostream& ofs, TupleT&& _data, std::index_sequence) { auto _write = [&ofs](size_t idx, auto&& _val) { using value_type = common::mpl::unqualified_type_t; if(idx > 0) ofs << ","; if constexpr(common::mpl::is_string_type::value) ofs << "\""; FmtT{}(ofs, _val) << _val; if constexpr(common::mpl::is_string_type::value) ofs << "\""; }; (_write(Idx, std::get(_data)), ...); return (ofs << '\n'); } template struct csv_encoder { static constexpr auto columns = NumCols; template = 0> static auto write_row(std::ostream& ofs, Args&&... args) { write_csv_entry( ofs, std::make_tuple(std::forward(args)...), std::make_index_sequence{}); return csv_encoder{}; } template static auto write_row(std::ostream& ofs, const std::array& arr) { static_assert(N == columns, "Error! too many/few args passed"); write_csv_entry(ofs, arr, std::make_index_sequence{}); return csv_encoder{}; } }; using api_csv_encoder = csv_encoder<7>; using agent_info_csv_encoder = csv_encoder<53>; using kernel_trace_csv_encoder = csv_encoder<18>; using counter_collection_csv_encoder = csv_encoder<18>; using memory_copy_csv_encoder = csv_encoder<7>; using memory_allocation_csv_encoder = csv_encoder<8>; using marker_csv_encoder = csv_encoder<7>; using list_basic_metrics_csv_encoder = csv_encoder<5>; using list_derived_metrics_csv_encoder = csv_encoder<5>; using scratch_memory_encoder = csv_encoder<8>; using stats_csv_encoder = csv_encoder<8>; using pc_sampling_host_trap_csv_encoder = csv_encoder<6>; } // namespace csv } // namespace tool } // namespace rocprofiler