#! -*- coding: utf-8
import numpy as np
import torch

__all__ = ["calc_mu_dog", "calc_vu_dog", "calc_mu_dowg", "calc_vu_dowg"]


def calc_mu_dog(r: float, vu: float, eps: float = 0.0) -> float:
    if isinstance(vu, torch.Tensor):
        vu = vu.detach().cpu().item()
    return r / (np.sqrt(vu+eps))


def calc_vu_dog(r: float, vu: float, delta_vu: float) -> float:
    # delta_vu: vuの増分値
    if isinstance(vu, torch.Tensor):
        vu = vu.detach().cpu().item()
    return vu+delta_vu


def calc_mu_dowg(r: float, vu: float, eps: float = 0.0) -> float:
    if isinstance(vu, torch.Tensor):
        vu = vu.detach().cpu().item()
    return (r**2) / np.sqrt(vu+eps)


def calc_vu_dowg(r: float, vu: float, delta_vu: float) -> float:
    # delta_vu: vuの増分値
    if isinstance(vu, torch.Tensor):
        vu = vu.detach().cpu().item()
    return vu+(r**2)*delta_vu
