बल-निर्देशित ग्राफ़ आरेखण: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Physical simulation to visualize graphs}} File:SocialNetworkAnalysis.png|250px|right|thumb|बल-निर्देशित ग्राफ़ ड्...")
 
No edit summary
Line 1: Line 1:
{{Short description|Physical simulation to visualize graphs}}
{{Short description|Physical simulation to visualize graphs}}
[[File:SocialNetworkAnalysis.png|250px|right|thumb|बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम का उपयोग करके सामाजिक नेटवर्क विज़ुअलाइज़ेशन<ref>{{citation|first=Martin|last=Grandjean|contribution=Introduction à la visualisation de données, l'analyse de réseau en histoire|year=2015|title=Geschichte und Informatik 18/19|pages=109–128|url=http://www.martingrandjean.ch/wp-content/uploads/2015/09/Grandjean2015.pdf}}</ref>]][[Image:Visualization of wiki structure using prefuse visualization package.png|250px|right|thumb|बल-निर्देशित लेआउट का उपयोग करके विकी पर पृष्ठों के बीच लिंक का विज़ुअलाइज़ेशन]]बल-निर्देशित [[ग्राफ ड्राइंग]] [[कलन विधि]] सौंदर्य-सुखदायक तरीके से ग्राफ़ ड्राइंग के लिए एल्गोरिदम का एक वर्ग है। उनका उद्देश्य ग्राफ़ (अलग-अलग गणित) के नोड्स को दो-आयामी या त्रि-आयामी अंतरिक्ष में स्थित करना है ताकि सभी किनारे कम या ज्यादा समान लंबाई के हों और जितना संभव हो उतना कम क्रॉसिंग किनारे हों, बीच में बल निर्दिष्ट करके किनारों का सेट और नोड्स का सेट, उनकी सापेक्ष स्थिति के आधार पर, और फिर इन बलों का उपयोग या तो किनारों और नोड्स की गति को अनुकरण करने या उनकी ऊर्जा को कम करने के लिए किया जाता है।<ref>{{citation|first=Stephen G.|last=Kobourov|title=Spring Embedders and Force-Directed Graph Drawing Algorithms|year=2012|arxiv=1201.3011|bibcode=2012arXiv1201.3011K}}.</ref>
[[File:SocialNetworkAnalysis.png|250px|right|thumb|बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम का उपयोग करके सामाजिक नेटवर्क विज़ुअलाइज़ेशन<ref>{{citation|first=Martin|last=Grandjean|contribution=Introduction à la visualisation de données, l'analyse de réseau en histoire|year=2015|title=Geschichte und Informatik 18/19|pages=109–128|url=http://www.martingrandjean.ch/wp-content/uploads/2015/09/Grandjean2015.pdf}}</ref>]][[Image:Visualization of wiki structure using prefuse visualization package.png|250px|right|thumb|बल-निर्देशित लेआउट का उपयोग करके विकी पर पृष्ठों के बीच लिंक का विज़ुअलाइज़ेशन]]बल-निर्देशित [[ग्राफ ड्राइंग]] [[कलन विधि]] सौंदर्य-सुखदायक तरीके से ग्राफ़ ड्राइंग के लिए एल्गोरिदम का वर्ग है। उनका उद्देश्य ग्राफ़ (अलग-अलग गणित) के नोड्स को दो-आयामी या त्रि-आयामी अंतरिक्ष में स्थित करना है ताकि सभी किनारे कम या ज्यादा समान लंबाई के हों और जितना संभव हो उतना कम क्रॉसिंग किनारे हों, बीच में बल निर्दिष्ट करके किनारों का सेट और नोड्स का सेट, उनकी सापेक्ष स्थिति के आधार पर, और फिर इन बलों का उपयोग या तो किनारों और नोड्स की गति को अनुकरण करने या उनकी ऊर्जा को कम करने के लिए किया जाता है।<ref>{{citation|first=Stephen G.|last=Kobourov|title=Spring Embedders and Force-Directed Graph Drawing Algorithms|year=2012|arxiv=1201.3011|bibcode=2012arXiv1201.3011K}}.</ref>
जबकि ग्राफ़ बनाना एक कठिन समस्या हो सकती है, बल-निर्देशित एल्गोरिदम, भौतिक सिमुलेशन होने के कारण, आमतौर पर ग्राफ़ सिद्धांत जैसे कि [[समतलीय ग्राफ]] के बारे में किसी विशेष ज्ञान की आवश्यकता नहीं होती है।
जबकि ग्राफ़ बनाना कठिन समस्या हो सकती है, बल-निर्देशित एल्गोरिदम, भौतिक सिमुलेशन होने के कारण, आमतौर पर ग्राफ़ सिद्धांत जैसे कि [[समतलीय ग्राफ]] के बारे में किसी विशेष ज्ञान की आवश्यकता नहीं होती है।


==बल==
==बल==
बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम किनारों के सेट और ग्राफ़ ड्राइंग के नोड्स के सेट के बीच बल निर्दिष्ट करते हैं। आमतौर पर, हुक के नियम पर आधारित [[वसंत (उपकरण)]]उपकरण) जैसे आकर्षक बलों का उपयोग ग्राफ के किनारों के अंतिम बिंदुओं के जोड़े को एक-दूसरे की ओर आकर्षित करने के लिए किया जाता है, जबकि साथ ही कूलम्ब के नियम के आधार पर विद्युत आवेश कणों जैसे प्रतिकारक बलों का उपयोग सभी जोड़े को अलग करने के लिए किया जाता है। नोड्स. बलों की इस प्रणाली के लिए [[यांत्रिक संतुलन]] में, किनारों की लंबाई एक समान होती है (स्प्रिंग बलों के कारण), और जो नोड्स एक किनारे से नहीं जुड़े होते हैं वे और अधिक दूर खींचे जाते हैं (विद्युत प्रतिकर्षण के कारण)। किनारे के आकर्षण और शीर्ष प्रतिकर्षण बलों को उन कार्यों का उपयोग करके परिभाषित किया जा सकता है जो स्प्रिंग्स और कणों के भौतिक व्यवहार पर आधारित नहीं हैं; उदाहरण के लिए, कुछ बल-निर्देशित प्रणालियाँ स्प्रिंग्स का उपयोग करती हैं जिनका आकर्षक बल रैखिक के बजाय लघुगणकीय होता है।
बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम किनारों के सेट और ग्राफ़ ड्राइंग के नोड्स के सेट के बीच बल निर्दिष्ट करते हैं। आमतौर पर, हुक के नियम पर आधारित [[वसंत (उपकरण)]]उपकरण) जैसे आकर्षक बलों का उपयोग ग्राफ के किनारों के अंतिम बिंदुओं के जोड़े को एक-दूसरे की ओर आकर्षित करने के लिए किया जाता है, जबकि साथ ही कूलम्ब के नियम के आधार पर विद्युत आवेश कणों जैसे प्रतिकारक बलों का उपयोग सभी जोड़े को अलग करने के लिए किया जाता है। नोड्स. बलों की इस प्रणाली के लिए [[यांत्रिक संतुलन]] में, किनारों की लंबाई समान होती है (स्प्रिंग बलों के कारण), और जो नोड्स किनारे से नहीं जुड़े होते हैं वे और अधिक दूर खींचे जाते हैं (विद्युत प्रतिकर्षण के कारण)। किनारे के आकर्षण और शीर्ष प्रतिकर्षण बलों को उन कार्यों का उपयोग करके परिभाषित किया जा सकता है जो स्प्रिंग्स और कणों के भौतिक व्यवहार पर आधारित नहीं हैं; उदाहरण के लिए, कुछ बल-निर्देशित प्रणालियाँ स्प्रिंग्स का उपयोग करती हैं जिनका आकर्षक बल रैखिक के बजाय लघुगणकीय होता है।
 
एक वैकल्पिक मॉडल प्रत्येक जोड़ी नोड्स के लिए स्प्रिंग-जैसे बल पर विचार करता है <math>(i,j)</math> जहां आदर्श लंबाई है <math>\delta_{ij}</math> प्रत्येक स्प्रिंग का मान एक अलग प्रतिकारक बल का उपयोग किए बिना, नोड्स i और j के बीच ग्राफ-सैद्धांतिक दूरी के समानुपाती होता है। [[यूक्लिडियन दूरी]] और नोड्स के बीच आदर्श दूरी के बीच अंतर (आमतौर पर वर्ग अंतर) को कम करना एक मीट्रिक [[बहुआयामी स्केलिंग]] समस्या के बराबर है।
 
एक बल-निर्देशित ग्राफ़ में यांत्रिक स्प्रिंग्स और विद्युत प्रतिकर्षण के अलावा अन्य बल शामिल हो सकते हैं। गुरुत्वाकर्षण के अनुरूप एक बल का उपयोग शीर्षों को ड्राइंग स्थान के एक निश्चित बिंदु की ओर खींचने के लिए किया जा सकता है; इसका उपयोग डिस्कनेक्ट किए गए ग्राफ़ के विभिन्न कनेक्टेड घटकों (ग्राफ़ सिद्धांत) को एक साथ खींचने के लिए किया जा सकता है, जो अन्यथा प्रतिकारक बलों के कारण एक-दूसरे से अलग हो जाते हैं, और ड्राइंग में अधिक केंद्रीय पदों पर अधिक केंद्रीयता वाले नोड्स खींचने के लिए उपयोग किया जा सकता है। ;<ref>{{citation|contribution=Force-directed graph drawing using social gravity and scaling|first1=M. J.|last1=Bannister|first2=D.|last2=Eppstein|author2-link=David Eppstein|first3=M. T.|last3=Goodrich|author3-link=Michael T. Goodrich|first4=L.|last4=Trott|arxiv=1209.0748|title=Proc. 20th Int. Symp. Graph Drawing|year=2012|bibcode=2012arXiv1209.0748B}}.</ref> यह एक घटक के भीतर शीर्ष रिक्ति को भी प्रभावित कर सकता है। निर्देशित ग्राफ़ के लिए [[चुंबकीय क्षेत्र]] के एनालॉग्स का उपयोग किया जा सकता है। अंतिम ड्राइंग में ओवरलैप या निकट-ओवरलैप से बचने के लिए किनारों के साथ-साथ नोड्स पर भी प्रतिकारक बल लगाए जा सकते हैं। घुमावदार किनारों वाले रेखाचित्रों जैसे कि वृत्ताकार चाप या [[तख़्ता वक्र]] में, इन वक्रों के नियंत्रण बिंदुओं पर बल भी लगाए जा सकते हैं, उदाहरण के लिए उनके कोणीय रिज़ॉल्यूशन (ग्राफ़ ड्राइंग) में सुधार करने के लिए।<ref>{{citation|first1=R.|last1=Chernobelskiy|first2=K.|last2=Cunningham|first3=M. T.|last3=Goodrich|author3-link=Michael T. Goodrich|first4=S. G.|last4=Kobourov|first5=L.|last5=Trott|contribution=Force-directed Lombardi-style graph drawing|title=Proc. 19th Symposium on Graph Drawing|pages=78–90|year=2011|url=http://www.cs.arizona.edu/~kobourov/fdl.pdf}}.</ref>


एक वैकल्पिक मॉडल प्रत्येक जोड़ी नोड्स के लिए स्प्रिंग-जैसे बल पर विचार करता है <math>(i,j)</math> जहां आदर्श लंबाई है <math>\delta_{ij}</math> प्रत्येक स्प्रिंग का मान अलग प्रतिकारक बल का उपयोग किए बिना, नोड्स i और j के बीच ग्राफ-सैद्धांतिक दूरी के समानुपाती होता है। [[यूक्लिडियन दूरी]] और नोड्स के बीच आदर्श दूरी के बीच अंतर (आमतौर पर वर्ग अंतर) को कम करना मीट्रिक [[बहुआयामी स्केलिंग]] समस्या के बराबर है।


एक बल-निर्देशित ग्राफ़ में यांत्रिक स्प्रिंग्स और विद्युत प्रतिकर्षण के अलावा अन्य बल शामिल हो सकते हैं। गुरुत्वाकर्षण के अनुरूप बल का उपयोग शीर्षों को ड्राइंग स्थान के निश्चित बिंदु की ओर खींचने के लिए किया जा सकता है; इसका उपयोग डिस्कनेक्ट किए गए ग्राफ़ के विभिन्न कनेक्टेड घटकों (ग्राफ़ सिद्धांत) को साथ खींचने के लिए किया जा सकता है, जो अन्यथा प्रतिकारक बलों के कारण एक-दूसरे से अलग हो जाते हैं, और ड्राइंग में अधिक केंद्रीय पदों पर अधिक केंद्रीयता वाले नोड्स खींचने के लिए उपयोग किया जा सकता है। ;<ref>{{citation|contribution=Force-directed graph drawing using social gravity and scaling|first1=M. J.|last1=Bannister|first2=D.|last2=Eppstein|author2-link=David Eppstein|first3=M. T.|last3=Goodrich|author3-link=Michael T. Goodrich|first4=L.|last4=Trott|arxiv=1209.0748|title=Proc. 20th Int. Symp. Graph Drawing|year=2012|bibcode=2012arXiv1209.0748B}}.</ref> यह घटक के भीतर शीर्ष रिक्ति को भी प्रभावित कर सकता है। निर्देशित ग्राफ़ के लिए [[चुंबकीय क्षेत्र]] के एनालॉग्स का उपयोग किया जा सकता है। अंतिम ड्राइंग में ओवरलैप या निकट-ओवरलैप से बचने के लिए किनारों के साथ-साथ नोड्स पर भी प्रतिकारक बल लगाए जा सकते हैं। घुमावदार किनारों वाले रेखाचित्रों जैसे कि वृत्ताकार चाप या [[तख़्ता वक्र]] में, इन वक्रों के नियंत्रण बिंदुओं पर बल भी लगाए जा सकते हैं, उदाहरण के लिए उनके कोणीय रिज़ॉल्यूशन (ग्राफ़ ड्राइंग) में सुधार करने के लिए।<ref>{{citation|first1=R.|last1=Chernobelskiy|first2=K.|last2=Cunningham|first3=M. T.|last3=Goodrich|author3-link=Michael T. Goodrich|first4=S. G.|last4=Kobourov|first5=L.|last5=Trott|contribution=Force-directed Lombardi-style graph drawing|title=Proc. 19th Symposium on Graph Drawing|pages=78–90|year=2011|url=http://www.cs.arizona.edu/~kobourov/fdl.pdf}}.</ref>
==तरीके==
==तरीके==
एक बार ग्राफ़ के नोड्स और किनारों पर बलों को परिभाषित किया गया है, तो इन स्रोतों के तहत पूरे ग्राफ़ का व्यवहार तब अनुकरण किया जा सकता है जैसे कि यह एक भौतिक प्रणाली थी। इस तरह के अनुकरण में, बलों को नोड्स पर लागू किया जाता है, उन्हें एक साथ करीब खींचा जाता है या उन्हें और दूर धकेल दिया जाता है। इसे तब तक दोहराया जाता है जब तक कि सिस्टम यांत्रिक संतुलन स्थिति में नहीं आ जाता; यानी, उनकी सापेक्ष स्थिति एक पुनरावृत्ति से दूसरी पुनरावृत्ति में नहीं बदलती है। इस संतुलन में नोड्स की स्थिति का उपयोग ग्राफ का चित्र बनाने के लिए किया जाता है।
एक बार ग्राफ़ के नोड्स और किनारों पर बलों को परिभाषित किया गया है, तो इन स्रोतों के तहत पूरे ग्राफ़ का व्यवहार तब अनुकरण किया जा सकता है जैसे कि यह भौतिक प्रणाली थी। इस तरह के अनुकरण में, बलों को नोड्स पर लागू किया जाता है, उन्हें साथ करीब खींचा जाता है या उन्हें और दूर धकेल दिया जाता है। इसे तब तक दोहराया जाता है जब तक कि सिस्टम यांत्रिक संतुलन स्थिति में नहीं आ जाता; यानी, उनकी सापेक्ष स्थिति पुनरावृत्ति से दूसरी पुनरावृत्ति में नहीं बदलती है। इस संतुलन में नोड्स की स्थिति का उपयोग ग्राफ का चित्र बनाने के लिए किया जाता है।


स्प्रिंग्स से परिभाषित बलों के लिए जिनकी आदर्श लंबाई ग्राफ-सैद्धांतिक दूरी के समानुपाती होती है, तनाव प्रमुखता एक बहुत अच्छी तरह से व्यवहार करती है (यानी, एक अनुक्रम की नीरस सीमा)<ref name="dl88">{{citation
स्प्रिंग्स से परिभाषित बलों के लिए जिनकी आदर्श लंबाई ग्राफ-सैद्धांतिक दूरी के समानुपाती होती है, तनाव प्रमुखता बहुत अच्छी तरह से व्यवहार करती है (यानी, अनुक्रम की नीरस सीमा)<ref name="dl88">{{citation
   | last=de Leeuw | first=Jan
   | last=de Leeuw | first=Jan
   | title=Convergence of the majorization method for multidimensional scaling
   | title=Convergence of the majorization method for multidimensional scaling
Line 22: Line 20:
   | volume=5 | issue=2 | pages=163&ndash;180
   | volume=5 | issue=2 | pages=163&ndash;180
   | doi=10.1007/BF01897162| s2cid=122413124
   | doi=10.1007/BF01897162| s2cid=122413124
  }}.</ref> और इन अंतरों को अनुकूलित करने के लिए गणितीय रूप से सुंदर तरीका (गणित) और, इसलिए, ग्राफ़ के लिए एक अच्छा लेआउट ढूंढें।
  }}.</ref> और इन अंतरों को अनुकूलित करने के लिए गणितीय रूप से सुंदर तरीका (गणित) और, इसलिए, ग्राफ़ के लिए अच्छा लेआउट ढूंढें।


ऐसे तंत्रों को नियोजित करना भी संभव है जो भौतिक सिमुलेशन के बजाय या उसके संयोजन के साथ ऊर्जा मिनिमा के लिए अधिक सीधे खोज करते हैं। ऐसे तंत्र, जो सामान्य [[वैश्विक अनुकूलन]] विधियों के उदाहरण हैं, में [[ तैयार किए हुयी धातु पे पानी चढाने की कला ]] और आनुवंशिक एल्गोरिदम शामिल हैं।
ऐसे तंत्रों को नियोजित करना भी संभव है जो भौतिक सिमुलेशन के बजाय या उसके संयोजन के साथ ऊर्जा मिनिमा के लिए अधिक सीधे खोज करते हैं। ऐसे तंत्र, जो सामान्य [[वैश्विक अनुकूलन]] विधियों के उदाहरण हैं, में [[ तैयार किए हुयी धातु पे पानी चढाने की कला |तैयार किए हुयी धातु पे पानी चढाने की कला]] और आनुवंशिक एल्गोरिदम शामिल हैं।


==फायदे==
==फायदे==
बल-निर्देशित एल्गोरिदम के सबसे महत्वपूर्ण लाभों में से निम्नलिखित हैं:
बल-निर्देशित एल्गोरिदम के सबसे महत्वपूर्ण लाभों में से निम्नलिखित हैं:
; अच्छी गुणवत्ता वाले परिणाम: कम से कम मध्यम आकार (50-500 शीर्षों तक) के ग्राफ़ के लिए, प्राप्त परिणाम आमतौर पर निम्नलिखित मानदंडों के आधार पर बहुत अच्छे परिणाम देते हैं: समान किनारे की लंबाई, समान शीर्ष वितरण और समरूपता दिखाना। यह अंतिम मानदंड सबसे महत्वपूर्ण मानदंडों में से एक है और किसी अन्य प्रकार के एल्गोरिदम के साथ इसे हासिल करना कठिन है।
; अच्छी गुणवत्ता वाले परिणाम: कम से कम मध्यम आकार (50-500 शीर्षों तक) के ग्राफ़ के लिए, प्राप्त परिणाम आमतौर पर निम्नलिखित मानदंडों के आधार पर बहुत अच्छे परिणाम देते हैं: समान किनारे की लंबाई, समान शीर्ष वितरण और समरूपता दिखाना। यह अंतिम मानदंड सबसे महत्वपूर्ण मानदंडों में से है और किसी अन्य प्रकार के एल्गोरिदम के साथ इसे हासिल करना कठिन है।
; लचीलापन: अतिरिक्त सौंदर्य मानदंडों को पूरा करने के लिए बल-निर्देशित एल्गोरिदम को आसानी से अनुकूलित और विस्तारित किया जा सकता है। यह उन्हें ग्राफ़ ड्राइंग एल्गोरिदम का सबसे बहुमुखी वर्ग बनाता है। मौजूदा एक्सटेंशन के उदाहरणों में निर्देशित ग्राफ़, 3डी ग्राफ़ ड्राइंग,<ref>{{cite web|last=Vose|first=Aaron|title=3D Phylogenetic Tree Viewer|url=http://aaronvose.net/phytree3d/|access-date=3 June 2012}}</ref> क्लस्टर ग्राफ़ ड्राइंग, विवश ग्राफ़ ड्राइंग, और गतिशील ग्राफ़ ड्राइंग।
; लचीलापन: अतिरिक्त सौंदर्य मानदंडों को पूरा करने के लिए बल-निर्देशित एल्गोरिदम को आसानी से अनुकूलित और विस्तारित किया जा सकता है। यह उन्हें ग्राफ़ ड्राइंग एल्गोरिदम का सबसे बहुमुखी वर्ग बनाता है। मौजूदा एक्सटेंशन के उदाहरणों में निर्देशित ग्राफ़, 3डी ग्राफ़ ड्राइंग,<ref>{{cite web|last=Vose|first=Aaron|title=3D Phylogenetic Tree Viewer|url=http://aaronvose.net/phytree3d/|access-date=3 June 2012}}</ref> क्लस्टर ग्राफ़ ड्राइंग, विवश ग्राफ़ ड्राइंग, और गतिशील ग्राफ़ ड्राइंग।
; सहज ज्ञान युक्त: चूंकि वे स्प्रिंग्स जैसी सामान्य वस्तुओं की भौतिक सादृश्यता पर आधारित हैं, इसलिए एल्गोरिदम के व्यवहार की भविष्यवाणी करना और समझना अपेक्षाकृत आसान है। अन्य प्रकार के ग्राफ़ ड्राइंग|ग्राफ़-ड्राइंग एल्गोरिदम के मामले में ऐसा नहीं है।
; सहज ज्ञान युक्त: चूंकि वे स्प्रिंग्स जैसी सामान्य वस्तुओं की भौतिक सादृश्यता पर आधारित हैं, इसलिए एल्गोरिदम के व्यवहार की भविष्यवाणी करना और समझना अपेक्षाकृत आसान है। अन्य प्रकार के ग्राफ़ ड्राइंग|ग्राफ़-ड्राइंग एल्गोरिदम के मामले में ऐसा नहीं है।
; सरलता: विशिष्ट बल-निर्देशित एल्गोरिदम सरल होते हैं और इन्हें कोड की कुछ पंक्तियों में लागू किया जा सकता है। ग्राफ़-ड्राइंग एल्गोरिदम के अन्य वर्ग, जैसे ऑर्थोगोनल लेआउट के लिए, आमतौर पर बहुत अधिक शामिल होते हैं।
; सरलता: विशिष्ट बल-निर्देशित एल्गोरिदम सरल होते हैं और इन्हें कोड की कुछ पंक्तियों में लागू किया जा सकता है। ग्राफ़-ड्राइंग एल्गोरिदम के अन्य वर्ग, जैसे ऑर्थोगोनल लेआउट के लिए, आमतौर पर बहुत अधिक शामिल होते हैं।
; अन्तरक्रियाशीलता: एल्गोरिदम के इस वर्ग का एक अन्य लाभ संवादात्मक पहलू है। ग्राफ़ के मध्यवर्ती चरणों को चित्रित करके, उपयोगकर्ता यह देख सकता है कि ग्राफ़ कैसे विकसित होता है, इसे एक उलझी हुई गड़बड़ी से एक अच्छे दिखने वाले कॉन्फ़िगरेशन में प्रकट होते हुए देख सकता है। कुछ इंटरैक्टिव ग्राफ़ ड्राइंग टूल में, उपयोगकर्ता एक या एक से अधिक नोड्स को उनकी संतुलन स्थिति से बाहर खींच सकता है और उन्हें वापस स्थिति में स्थानांतरित होते हुए देख सकता है। यह उन्हें गतिशील और [[ऑनलाइन एल्गोरिदम]] ग्राफ़-ड्राइंग सिस्टम के लिए पसंदीदा विकल्प बनाता है।
; अन्तरक्रियाशीलता: एल्गोरिदम के इस वर्ग का अन्य लाभ संवादात्मक पहलू है। ग्राफ़ के मध्यवर्ती चरणों को चित्रित करके, उपयोगकर्ता यह देख सकता है कि ग्राफ़ कैसे विकसित होता है, इसे उलझी हुई गड़बड़ी से अच्छे दिखने वाले कॉन्फ़िगरेशन में प्रकट होते हुए देख सकता है। कुछ इंटरैक्टिव ग्राफ़ ड्राइंग टूल में, उपयोगकर्ता या से अधिक नोड्स को उनकी संतुलन स्थिति से बाहर खींच सकता है और उन्हें वापस स्थिति में स्थानांतरित होते हुए देख सकता है। यह उन्हें गतिशील और [[ऑनलाइन एल्गोरिदम]] ग्राफ़-ड्राइंग सिस्टम के लिए पसंदीदा विकल्प बनाता है।
; मजबूत सैद्धांतिक आधार: जबकि सरल तदर्थ बल-निर्देशित एल्गोरिदम अक्सर साहित्य और व्यवहार में दिखाई देते हैं (क्योंकि उन्हें समझना अपेक्षाकृत आसान है), अधिक तर्कसंगत दृष्टिकोण लोकप्रियता हासिल करना शुरू कर रहे हैं। सांख्यिकीविद् 1930 के दशक से बहुआयामी स्केलिंग (एमडीएस) में समान समस्याओं को हल कर रहे हैं, और भौतिकविदों के पास संबंधित ए[[ एन शरीर ]] समस्याओं के साथ काम करने का एक लंबा इतिहास भी है - इसलिए बेहद परिपक्व दृष्टिकोण मौजूद हैं। उदाहरण के तौर पर, मीट्रिक एमडीएस के लिए तनाव प्रमुखीकरण दृष्टिकोण को ऊपर वर्णित अनुसार ग्राफ ड्राइंग पर लागू किया जा सकता है। यह [[मोनोटोन अभिसरण प्रमेय]] से सिद्ध हो चुका है।<ref name="dl88"/>मोनोटोनिक अभिसरण, वह गुण जो एल्गोरिदम प्रत्येक पुनरावृत्ति पर लेआउट के तनाव या लागत को कम करेगा, महत्वपूर्ण है क्योंकि यह गारंटी देता है कि लेआउट अंततः स्थानीय न्यूनतम तक पहुंच जाएगा और रुक जाएगा। डंपिंग शेड्यूल के कारण एल्गोरिदम रुक जाता है, लेकिन यह गारंटी नहीं दे सकता कि वास्तविक स्थानीय न्यूनतम तक पहुंच गया है।
; मजबूत सैद्धांतिक आधार: जबकि सरल तदर्थ बल-निर्देशित एल्गोरिदम अक्सर साहित्य और व्यवहार में दिखाई देते हैं (क्योंकि उन्हें समझना अपेक्षाकृत आसान है), अधिक तर्कसंगत दृष्टिकोण लोकप्रियता हासिल करना शुरू कर रहे हैं। सांख्यिकीविद् 1930 के दशक से बहुआयामी स्केलिंग (एमडीएस) में समान समस्याओं को हल कर रहे हैं, और भौतिकविदों के पास संबंधित ए[[ एन शरीर | एन शरीर]] समस्याओं के साथ काम करने का लंबा इतिहास भी है - इसलिए बेहद परिपक्व दृष्टिकोण मौजूद हैं। उदाहरण के तौर पर, मीट्रिक एमडीएस के लिए तनाव प्रमुखीकरण दृष्टिकोण को ऊपर वर्णित अनुसार ग्राफ ड्राइंग पर लागू किया जा सकता है। यह [[मोनोटोन अभिसरण प्रमेय]] से सिद्ध हो चुका है।<ref name="dl88"/>मोनोटोनिक अभिसरण, वह गुण जो एल्गोरिदम प्रत्येक पुनरावृत्ति पर लेआउट के तनाव या लागत को कम करेगा, महत्वपूर्ण है क्योंकि यह गारंटी देता है कि लेआउट अंततः स्थानीय न्यूनतम तक पहुंच जाएगा और रुक जाएगा। डंपिंग शेड्यूल के कारण एल्गोरिदम रुक जाता है, लेकिन यह गारंटी नहीं दे सकता कि वास्तविक स्थानीय न्यूनतम तक पहुंच गया है।


==नुकसान==
==नुकसान==
Line 56: Line 54:
  |pages        = 197&ndash;210
  |pages        = 197&ndash;210
  |isbn        = 3-540-41554-8
  |isbn        = 3-540-41554-8
  }}.</ref> चलने के समय को रैखिक अंकीय बनाने में सुधार कर सकते हैं, या <math>n\log(n)</math> प्रति पुनरावृत्ति. एक मोटे मार्गदर्शक के रूप में, कुछ ही सेकंड में एक मानक के साथ अधिकतम 1,000 नोड्स खींचने की उम्मीद की जा सकती है <math>n^2</math> प्रति पुनरावृत्ति तकनीक, और 100,000 के साथ <math>n\log(n)</math> प्रति पुनरावृत्ति तकनीक.<ref name="quigley+eades" />बल-निर्देशित एल्गोरिदम, जब ग्राफ़ क्लस्टरिंग दृष्टिकोण के साथ संयुक्त होते हैं, तो लाखों नोड्स के ग्राफ़ खींच सकते हैं।<ref>{{cite web|title=बड़े ग्राफ़ की एक गैलरी|url=http://yifanhu.net/GALLERY/GRAPHS/|access-date=22 Oct 2017}}</ref>
  }}.</ref> चलने के समय को रैखिक अंकीय बनाने में सुधार कर सकते हैं, या <math>n\log(n)</math> प्रति पुनरावृत्ति. मोटे मार्गदर्शक के रूप में, कुछ ही सेकंड में मानक के साथ अधिकतम 1,000 नोड्स खींचने की उम्मीद की जा सकती है <math>n^2</math> प्रति पुनरावृत्ति तकनीक, और 100,000 के साथ <math>n\log(n)</math> प्रति पुनरावृत्ति तकनीक.<ref name="quigley+eades" />बल-निर्देशित एल्गोरिदम, जब ग्राफ़ क्लस्टरिंग दृष्टिकोण के साथ संयुक्त होते हैं, तो लाखों नोड्स के ग्राफ़ खींच सकते हैं।<ref>{{cite web|title=बड़े ग्राफ़ की एक गैलरी|url=http://yifanhu.net/GALLERY/GRAPHS/|access-date=22 Oct 2017}}</ref>
; ख़राब [[स्थानीय न्यूनतम]]: यह देखना आसान है कि बल-निर्देशित एल्गोरिदम न्यूनतम ऊर्जा के साथ एक ग्राफ़ उत्पन्न करते हैं, विशेष रूप से जिसकी कुल ऊर्जा केवल स्थानीय न्यूनतम होती है। पाया गया स्थानीय न्यूनतम, कई मामलों में, वैश्विक न्यूनतम से काफी खराब हो सकता है, जो निम्न-गुणवत्ता वाली ड्राइंग में तब्दील हो जाता है। कई एल्गोरिदम के लिए, विशेष रूप से वे जो केवल शीर्ष से नीचे की ओर बढ़ने की अनुमति देते हैं, अंतिम परिणाम प्रारंभिक लेआउट से दृढ़ता से प्रभावित हो सकता है, जो कि ज्यादातर मामलों में यादृच्छिक रूप से उत्पन्न होता है। जैसे-जैसे ग्राफ़ के शीर्षों की संख्या बढ़ती है, ख़राब स्थानीय न्यूनतम की समस्या और अधिक महत्वपूर्ण हो जाती है। विभिन्न एल्गोरिदम का संयुक्त अनुप्रयोग इस समस्या को हल करने में सहायक है।<ref>{{citation
; ख़राब [[स्थानीय न्यूनतम]]: यह देखना आसान है कि बल-निर्देशित एल्गोरिदम न्यूनतम ऊर्जा के साथ ग्राफ़ उत्पन्न करते हैं, विशेष रूप से जिसकी कुल ऊर्जा केवल स्थानीय न्यूनतम होती है। पाया गया स्थानीय न्यूनतम, कई मामलों में, वैश्विक न्यूनतम से काफी खराब हो सकता है, जो निम्न-गुणवत्ता वाली ड्राइंग में तब्दील हो जाता है। कई एल्गोरिदम के लिए, विशेष रूप से वे जो केवल शीर्ष से नीचे की ओर बढ़ने की अनुमति देते हैं, अंतिम परिणाम प्रारंभिक लेआउट से दृढ़ता से प्रभावित हो सकता है, जो कि ज्यादातर मामलों में यादृच्छिक रूप से उत्पन्न होता है। जैसे-जैसे ग्राफ़ के शीर्षों की संख्या बढ़ती है, ख़राब स्थानीय न्यूनतम की समस्या और अधिक महत्वपूर्ण हो जाती है। विभिन्न एल्गोरिदम का संयुक्त अनुप्रयोग इस समस्या को हल करने में सहायक है।<ref>{{citation
  | last1 = Collberg | first1 = Christian
  | last1 = Collberg | first1 = Christian
  | last2 = Kobourov | first2 = Stephen
  | last2 = Kobourov | first2 = Stephen
Line 72: Line 70:
  | url = https://www.researchgate.net/publication/2851716
  | url = https://www.researchgate.net/publication/2851716
  | year = 2003| s2cid = 824991
  | year = 2003| s2cid = 824991
  |quote=To achieve an aesthetically pleasing layout of the graph it is also necessary to employ modified Fruchterman–Reingold forces, as the Kamada–Kawai method does not achieve satisfactory methods by itself but rather creates a good approximate layout so that the Fruchterman-Reingold calculations can quickly "tidy up" the layout.}}</ref> उदाहरण के लिए, कामदा-कवाई एल्गोरिदम का उपयोग करना<ref name="kk89"/>शीघ्रता से एक उचित प्रारंभिक लेआउट और फिर फ्रूचटरमैन-रींगोल्ड एल्गोरिथम उत्पन्न करने के लिए<ref name="fr91"/>पड़ोसी नोड्स की स्थिति में सुधार करने के लिए। वैश्विक न्यूनतम हासिल करने की एक अन्य तकनीक बहुस्तरीय दृष्टिकोण का उपयोग करना है।<ref>http://jgaa.info/accepted/2003/Walshaw2003.7.3.pdf A Multilevel Algorithm for Force-Directed
  |quote=To achieve an aesthetically pleasing layout of the graph it is also necessary to employ modified Fruchterman–Reingold forces, as the Kamada–Kawai method does not achieve satisfactory methods by itself but rather creates a good approximate layout so that the Fruchterman-Reingold calculations can quickly "tidy up" the layout.}}</ref> उदाहरण के लिए, कामदा-कवाई एल्गोरिदम का उपयोग करना<ref name="kk89"/>शीघ्रता से उचित प्रारंभिक लेआउट और फिर फ्रूचटरमैन-रींगोल्ड एल्गोरिथम उत्पन्न करने के लिए<ref name="fr91"/>पड़ोसी नोड्स की स्थिति में सुधार करने के लिए। वैश्विक न्यूनतम हासिल करने की अन्य तकनीक बहुस्तरीय दृष्टिकोण का उपयोग करना है।<ref>http://jgaa.info/accepted/2003/Walshaw2003.7.3.pdf A Multilevel Algorithm for Force-Directed
Graph-Drawing</ref>
Graph-Drawing</ref>
==इतिहास==
==इतिहास==
ग्राफ़ ड्राइंग में बल-निर्देशित विधियाँ किसके काम की हैं {{harvtxt|Tutte|1963}}, जिन्होंने दिखाया कि [[बहुफलकीय ग्राफ]] समतल में सभी फलकों के उत्तल होने के साथ खींचा जा सकता है, इसके लिए ग्राफ के एक समतलीय फलक के बाहरी फलक के शीर्षों को [[उत्तल स्थिति]] में स्थापित करके, प्रत्येक किनारे पर एक स्प्रिंग जैसा आकर्षक बल लगाकर, और सिस्टम एक संतुलन में स्थापित हो जाता है।<ref>{{citation|first=W. T.|last=Tutte|author-link=W. T. Tutte|title=How to draw a graph|journal=Proceedings of the London Mathematical Society|volume=13|issue=52|pages=743–768|year=1963|doi=10.1112/plms/s3-13.1.743}}.</ref> इस मामले में बलों की सरल प्रकृति के कारण, सिस्टम स्थानीय मिनिमा में फंस नहीं सकता है, बल्कि एक अद्वितीय वैश्विक इष्टतम कॉन्फ़िगरेशन में परिवर्तित हो जाता है। इस कार्य के कारण, उत्तल फलकों वाले समतलीय ग्राफ़ों की एम्बेडिंग को कभी-कभी [[टुटे एम्बेडिंग]] कहा जाता है।
ग्राफ़ ड्राइंग में बल-निर्देशित विधियाँ किसके काम की हैं {{harvtxt|Tutte|1963}}, जिन्होंने दिखाया कि [[बहुफलकीय ग्राफ]] समतल में सभी फलकों के उत्तल होने के साथ खींचा जा सकता है, इसके लिए ग्राफ के समतलीय फलक के बाहरी फलक के शीर्षों को [[उत्तल स्थिति]] में स्थापित करके, प्रत्येक किनारे पर स्प्रिंग जैसा आकर्षक बल लगाकर, और सिस्टम संतुलन में स्थापित हो जाता है।<ref>{{citation|first=W. T.|last=Tutte|author-link=W. T. Tutte|title=How to draw a graph|journal=Proceedings of the London Mathematical Society|volume=13|issue=52|pages=743–768|year=1963|doi=10.1112/plms/s3-13.1.743}}.</ref> इस मामले में बलों की सरल प्रकृति के कारण, सिस्टम स्थानीय मिनिमा में फंस नहीं सकता है, बल्कि अद्वितीय वैश्विक इष्टतम कॉन्फ़िगरेशन में परिवर्तित हो जाता है। इस कार्य के कारण, उत्तल फलकों वाले समतलीय ग्राफ़ों की एम्बेडिंग को कभी-कभी [[टुटे एम्बेडिंग]] कहा जाता है।


आसन्न शीर्षों पर आकर्षक बलों और सभी शीर्षों पर प्रतिकारक बलों के संयोजन का प्रयोग सबसे पहले किसके द्वारा किया गया था? {{harvtxt|Eades|1984}};<ref>{{citation
आसन्न शीर्षों पर आकर्षक बलों और सभी शीर्षों पर प्रतिकारक बलों के संयोजन का प्रयोग सबसे पहले किसके द्वारा किया गया था? {{harvtxt|Eades|1984}};<ref>{{citation
Line 102: Line 98:
   | volume=31 | issue=1 | pages=7&ndash;15
   | volume=31 | issue=1 | pages=7&ndash;15
   | doi=10.1016/0020-0190(89)90102-6}}.</ref>
   | doi=10.1016/0020-0190(89)90102-6}}.</ref>
==यह भी देखें==
==यह भी देखें==
*[[साइटोस्केप]], जैविक नेटवर्क को देखने के लिए सॉफ्टवेयर। बेस पैकेज में अंतर्निहित तरीकों में से एक के रूप में बल-निर्देशित लेआउट शामिल हैं।
*[[साइटोस्केप]], जैविक नेटवर्क को देखने के लिए सॉफ्टवेयर। बेस पैकेज में अंतर्निहित तरीकों में से के रूप में बल-निर्देशित लेआउट शामिल हैं।
*[[ कहाँ? ]], सभी प्रकार के नेटवर्क और जटिल प्रणालियों, गतिशील और श्रेणीबद्ध ग्राफ़ के लिए एक इंटरैक्टिव विज़ुअलाइज़ेशन और अन्वेषण मंच।
*[[ कहाँ? ]], सभी प्रकार के नेटवर्क और जटिल प्रणालियों, गतिशील और श्रेणीबद्ध ग्राफ़ के लिए इंटरैक्टिव विज़ुअलाइज़ेशन और अन्वेषण मंच।
*[[ग्रप्ह्वइज़]], सॉफ़्टवेयर जो एक बहुस्तरीय बल-निर्देशित लेआउट एल्गोरिदम लागू करता है (कई अन्य के बीच) जो बहुत बड़े ग्राफ़ को संभालने में सक्षम है।
*[[ग्रप्ह्वइज़]], सॉफ़्टवेयर जो बहुस्तरीय बल-निर्देशित लेआउट एल्गोरिदम लागू करता है (कई अन्य के बीच) जो बहुत बड़े ग्राफ़ को संभालने में सक्षम है।
*[[ट्यूलिप (सॉफ्टवेयर)]], सॉफ्टवेयर जो अधिकांश बल-निर्देशित लेआउट एल्गोरिदम (जीईएम, एलजीएल, जीआरआईपी, एफएम³) को लागू करता है।
*[[ट्यूलिप (सॉफ्टवेयर)]], सॉफ्टवेयर जो अधिकांश बल-निर्देशित लेआउट एल्गोरिदम (जीईएम, एलजीएल, जीआरआईपी, एफएम³) को लागू करता है।
*प्रस्तावना
*प्रस्तावना
Line 136: Line 130:
   | isbn=978-3-540-42062-0| s2cid=1808286
   | isbn=978-3-540-42062-0| s2cid=1808286
  }}
  }}
==बाहरी संबंध==
==बाहरी संबंध==
*[https://cs.brown.edu/people/rtamassi/gdhandbook/chapters/force-directed.pdf Book chapter on Force-Directed Drawing Algorithms] by Stephen G. Kobourov
*[https://cs.brown.edu/people/rtamassi/gdhandbook/chapters/force-directed.pdf Book chapter on Force-Directed Drawing Algorithms] by Stephen G. Kobourov

Revision as of 17:41, 6 July 2023

बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम का उपयोग करके सामाजिक नेटवर्क विज़ुअलाइज़ेशन[1]
बल-निर्देशित लेआउट का उपयोग करके विकी पर पृष्ठों के बीच लिंक का विज़ुअलाइज़ेशन

बल-निर्देशित ग्राफ ड्राइंग कलन विधि सौंदर्य-सुखदायक तरीके से ग्राफ़ ड्राइंग के लिए एल्गोरिदम का वर्ग है। उनका उद्देश्य ग्राफ़ (अलग-अलग गणित) के नोड्स को दो-आयामी या त्रि-आयामी अंतरिक्ष में स्थित करना है ताकि सभी किनारे कम या ज्यादा समान लंबाई के हों और जितना संभव हो उतना कम क्रॉसिंग किनारे हों, बीच में बल निर्दिष्ट करके किनारों का सेट और नोड्स का सेट, उनकी सापेक्ष स्थिति के आधार पर, और फिर इन बलों का उपयोग या तो किनारों और नोड्स की गति को अनुकरण करने या उनकी ऊर्जा को कम करने के लिए किया जाता है।[2]

जबकि ग्राफ़ बनाना कठिन समस्या हो सकती है, बल-निर्देशित एल्गोरिदम, भौतिक सिमुलेशन होने के कारण, आमतौर पर ग्राफ़ सिद्धांत जैसे कि समतलीय ग्राफ के बारे में किसी विशेष ज्ञान की आवश्यकता नहीं होती है।

बल

बल-निर्देशित ग्राफ़ ड्राइंग एल्गोरिदम किनारों के सेट और ग्राफ़ ड्राइंग के नोड्स के सेट के बीच बल निर्दिष्ट करते हैं। आमतौर पर, हुक के नियम पर आधारित वसंत (उपकरण)उपकरण) जैसे आकर्षक बलों का उपयोग ग्राफ के किनारों के अंतिम बिंदुओं के जोड़े को एक-दूसरे की ओर आकर्षित करने के लिए किया जाता है, जबकि साथ ही कूलम्ब के नियम के आधार पर विद्युत आवेश कणों जैसे प्रतिकारक बलों का उपयोग सभी जोड़े को अलग करने के लिए किया जाता है। नोड्स. बलों की इस प्रणाली के लिए यांत्रिक संतुलन में, किनारों की लंबाई समान होती है (स्प्रिंग बलों के कारण), और जो नोड्स किनारे से नहीं जुड़े होते हैं वे और अधिक दूर खींचे जाते हैं (विद्युत प्रतिकर्षण के कारण)। किनारे के आकर्षण और शीर्ष प्रतिकर्षण बलों को उन कार्यों का उपयोग करके परिभाषित किया जा सकता है जो स्प्रिंग्स और कणों के भौतिक व्यवहार पर आधारित नहीं हैं; उदाहरण के लिए, कुछ बल-निर्देशित प्रणालियाँ स्प्रिंग्स का उपयोग करती हैं जिनका आकर्षक बल रैखिक के बजाय लघुगणकीय होता है।

एक वैकल्पिक मॉडल प्रत्येक जोड़ी नोड्स के लिए स्प्रिंग-जैसे बल पर विचार करता है जहां आदर्श लंबाई है प्रत्येक स्प्रिंग का मान अलग प्रतिकारक बल का उपयोग किए बिना, नोड्स i और j के बीच ग्राफ-सैद्धांतिक दूरी के समानुपाती होता है। यूक्लिडियन दूरी और नोड्स के बीच आदर्श दूरी के बीच अंतर (आमतौर पर वर्ग अंतर) को कम करना मीट्रिक बहुआयामी स्केलिंग समस्या के बराबर है।

एक बल-निर्देशित ग्राफ़ में यांत्रिक स्प्रिंग्स और विद्युत प्रतिकर्षण के अलावा अन्य बल शामिल हो सकते हैं। गुरुत्वाकर्षण के अनुरूप बल का उपयोग शीर्षों को ड्राइंग स्थान के निश्चित बिंदु की ओर खींचने के लिए किया जा सकता है; इसका उपयोग डिस्कनेक्ट किए गए ग्राफ़ के विभिन्न कनेक्टेड घटकों (ग्राफ़ सिद्धांत) को साथ खींचने के लिए किया जा सकता है, जो अन्यथा प्रतिकारक बलों के कारण एक-दूसरे से अलग हो जाते हैं, और ड्राइंग में अधिक केंद्रीय पदों पर अधिक केंद्रीयता वाले नोड्स खींचने के लिए उपयोग किया जा सकता है। ;[3] यह घटक के भीतर शीर्ष रिक्ति को भी प्रभावित कर सकता है। निर्देशित ग्राफ़ के लिए चुंबकीय क्षेत्र के एनालॉग्स का उपयोग किया जा सकता है। अंतिम ड्राइंग में ओवरलैप या निकट-ओवरलैप से बचने के लिए किनारों के साथ-साथ नोड्स पर भी प्रतिकारक बल लगाए जा सकते हैं। घुमावदार किनारों वाले रेखाचित्रों जैसे कि वृत्ताकार चाप या तख़्ता वक्र में, इन वक्रों के नियंत्रण बिंदुओं पर बल भी लगाए जा सकते हैं, उदाहरण के लिए उनके कोणीय रिज़ॉल्यूशन (ग्राफ़ ड्राइंग) में सुधार करने के लिए।[4]

तरीके

एक बार ग्राफ़ के नोड्स और किनारों पर बलों को परिभाषित किया गया है, तो इन स्रोतों के तहत पूरे ग्राफ़ का व्यवहार तब अनुकरण किया जा सकता है जैसे कि यह भौतिक प्रणाली थी। इस तरह के अनुकरण में, बलों को नोड्स पर लागू किया जाता है, उन्हें साथ करीब खींचा जाता है या उन्हें और दूर धकेल दिया जाता है। इसे तब तक दोहराया जाता है जब तक कि सिस्टम यांत्रिक संतुलन स्थिति में नहीं आ जाता; यानी, उनकी सापेक्ष स्थिति पुनरावृत्ति से दूसरी पुनरावृत्ति में नहीं बदलती है। इस संतुलन में नोड्स की स्थिति का उपयोग ग्राफ का चित्र बनाने के लिए किया जाता है।

स्प्रिंग्स से परिभाषित बलों के लिए जिनकी आदर्श लंबाई ग्राफ-सैद्धांतिक दूरी के समानुपाती होती है, तनाव प्रमुखता बहुत अच्छी तरह से व्यवहार करती है (यानी, अनुक्रम की नीरस सीमा)[5] और इन अंतरों को अनुकूलित करने के लिए गणितीय रूप से सुंदर तरीका (गणित) और, इसलिए, ग्राफ़ के लिए अच्छा लेआउट ढूंढें।

ऐसे तंत्रों को नियोजित करना भी संभव है जो भौतिक सिमुलेशन के बजाय या उसके संयोजन के साथ ऊर्जा मिनिमा के लिए अधिक सीधे खोज करते हैं। ऐसे तंत्र, जो सामान्य वैश्विक अनुकूलन विधियों के उदाहरण हैं, में तैयार किए हुयी धातु पे पानी चढाने की कला और आनुवंशिक एल्गोरिदम शामिल हैं।

फायदे

बल-निर्देशित एल्गोरिदम के सबसे महत्वपूर्ण लाभों में से निम्नलिखित हैं:

अच्छी गुणवत्ता वाले परिणाम
कम से कम मध्यम आकार (50-500 शीर्षों तक) के ग्राफ़ के लिए, प्राप्त परिणाम आमतौर पर निम्नलिखित मानदंडों के आधार पर बहुत अच्छे परिणाम देते हैं: समान किनारे की लंबाई, समान शीर्ष वितरण और समरूपता दिखाना। यह अंतिम मानदंड सबसे महत्वपूर्ण मानदंडों में से है और किसी अन्य प्रकार के एल्गोरिदम के साथ इसे हासिल करना कठिन है।
लचीलापन
अतिरिक्त सौंदर्य मानदंडों को पूरा करने के लिए बल-निर्देशित एल्गोरिदम को आसानी से अनुकूलित और विस्तारित किया जा सकता है। यह उन्हें ग्राफ़ ड्राइंग एल्गोरिदम का सबसे बहुमुखी वर्ग बनाता है। मौजूदा एक्सटेंशन के उदाहरणों में निर्देशित ग्राफ़, 3डी ग्राफ़ ड्राइंग,[6] क्लस्टर ग्राफ़ ड्राइंग, विवश ग्राफ़ ड्राइंग, और गतिशील ग्राफ़ ड्राइंग।
सहज ज्ञान युक्त
चूंकि वे स्प्रिंग्स जैसी सामान्य वस्तुओं की भौतिक सादृश्यता पर आधारित हैं, इसलिए एल्गोरिदम के व्यवहार की भविष्यवाणी करना और समझना अपेक्षाकृत आसान है। अन्य प्रकार के ग्राफ़ ड्राइंग|ग्राफ़-ड्राइंग एल्गोरिदम के मामले में ऐसा नहीं है।
सरलता
विशिष्ट बल-निर्देशित एल्गोरिदम सरल होते हैं और इन्हें कोड की कुछ पंक्तियों में लागू किया जा सकता है। ग्राफ़-ड्राइंग एल्गोरिदम के अन्य वर्ग, जैसे ऑर्थोगोनल लेआउट के लिए, आमतौर पर बहुत अधिक शामिल होते हैं।
अन्तरक्रियाशीलता
एल्गोरिदम के इस वर्ग का अन्य लाभ संवादात्मक पहलू है। ग्राफ़ के मध्यवर्ती चरणों को चित्रित करके, उपयोगकर्ता यह देख सकता है कि ग्राफ़ कैसे विकसित होता है, इसे उलझी हुई गड़बड़ी से अच्छे दिखने वाले कॉन्फ़िगरेशन में प्रकट होते हुए देख सकता है। कुछ इंटरैक्टिव ग्राफ़ ड्राइंग टूल में, उपयोगकर्ता या से अधिक नोड्स को उनकी संतुलन स्थिति से बाहर खींच सकता है और उन्हें वापस स्थिति में स्थानांतरित होते हुए देख सकता है। यह उन्हें गतिशील और ऑनलाइन एल्गोरिदम ग्राफ़-ड्राइंग सिस्टम के लिए पसंदीदा विकल्प बनाता है।
मजबूत सैद्धांतिक आधार
जबकि सरल तदर्थ बल-निर्देशित एल्गोरिदम अक्सर साहित्य और व्यवहार में दिखाई देते हैं (क्योंकि उन्हें समझना अपेक्षाकृत आसान है), अधिक तर्कसंगत दृष्टिकोण लोकप्रियता हासिल करना शुरू कर रहे हैं। सांख्यिकीविद् 1930 के दशक से बहुआयामी स्केलिंग (एमडीएस) में समान समस्याओं को हल कर रहे हैं, और भौतिकविदों के पास संबंधित ए एन शरीर समस्याओं के साथ काम करने का लंबा इतिहास भी है - इसलिए बेहद परिपक्व दृष्टिकोण मौजूद हैं। उदाहरण के तौर पर, मीट्रिक एमडीएस के लिए तनाव प्रमुखीकरण दृष्टिकोण को ऊपर वर्णित अनुसार ग्राफ ड्राइंग पर लागू किया जा सकता है। यह मोनोटोन अभिसरण प्रमेय से सिद्ध हो चुका है।[5]मोनोटोनिक अभिसरण, वह गुण जो एल्गोरिदम प्रत्येक पुनरावृत्ति पर लेआउट के तनाव या लागत को कम करेगा, महत्वपूर्ण है क्योंकि यह गारंटी देता है कि लेआउट अंततः स्थानीय न्यूनतम तक पहुंच जाएगा और रुक जाएगा। डंपिंग शेड्यूल के कारण एल्गोरिदम रुक जाता है, लेकिन यह गारंटी नहीं दे सकता कि वास्तविक स्थानीय न्यूनतम तक पहुंच गया है।

नुकसान

बल-निर्देशित एल्गोरिदम के मुख्य नुकसानों में निम्नलिखित शामिल हैं:

उच्च समय जटिलता
विशिष्ट बल-निर्देशित एल्गोरिदम को आम तौर पर घन समय में चलने वाला माना जाता है (), कहाँ इनपुट ग्राफ़ के नोड्स की संख्या है। ऐसा इसलिए है क्योंकि पुनरावृत्तियों की संख्या रैखिक होने का अनुमान है (), और प्रत्येक पुनरावृत्ति में, नोड्स के सभी जोड़े का दौरा करने और उनकी पारस्परिक प्रतिकारक शक्तियों की गणना करने की आवश्यकता होती है। यह भौतिकी में एन-बॉडी समस्या से संबंधित है। हालाँकि, चूँकि प्रतिकारक शक्तियाँ स्थानीय प्रकृति की होती हैं, इसलिए ग्राफ को इस तरह विभाजित किया जा सकता है कि केवल पड़ोसी शीर्षों पर ही विचार किया जाए। बड़े ग्राफ़ के लेआउट को निर्धारित करने के लिए एल्गोरिदम द्वारा उपयोग की जाने वाली सामान्य तकनीकों में उच्च-आयामी एम्बेडिंग शामिल है,[7] मल्टी-लेयर ड्राइंग और एन-बॉडी सिमुलेशन से संबंधित अन्य विधियां। उदाहरण के लिए, बार्न्स-हट सिमुलेशन-आधारित विधि FADE[8] चलने के समय को रैखिक अंकीय बनाने में सुधार कर सकते हैं, या प्रति पुनरावृत्ति. मोटे मार्गदर्शक के रूप में, कुछ ही सेकंड में मानक के साथ अधिकतम 1,000 नोड्स खींचने की उम्मीद की जा सकती है प्रति पुनरावृत्ति तकनीक, और 100,000 के साथ प्रति पुनरावृत्ति तकनीक.[8]बल-निर्देशित एल्गोरिदम, जब ग्राफ़ क्लस्टरिंग दृष्टिकोण के साथ संयुक्त होते हैं, तो लाखों नोड्स के ग्राफ़ खींच सकते हैं।[9]
ख़राब स्थानीय न्यूनतम
यह देखना आसान है कि बल-निर्देशित एल्गोरिदम न्यूनतम ऊर्जा के साथ ग्राफ़ उत्पन्न करते हैं, विशेष रूप से जिसकी कुल ऊर्जा केवल स्थानीय न्यूनतम होती है। पाया गया स्थानीय न्यूनतम, कई मामलों में, वैश्विक न्यूनतम से काफी खराब हो सकता है, जो निम्न-गुणवत्ता वाली ड्राइंग में तब्दील हो जाता है। कई एल्गोरिदम के लिए, विशेष रूप से वे जो केवल शीर्ष से नीचे की ओर बढ़ने की अनुमति देते हैं, अंतिम परिणाम प्रारंभिक लेआउट से दृढ़ता से प्रभावित हो सकता है, जो कि ज्यादातर मामलों में यादृच्छिक रूप से उत्पन्न होता है। जैसे-जैसे ग्राफ़ के शीर्षों की संख्या बढ़ती है, ख़राब स्थानीय न्यूनतम की समस्या और अधिक महत्वपूर्ण हो जाती है। विभिन्न एल्गोरिदम का संयुक्त अनुप्रयोग इस समस्या को हल करने में सहायक है।[10] उदाहरण के लिए, कामदा-कवाई एल्गोरिदम का उपयोग करना[11]शीघ्रता से उचित प्रारंभिक लेआउट और फिर फ्रूचटरमैन-रींगोल्ड एल्गोरिथम उत्पन्न करने के लिए[12]पड़ोसी नोड्स की स्थिति में सुधार करने के लिए। वैश्विक न्यूनतम हासिल करने की अन्य तकनीक बहुस्तरीय दृष्टिकोण का उपयोग करना है।[13]

इतिहास

ग्राफ़ ड्राइंग में बल-निर्देशित विधियाँ किसके काम की हैं Tutte (1963), जिन्होंने दिखाया कि बहुफलकीय ग्राफ समतल में सभी फलकों के उत्तल होने के साथ खींचा जा सकता है, इसके लिए ग्राफ के समतलीय फलक के बाहरी फलक के शीर्षों को उत्तल स्थिति में स्थापित करके, प्रत्येक किनारे पर स्प्रिंग जैसा आकर्षक बल लगाकर, और सिस्टम संतुलन में स्थापित हो जाता है।[14] इस मामले में बलों की सरल प्रकृति के कारण, सिस्टम स्थानीय मिनिमा में फंस नहीं सकता है, बल्कि अद्वितीय वैश्विक इष्टतम कॉन्फ़िगरेशन में परिवर्तित हो जाता है। इस कार्य के कारण, उत्तल फलकों वाले समतलीय ग्राफ़ों की एम्बेडिंग को कभी-कभी टुटे एम्बेडिंग कहा जाता है।

आसन्न शीर्षों पर आकर्षक बलों और सभी शीर्षों पर प्रतिकारक बलों के संयोजन का प्रयोग सबसे पहले किसके द्वारा किया गया था? Eades (1984);[15] इस प्रकार के बल-निर्देशित लेआउट पर अतिरिक्त अग्रणी कार्य किसके द्वारा किया गया था? Fruchterman & Reingold (1991).[12] शीर्षों के सभी युग्मों के बीच केवल स्प्रिंग बलों का उपयोग करने का विचार, शीर्षों की ग्राफ-सैद्धांतिक दूरी के बराबर आदर्श स्प्रिंग लंबाई के साथ, से है Kamada & Kawai (1989).[11]

यह भी देखें

  • साइटोस्केप, जैविक नेटवर्क को देखने के लिए सॉफ्टवेयर। बेस पैकेज में अंतर्निहित तरीकों में से के रूप में बल-निर्देशित लेआउट शामिल हैं।
  • कहाँ? , सभी प्रकार के नेटवर्क और जटिल प्रणालियों, गतिशील और श्रेणीबद्ध ग्राफ़ के लिए इंटरैक्टिव विज़ुअलाइज़ेशन और अन्वेषण मंच।
  • ग्रप्ह्वइज़, सॉफ़्टवेयर जो बहुस्तरीय बल-निर्देशित लेआउट एल्गोरिदम लागू करता है (कई अन्य के बीच) जो बहुत बड़े ग्राफ़ को संभालने में सक्षम है।
  • ट्यूलिप (सॉफ्टवेयर), सॉफ्टवेयर जो अधिकांश बल-निर्देशित लेआउट एल्गोरिदम (जीईएम, एलजीएल, जीआरआईपी, एफएम³) को लागू करता है।
  • प्रस्तावना

संदर्भ

  1. Grandjean, Martin (2015), "Introduction à la visualisation de données, l'analyse de réseau en histoire", Geschichte und Informatik 18/19 (PDF), pp. 109–128
  2. Kobourov, Stephen G. (2012), Spring Embedders and Force-Directed Graph Drawing Algorithms, arXiv:1201.3011, Bibcode:2012arXiv1201.3011K.
  3. Bannister, M. J.; Eppstein, D.; Goodrich, M. T.; Trott, L. (2012), "Force-directed graph drawing using social gravity and scaling", Proc. 20th Int. Symp. Graph Drawing, arXiv:1209.0748, Bibcode:2012arXiv1209.0748B.
  4. Chernobelskiy, R.; Cunningham, K.; Goodrich, M. T.; Kobourov, S. G.; Trott, L. (2011), "Force-directed Lombardi-style graph drawing", Proc. 19th Symposium on Graph Drawing (PDF), pp. 78–90.
  5. 5.0 5.1 de Leeuw, Jan (1988), "Convergence of the majorization method for multidimensional scaling", Journal of Classification, Springer, 5 (2): 163–180, doi:10.1007/BF01897162, S2CID 122413124.
  6. Vose, Aaron. "3D Phylogenetic Tree Viewer". Retrieved 3 June 2012.
  7. Harel, David; Koren, Yehuda (2002), "Graph drawing by high-dimensional embedding", Proceedings of the 9th International Symposium on Graph Drawing, pp. 207–219, CiteSeerX 10.1.1.20.5390, ISBN 3-540-00158-1
  8. 8.0 8.1 Quigley, Aaron; Eades, Peter (2001), "FADE: Graph Drawing, Clustering, and Visual Abstraction", Proceedings of the 8th International Symposium on Graph Drawing (PDF), pp. 197–210, ISBN 3-540-41554-8.
  9. "बड़े ग्राफ़ की एक गैलरी". Retrieved 22 Oct 2017.
  10. Collberg, Christian; Kobourov, Stephen; Nagra, Jasvir; Pitts, Jacob; Wampler, Kevin (2003), "A System for Graph-based Visualization of the Evolution of Software", Proceedings of the 2003 ACM Symposium on Software Visualization (SoftVis '03), New York, NY, USA: ACM, pp. 77–86, figures on p. 212, doi:10.1145/774833.774844, ISBN 1-58113-642-0, S2CID 824991, To achieve an aesthetically pleasing layout of the graph it is also necessary to employ modified Fruchterman–Reingold forces, as the Kamada–Kawai method does not achieve satisfactory methods by itself but rather creates a good approximate layout so that the Fruchterman-Reingold calculations can quickly "tidy up" the layout.
  11. 11.0 11.1 Kamada, Tomihisa; Kawai, Satoru (1989), "An algorithm for drawing general undirected graphs", Information Processing Letters, Elsevier, 31 (1): 7–15, doi:10.1016/0020-0190(89)90102-6.
  12. 12.0 12.1 Fruchterman, Thomas M. J.; Reingold, Edward M. (1991), "Graph Drawing by Force-Directed Placement", Software: Practice and Experience, Wiley, 21 (11): 1129–1164, doi:10.1002/spe.4380211102, S2CID 31468174.
  13. http://jgaa.info/accepted/2003/Walshaw2003.7.3.pdf A Multilevel Algorithm for Force-Directed Graph-Drawing
  14. Tutte, W. T. (1963), "How to draw a graph", Proceedings of the London Mathematical Society, 13 (52): 743–768, doi:10.1112/plms/s3-13.1.743.
  15. Eades, Peter (1984), "A Heuristic for Graph Drawing", Congressus Numerantium, 42 (11): 149–160.


अग्रिम पठन

बाहरी संबंध