Используя мой собственный силовой алгоритм с Networkx
Я пытаюсь заставить работать силовой алгоритм, который я пишу. Я не использую тот, который поставляется с Networkx, потому что мы хотим позже изменить его для наших собственных целей. В настоящее время, когда я запускаю его, в строке 54 появляется сообщение об ошибке "Результат слишком велик". Есть идеи, почему это так?
import math
import networkx as nx
import matplotlib.pyplot as plt
node_data = {0:[0,0], 1:[0,0], 2:[0,0], 3:[0,0], 4:[0,0], 5:[0,0], 6:[0,0], 7:[0,0]}
graph = [(0,1),(1,2),(2,3),(3,0),(4,5),(5,6),(6,7),(7,4),(0,4),(1,5),(2,6),(3,7)]
pi = 3.14159265358979323
k = 1 # number of the node, ie the Kth node
# assign nodes an initial position evenly spaced around the unit circle
for key, value in node_data.items():
value[0] = math.cos((2 * pi * k) / len(node_data))
value[1] = math.sin((2 * pi * k) / len(node_data))
k += 1
#print node_data[0]
for i in range(0,600):
# repulsion forces
for key, value in node_data.items():
for key1, value1 in node_data.items():
if key1 > key:
# compare the x, y values of every element to every other
x0 = value[0]
y0 = value[1]
x1 = value1[0]
y1 = value1[1]
# compute repulsion force for each node
krepel = 0.001
frepel = krepel / math.sqrt((x1 - x0) ** 2 + (y1 - y0) ** 2)
theta = math.atan((y1 - y0) / (x1 - x0))
# update x and y values
value[0] -= frepel * math.cos(theta)
value[1] -= frepel * math.sin(theta)
value1[0] += frepel * math.cos(theta)
value1[1] += frepel * math.sin(theta)
#print node_data[0]
# attractive forces
for e in graph:
# compare nodes with nodes they are connected to
n0 = node_data[e[0]]
n1 = node_data[e[1]]
x0 = n0[0]
y0 = n0[1]
x1 = n1[0]
y1 = n1[1]
# compute fattract
kattract = 0.001
fattract = kattract * ((x1 - x0) ** 2 + (y1 + y0) ** 2)
theta = math.atan((y1 - y0) / (x1 - x0))
# update x and y values
n0[0] += fattract * math.cos(theta)
n0[1] += fattract * math.sin(theta)
n1[0] -= fattract * math.cos(theta)
n1[1] -= fattract * math.sin(theta)
#print node_data[0]
G = nx.Graph()
# add node
for key, value in node_data.items():
G.add_node(key, posxy=(value[0], value[1]))
# add edges
for e in graph:
G.add_edge(e[0], e[1])
print G.nodes()
print G.edges()
pos = nx.get_node_attributes(G, 'posxy')
# draw graph
nx.draw(G, pos)
# show graph
plt.show()