ملف:PrimAlgDemo.gif
من testwiki
اذهب إلى التنقل
اذهب إلى البحث
PrimAlgDemo.gif (٣١٤ × ٣٢٣ بكسل حجم الملف: ٢٤٨ كيلوبايت، نوع MIME: image/gif، ملفوف، ٥٨ إطارا، ٢٩ث)
هذا الملف من ويكيميديا كومنز ويمكن استخدامه بواسطة المشاريع الأخرى. الوصف على صفحة وصف الملف هناك معروض بالأسفل.
ملخص
| الوصفPrimAlgDemo.gif |
English: A demo for Prim's algorithm to find minimum spanning tree on a 2D plane. |
| التاريخ | |
| المصدر | عمل شخصي |
| المؤلف | Shiyu Ji |
| GIF منشأ الملف InfoField |
Python 3 Code
'''
Minimum Spanning Tree generation (SVG) for Prim'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
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 prim(n, points):
n = len(points)
mst = []
S = set()
import heapq
heap = []
nframe = 0
while len(mst)<n-1:
if len(S)==0:
topV = 0
else:
while heap[0][2] in S:
heapq.heappop(heap)
topV = heap[0][2]
saveToSVG(nframe, points, mst, [[points[heap[0][1]], points[heap[0][2]]]])
nframe+=1
mst.append([points[heap[0][1]], points[topV]])
heapq.heappop(heap)
saveToSVG(nframe, points, mst, [])
nframe+=1
S.add(topV)
for i in range(n):
if i not in S:
L = norm(points[i][0]-points[topV][0], points[i][1]-points[topV][1])
heapq.heappush(heap, [L, topV, i])
return mst
# test 30 points temporarily
n = 30
pts = generatePoints(n)
prim(n, pts)
ترخيص
أنا، صاحب حقوق التأليف والنشر لهذا العمل، أنشر هذا العمل تحت الرخصة التالية:
هذا الملفُّ مُرخَّصٌ برخصة المشاع الإبداعي الدَّوليَّة المُلزِمة بنسب العمل إلى مُؤَلِّفه وبترخيص المُشتقَّات بالمثل 4.0.
- يحقُّ لك:
- مشاركة العمل – نسخ العمل وتوزيعه وبثُّه
- إعادة إنتاج العمل – تعديل العمل
- حسب الشروط التالية:
- نسب العمل إلى مُؤَلِّفه – يلزم نسب العمل إلى مُؤَلِّفه بشكل مناسب وتوفير رابط للرخصة وتحديد ما إذا أجريت تغييرات. بالإمكان القيام بذلك بأية طريقة معقولة، ولكن ليس بأية طريقة تشير إلى أن المرخِّص يوافقك على الاستعمال.
- الإلزام بترخيص المُشتقات بالمثل – إذا أعدت إنتاج المواد أو غيرت فيها، فيلزم أن تنشر مساهماتك المُشتقَّة عن الأصل تحت ترخيص الأصل نفسه أو تحت ترخيص مُتوافِقٍ معه.
الشروحات
أضف شرحاً من سطر واحد لما يُمثِّله هذا الملف
العناصر المصورة في هذا الملف
يُصوِّر
قيمة ما بدون عنصر ويكي بيانات
٢٤ ديسمبر 2016
image/gif
تاريخ الملف
اضغط على زمن/تاريخ لرؤية الملف كما بدا في هذا الزمن.
| زمن/تاريخ | صورة مصغرة | الأبعاد | مستخدم | تعليق | |
|---|---|---|---|---|---|
| حالي | ١٣:٥٢، ٢٤ ديسمبر ٢٠١٦ | ٣١٤ × ٣٢٣ (٢٤٨ كيلوبايت) | wikimediacommons>Shiyu Ji | User created page with UploadWizard |
استخدام الملف
الصفحة التالية تستخدم هذا الملف:
