File:KruskalDemo.gif
Da testwiki.
Vai alla navigazione
Vai alla ricerca
KruskalDemo.gif (314 × 323 pixel, dimensione del file: 415 KB, tipo MIME: image/gif, ciclico, 93 frame, 47 s)
Questo file proviene da Wikimedia Commons e può essere utilizzato da altri progetti. Di seguito viene mostrata la descrizione presente nella pagina di descrizione del file.
Dettagli
| DescrizioneKruskalDemo.gif |
English: A demo for Kruskal's algorithm to find minimum spanning tree on a 2D plane. |
| Data | |
| Fonte | Opera propria |
| Autore | Shiyu Ji |
Python 3 Code
'''
Minimum Spanning Tree generation (SVG) for Kruskal's algorithm.
Firstly use this code to generate SVG frames.
Then transform to bitmaps and convert to GIF.
'''
# range size
N = 300
margin = 20
def norm(x, y):
return (x*x+y*y)**.5
class Edge(object):
def __init__(self, source, target, points):
self.u = source
self.v = target
self.len = norm(points[source][0]-points[target][0], points[source][1]-points[target][1])
class UnionNode(object):
def __init__(self):
self.next = None
def saveToSVG(nFrames, points, firmed, trying):
f = open('demo_'+'0'*(3-len(str(nFrames)))+str(nFrames)+'.svg', 'w')
f.write("<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n")
for p in points:
f.write("<circle cx=\"" +str(p[0]+margin)+ "\" cy=\""+ str(N-p[1]+margin) +"\" r=\"5\" fill=\"white\" stroke=\"black\"/>\n")
for L in firmed:
f.write("<line x1=\"" +str(L[0][0]+margin)+ "\" y1=\""+ str(N-L[0][1]+margin) +"\" x2=\"" + str(L[1][0]+margin) + "\" y2=\"" + str(N-L[1][1]+margin) + "\" stroke=\"red\" stroke-width=\"5\"/>\n")
for L in trying:
f.write("<line x1=\"" +str(L[0][0]+margin)+ "\" y1=\""+ str(N-L[0][1]+margin) +"\" x2=\"" + str(L[1][0]+margin) + "\" y2=\"" + str(N-L[1][1]+margin) + "\" stroke=\"blue\" stroke-width=\"5\"/>\n")
f.write("</svg>\n")
f.close()
def generatePoints(n):
import random as r
r.seed(100)
res = []
for i in range(n):
pt = [r.randint(0,N) for _ in [0, 1]]
if [pt] not in res:
res += [pt]
return res
def kruskal(n, points):
n = len(points)
union = [UnionNode() for _ in points]
edges = []
for i in range(n-1):
for j in range(i+1, n):
e = Edge(i, j, points)
edges.append(e)
edges.sort(key = lambda x:-x.len)
mst = []
nframe = 0
saveToSVG(nframe, points, mst, [])
nframe+=1
while len(mst)<n-1:
s = edges[-1].u
t = edges[-1].v
saveToSVG(nframe, points, mst, [[points[s], points[t]]])
nframe+=1
p = union[s]
q = union[t]
while p.next != None: p = p.next
while q.next != None: q = q.next
if p!=q:
newNode = UnionNode()
p.next = q.next = newNode
mst.append([points[s], points[t]])
saveToSVG(nframe, points, mst, [])
nframe+=1
edges.pop()
return mst
# test 30 points temporarily
n = 30
pts = generatePoints(n)
kruskal(n, pts)
Licenza
Io, detentore del copyright su quest'opera, dichiaro di pubblicarla con la seguente licenza:
Questo file è disponibile in base alla licenza Creative Commons Attribuzione-Condividi allo stesso modo 4.0 Internazionale
- Tu sei libero:
- di condividere – di copiare, distribuire e trasmettere quest'opera
- di modificare – di adattare l'opera
- Alle seguenti condizioni:
- attribuzione – Devi fornire i crediti appropriati, un collegamento alla licenza e indicare se sono state apportate modifiche. Puoi farlo in qualsiasi modo ragionevole, ma non in alcun modo che suggerisca che il licenziante approvi te o il tuo uso.
- condividi allo stesso modo – Se remixi, trasformi o sviluppi il materiale, devi distribuire i tuoi contributi in base alla stessa licenza o compatibile all'originale.
Didascalie
Aggiungi una brevissima spiegazione di ciò che questo file rappresenta
Elementi ritratti in questo file
raffigura
Valore sconosciuto senza un elemento Wikidata
24 dic 2016
425 444 byte
323 pixel
314 pixel
image/gif
29632d222eeed6306182565f60864600f0660a8c
Cronologia del file
Fare clic su un gruppo data/ora per vedere il file come si presentava nel momento indicato.
| Data/Ora | Miniatura | Dimensioni | Utente | Commento | |
|---|---|---|---|---|---|
| attuale | 13:52, 24 dic 2016 | 314 × 323 (415 KB) | wikimediacommons>Shiyu Ji | User created page with UploadWizard |
Utilizzo del file
La seguente pagina usa questo file:
