#! -*- coding: utf-8
import math

import numpy as np
import torch

from .dynamic_graph import *

__all__ = ["KPeerExponentialGraph"]


class KPeerExponentialGraph(DynamicGraph):
    def __init__(self, n_nodes, K: int = 2,
                 penalty: str = "no", nrepeat: int = 5, seed: int = 11):
        w_list = []

        k = K+1
        tau = max(int(np.floor(np.log(n_nodes)/np.log(k))), 1)
        for i in range(tau):
            interval = (k)**i
            w = np.array([0.0] * n_nodes)
            for idx in [(j*interval) % n_nodes for j in range(k)]:
                w[idx] += 1/k
            w = w.tolist()
            w_list.append(torch.tensor(
                np.array([w[-n:]+w[:-n] for n in range(n_nodes)]).astype(np.float32)))
        super().__init__(w_list,
                         penalty=penalty, nrepeat=nrepeat, seed=seed)
