// Copyright (c) by respective owners including Yahoo!, Microsoft, and
// individual contributors. All rights reserved. Released under a BSD (revised)
// license as described in the file LICENSE.
#pragma once

#include <string>
#include "v_array.h"

namespace VW
{
namespace continuous_actions
{
struct probability_density_function_value
{
  float action = 0.f;     // continuous action
  float pdf_value = 0.f;  // pdf value

  probability_density_function_value() = default;
  probability_density_function_value(float action, float pdf_value) : action(action), pdf_value(pdf_value) {}
};

struct pdf_segment
{
  float left = 0.f;       // starting point
  float right = 0.f;      // ending point
  float pdf_value = 0.f;  // height

  pdf_segment() = default;
  pdf_segment(float left, float right, float pdf_value) : left(left), right(right), pdf_value(pdf_value) {}
  
  // Explicitly ensure this is trivially copyable
  pdf_segment(const pdf_segment&) = default;
  pdf_segment& operator=(const pdf_segment&) = default;
  ~pdf_segment() = default;
};

using probability_density_function = v_array<pdf_segment>;

std::string to_string(const probability_density_function_value& pdf_value, bool print_newline = false);
std::string to_string(const probability_density_function& pdf, bool print_newline = false, int precision = -1);
bool is_valid_pdf(probability_density_function& pdf);

}  // namespace continuous_actions
}  // namespace VW
