#!/usr/bin/env python
# coding: utf-8

# In[ ]:


# we initilize the nodes out of the main function in the following all algorithms
def generate_complete_graph(agents):
    number=len(agents)
    weight=1/number
    neighbors={i:weight for i in range(number)}
    for i in range(number):
        agents[i].neighbors= neighbors

def generate_directed_complete_graph(agents):
    number=len(agents)
    weight=1/number
    #neighbors={i:weight for i in range(number)}
    for i in range(number):
        agents[i].neighbors={}
        for j in range(int(i+1)):
            agents[i].neighbors[j]=0
        

def generate_cycle_graph(agents):
    number=len(agents)
    weight=1/3
    for i in range(number):
        agents[i].neighbors={}
        agents[i].neighbors[(i-1)%number]=weight
        agents[i].neighbors[i]=weight
        agents[i].neighbors[(i+1)%number]=weight

def generate_ER_graph(agents,ave=4):
    number=len(agents)
    p=ave/(number-1)
    for ag in agents:
        ag.neighbors={}
    i=0
    while i<number-1:
        j=i+1
        while j<number:
            random_num=np.random.rand()
            if random_num<=p:
                agents[i].neighbors[j]=0
                agents[j].neighbors[i]=0
            j+=1
        i+=1
    for i in range(number):
        for j in agents[i].neighbors:
            agents[i].neighbors[j]=1/(1+max(len(agents[i].neighbors),len(agents[j].neighbors)))
    for i in range(number):
        agents[i].neighbors[i]=1-sum(list(agents[i].neighbors.values()))

