अधिकतम प्रवाह की समस्या: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Computational problem in graph theory}} {{Use dmy dates|date=May 2022}} File:Pets flow.svg|alt=Flow network for the problem: प्रत्येक म...")
 
No edit summary
 
(12 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Short description|Computational problem in graph theory}}
{{Short description|Computational problem in graph theory}}
{{Use dmy dates|date=May 2022}}
[[File:Pets flow.svg|alt=Flow network for the problem: प्रत्येक मानव (री) एक बिल्ली (wi1) और/या एक कुत्ता (wi2) अपनाने को तैयार है। हालाँकि प्रत्येक पालतू जानवर (पाई) की मनुष्यों के केवल एक उपसमूह के लिए प्राथमिकता है। मनुष्यों के लिए पालतू जानवरों के किसी भी मिलान का पता लगाएं, ताकि पालतू जानवरों की अधिकतम संख्या उसके पसंदीदा मनुष्यों में से किसी एक द्वारा अपनाई जाए। थंब|252x252px|समस्या के लिए प्रवाह नेटवर्क: प्रत्येक मानव (ri) एक बिल्ली (wi1) और / को अपनाने के लिए तैयार है या एक कुत्ता (wi2)। हालाँकि प्रत्येक पालतू जानवर (पाई) की मनुष्यों के केवल एक उपसमूह के लिए प्राथमिकता है। मनुष्यों के लिए पालतू जानवरों के किसी भी मिलान का पता लगाएं, ताकि अधिकतम संख्या में पालतू जानवरों को उसके पसंदीदा मनुष्यों में से एक द्वारा अपनाया जा सके।]]
[[File:Pets flow.svg|alt=Flow network for the problem: प्रत्येक मानव (री) एक बिल्ली (wi1) और/या एक कुत्ता (wi2) अपनाने को तैयार है। हालाँकि प्रत्येक पालतू जानवर (पाई) की मनुष्यों के केवल एक उपसमूह के लिए प्राथमिकता है। मनुष्यों के लिए पालतू जानवरों के किसी भी मिलान का पता लगाएं, ताकि पालतू जानवरों की अधिकतम संख्या उसके पसंदीदा मनुष्यों में से किसी एक द्वारा अपनाई जाए। थंब|252x252px|समस्या के लिए प्रवाह नेटवर्क: प्रत्येक मानव (ri) एक बिल्ली (wi1) और / को अपनाने के लिए तैयार है या एक कुत्ता (wi2)। हालाँकि प्रत्येक पालतू जानवर (पाई) की मनुष्यों के केवल एक उपसमूह के लिए प्राथमिकता है। मनुष्यों के लिए पालतू जानवरों के किसी भी मिलान का पता लगाएं, ताकि अधिकतम संख्या में पालतू जानवरों को उसके पसंदीदा मनुष्यों में से एक द्वारा अपनाया जा सके।]][[अनुकूलन (गणित)]] में, अधिकतम प्रवाह समस्याओं में एक [[प्रवाह नेटवर्क]] के माध्यम से एक व्यवहार्य प्रवाह खोजना शामिल होता है जो अधिकतम संभव प्रवाह दर प्राप्त करता है।


अधिकतम प्रवाह समस्या को संचलन समस्या जैसे अधिक जटिल नेटवर्क प्रवाह समस्याओं के विशेष मामले के रूप में देखा जा सकता है। एक एसटी प्रवाह का अधिकतम मूल्य (अर्थात, ग्राफ सिद्धांत की शब्दावली से प्रवाह#दिशा s से ग्राफ़ सिद्धांत की शब्दावली#दिशा t) एक [[कट (ग्राफ सिद्धांत)]] की न्यूनतम क्षमता के बराबर है|एसटी कट (यानी, विच्छेदित एस टी से) नेटवर्क में, जैसा कि [[मैक्स-फ्लो मिन-कट प्रमेय]] में कहा गया है।
[[अनुकूलन (गणित)]] में, अधिकतम प्रवाह समस्याओं में [[प्रवाह नेटवर्क]] के माध्यम से व्यवहार्य प्रवाह खोजना सम्मिलित होता है जो अधिकतम संभव प्रवाह दर प्राप्त करता है।
 
'''अधिकतम प्रवाह समस्या''' को संचलन समस्या जैसे अधिक जटिल नेटवर्क प्रवाह समस्याओं के विशेष स्थिति के रूप में देखा जा सकता है। एसटी प्रवाह का अधिकतम मूल्य (अर्थात, ग्राफ सिद्धांत की शब्दावली से प्रवाह दिशा s से ग्राफ़ सिद्धांत की शब्दावली दिशा t) [[कट (ग्राफ सिद्धांत)]] की न्यूनतम क्षमता के समान होती है। और एसटी कट (अर्थात, विच्छेदित एस टी से) नेटवर्क में, जैसा कि [[मैक्स-फ्लो मिन-कट प्रमेय]] में कहा गया है।


== इतिहास ==
== इतिहास ==
अधिकतम प्रवाह समस्या पहली बार 1954 में टेड हैरिस (गणितज्ञ) | टी द्वारा तैयार की गई थी। सोवियत रेलवे यातायात प्रवाह के सरलीकृत मॉडल के रूप में ई. हैरिस और एफ.एस. रॉस।<ref name=":0">{{Cite journal | last1 = Schrijver | first1 = A. | title = परिवहन के इतिहास और अधिकतम प्रवाह की समस्याओं पर| doi = 10.1007/s101070100259 | journal = Mathematical Programming | volume = 91 | issue = 3 | pages = 437–445 | year = 2002 | citeseerx = 10.1.1.23.5134 | s2cid = 10210675 }}</ref><ref>{{Cite book | doi = 10.1007/0-387-25837-X_5 | first1 =  Saul I. | last1 = Gass| first2 = Arjang A. | last2 = Assad | chapter = Mathematical, algorithmic and professional developments of operations research from 1951 to 1956 | title = ऑपरेशंस रिसर्च की एन एनोटेटेड टाइमलाइन| series = International Series in Operations Research & Management Science | volume = 75 | pages = 79–110 | year = 2005 | isbn = 978-1-4020-8116-3 }}</ref><ref name=":2">{{cite journal | first1 = T. E. | last1 = Harris | author-link1 = Ted Harris (mathematician) | first2 = F. S. | last2 = Ross | year = 1955 | title = रेल नेट क्षमताओं के मूल्यांकन के लिए एक विधि के मूल सिद्धांत| journal = Research Memorandum| url = http://www.dtic.mil/dtic/tr/fulltext/u2/093458.pdf| archive-url = https://web.archive.org/web/20140108021700/http://www.dtic.mil/dtic/tr/fulltext/u2/093458.pdf| url-status = dead| archive-date = 8 January 2014}}</ref>
अधिकतम प्रवाह समस्या प्रथम बार 1954 में टेड हैरिस (गणितज्ञ) टी द्वारा तैयार की गई थी। सोवियत रेलवे यातायात प्रवाह के सरलीकृत मॉडल के रूप में ई. हैरिस और एफ.एस. रॉस है।<ref name=":0">{{Cite journal | last1 = Schrijver | first1 = A. | title = परिवहन के इतिहास और अधिकतम प्रवाह की समस्याओं पर| doi = 10.1007/s101070100259 | journal = Mathematical Programming | volume = 91 | issue = 3 | pages = 437–445 | year = 2002 | citeseerx = 10.1.1.23.5134 | s2cid = 10210675 }}</ref><ref>{{Cite book | doi = 10.1007/0-387-25837-X_5 | first1 =  Saul I. | last1 = Gass| first2 = Arjang A. | last2 = Assad | chapter = Mathematical, algorithmic and professional developments of operations research from 1951 to 1956 | title = ऑपरेशंस रिसर्च की एन एनोटेटेड टाइमलाइन| series = International Series in Operations Research & Management Science | volume = 75 | pages = 79–110 | year = 2005 | isbn = 978-1-4020-8116-3 }}</ref><ref name=":2">{{cite journal | first1 = T. E. | last1 = Harris | author-link1 = Ted Harris (mathematician) | first2 = F. S. | last2 = Ross | year = 1955 | title = रेल नेट क्षमताओं के मूल्यांकन के लिए एक विधि के मूल सिद्धांत| journal = Research Memorandum| url = http://www.dtic.mil/dtic/tr/fulltext/u2/093458.pdf| archive-url = https://web.archive.org/web/20140108021700/http://www.dtic.mil/dtic/tr/fulltext/u2/093458.pdf| url-status = dead| archive-date = 8 January 2014}}</ref>
1955 में, लेस्टर आर. फोर्ड, जूनियर और डी. आर. फुलकर्सन | डेलबर्ट आर. फुलकर्सन ने पहला ज्ञात एल्गोरिदम, फोर्ड-फुलकर्सन एल्गोरिदम बनाया।<ref name=":1">{{Cite journal | last1 = Ford | first1 = L. R. | author-link1 = L. R. Ford, Jr.| last2 = Fulkerson | first2 = D. R. | author-link2 = D. R. Fulkerson| doi = 10.4153/CJM-1956-045-5 | title = एक नेटवर्क के माध्यम से अधिकतम प्रवाह| journal = [[Canadian Journal of Mathematics]]| volume = 8 | pages = 399–404 | year = 1956 | doi-access = free }}</ref><ref name=":3">Ford, L.R., Jr.; Fulkerson, D.R., ''Flows in Networks'', Princeton University Press (1962).</ref> उनके 1955 के पेपर में,<ref name=":1" />फोर्ड और फुलकर्सन ने लिखा है कि हैरिस और रॉस की समस्या निम्नानुसार तैयार की गई है (देखें<ref name=":0" />पी। 5):<blockquote>एक रेल नेटवर्क पर विचार करें जो दो शहरों को कई मध्यवर्ती शहरों के माध्यम से जोड़ता है, जहां नेटवर्क के प्रत्येक लिंक में एक नंबर दिया गया है जो इसकी क्षमता का प्रतिनिधित्व करता है। एक स्थिर स्थिति की स्थिति मानते हुए, एक दिए गए शहर से दूसरे शहर में अधिकतम प्रवाह खोजें।</blockquote>उनकी पुस्तक फ्लो इन नेटवर्क में,<ref name=":3" />1962 में, फोर्ड और फुलकर्सन ने लिखा:<blockquote>यह लेखकों को 1955 के वसंत में टी. ई. हैरिस द्वारा प्रस्तुत किया गया था, जिन्होंने जनरल एफ.एस. रॉस (सेवानिवृत्त) के साथ मिलकर रेलवे यातायात प्रवाह का एक सरलीकृत मॉडल तैयार किया था, और इस विशेष समस्या को मॉडल [11] द्वारा सुझाई गई केंद्रीय समस्या के रूप में इंगित किया।</blockquote> जहां [11] हैरिस और रॉस द्वारा रेल नेट क्षमताओं के मूल्यांकन के लिए 1955 की गुप्त रिपोर्ट फंडामेंटल्स ऑफ ए मेथड को संदर्भित करता है।<ref name=":2" />(देखना<ref name=":0" />पी। 5).
1955 में, लेस्टर आर. फोर्ड, जूनियर और डी. आर. फुलकर्सन या डेलबर्ट आर. फुलकर्सन ने पहला ज्ञात एल्गोरिदम, फोर्ड-फुलकर्सन एल्गोरिदम बनाया गया था।<ref name=":1">{{Cite journal | last1 = Ford | first1 = L. R. | author-link1 = L. R. Ford, Jr.| last2 = Fulkerson | first2 = D. R. | author-link2 = D. R. Fulkerson| doi = 10.4153/CJM-1956-045-5 | title = एक नेटवर्क के माध्यम से अधिकतम प्रवाह| journal = [[Canadian Journal of Mathematics]]| volume = 8 | pages = 399–404 | year = 1956 | doi-access = free }}</ref><ref name=":3">Ford, L.R., Jr.; Fulkerson, D.R., ''Flows in Networks'', Princeton University Press (1962).</ref> उनके 1955 के पेपर में,<ref name=":1" /> फोर्ड और फुलकर्सन ने लिखा है कि हैरिस और रॉस की समस्या निम्नानुसार तैयार की गई है (देखें <ref name=":0" /> पी। 5):<blockquote>रेल नेटवर्क पर विचार करें जोकी दो शहरों को कई मध्यवर्ती शहरों के माध्यम से जोड़ता है, जहां नेटवर्क के प्रत्येक लिंक में नंबर दिया गया है जो इसकी क्षमता का प्रतिनिधित्व करता है। स्थिर स्थिति की स्थिति मानते हुए, दिए गए शहर से दूसरे शहर में अधिकतम प्रवाह खोजते है।</blockquote>1962 में अपनी किताब फ्लोज़ इन नेटवर्क <ref name=":3" /> में फोर्ड और फुलकर्सन ने लिखा:<blockquote>यह लेखकों को 1955 के वसंत में टी. ई. हैरिस द्वारा प्रस्तुत किया गया था, जिन्होंने जनरल एफ.एस. रॉस (सेवानिवृत्त) के साथ मिलकर रेलवे यातायात प्रवाह का सरलीकृत मॉडल तैयार किया था, और इस विशेष समस्या को मॉडल द्वारा सुझाई गई केंद्रीय समस्या के रूप में इंगित किया गया था।</blockquote> जहां हैरिस और रॉस द्वारा रेल नेट क्षमताओं के मूल्यांकन के लिए 1955 की गुप्त प्रतिवेदन फंडामेंटल्स ऑफ ए मेथड को संदर्भित करता है।<ref name=":2" /> (देखना <ref name=":0" /> पी। 5).


इन वर्षों में, अधिकतम प्रवाह समस्या के विभिन्न उन्नत समाधानों की खोज की गई, विशेष रूप से एडमंड्स और कार्प और स्वतंत्र रूप से डिनिट्ज़ का सबसे छोटा संवर्द्धन पथ एल्गोरिथम; डिनिट्ज़ का ब्लॉकिंग फ्लो एल्गोरिथम; पुश-रीलेबेल अधिकतम प्रवाह एल्गोरिथम|एंड्रयू वी. गोल्डबर्ग और [[रॉबर्ट टार्जन]] का पुश-रीलेबेल एल्गोरिथम; और गोल्डबर्ग और राव का बाइनरी ब्लॉकिंग फ्लो एल्गोरिथम। शर्मन के एल्गोरिदम<ref>{{Cite book | last = Sherman | first = Jonah | chapter = Nearly Maximum Flows in Nearly Linear Time | doi = 10.1109/FOCS.2013.36 | title = Proceedings of the 54th Annual IEEE Symposium on Foundations of Computer Science | pages = 263–269 | year = 2013 | arxiv = 1304.2077 | isbn = 978-0-7695-5135-7 | s2cid = 14681906 }}</ref> और केलनर, ली, ओरेचिया और सिडफोर्ड,<ref>{{Cite book | last1 = Kelner | first1 = J. A. | last2 = Lee | first2 = Y. T. | last3 = Orecchia | first3 = L. | last4 = Sidford | first4 = A. | chapter = An Almost-Linear-Time Algorithm for Approximate Max Flow in Undirected Graphs, and its Multicommodity Generalizations | doi = 10.1137/1.9781611973402.16 | title = असतत एल्गोरिदम पर पच्चीसवीं वार्षिक एसीएम-सियाम संगोष्ठी की कार्यवाही| pages = 217 | year = 2014 | isbn = 978-1-61197-338-9 | chapter-url = http://math.mit.edu/~kelner/Publications/Docs/klos_maxflow_main.pdf | arxiv = 1304.2338 | s2cid = 10733914 | url-status = dead | archive-url = https://web.archive.org/web/20160303170302/http://math.mit.edu/~kelner/Publications/Docs/klos_maxflow_main.pdf | archive-date =2016-03-03 }}</ref><ref>{{cite web | url = http://web.mit.edu/newsoffice/2013/new-algorithm-can-dramatically-streamline-solutions-to-the-max-flow-problem-0107.html | title = नया एल्गोरिदम नाटकीय रूप से 'अधिकतम प्रवाह' समस्या के समाधान को सुव्यवस्थित कर सकता है| first = Helen | last = Knight | date = 7 January 2014 | access-date = 8 January 2014 | publisher = MIT News}}</ref> क्रमशः, लगभग इष्टतम अधिकतम प्रवाह ज्ञात करें लेकिन केवल अप्रत्यक्ष रेखांकन में काम करें।
इन वर्षों में, अधिकतम प्रवाह समस्या के विभिन्न उन्नत समाधानों की खोज की गई थी, विशेष रूप से एडमंड्स और कार्प और स्वतंत्र रूप से डिनिट्ज़ का सबसे छोटा संवर्द्धन पथ एल्गोरिथम; डिनिट्ज़ का ब्लॉकिंग फ्लो एल्गोरिथम; पुश-रीलेबेल अधिकतम प्रवाह एल्गोरिथम या एंड्रयू वी. गोल्डबर्ग और [[रॉबर्ट टार्जन]] का पुश-रीलेबेल एल्गोरिथम; और गोल्डबर्ग और राव का बाइनरी ब्लॉकिंग फ्लो एल्गोरिथम या शर्मन के एल्गोरिदम <ref>{{Cite book | last = Sherman | first = Jonah | chapter = Nearly Maximum Flows in Nearly Linear Time | doi = 10.1109/FOCS.2013.36 | title = Proceedings of the 54th Annual IEEE Symposium on Foundations of Computer Science | pages = 263–269 | year = 2013 | arxiv = 1304.2077 | isbn = 978-0-7695-5135-7 | s2cid = 14681906 }}</ref> और केलनर, ली, ओरेचिया और सिडफोर्ड,<ref>{{Cite book | last1 = Kelner | first1 = J. A. | last2 = Lee | first2 = Y. T. | last3 = Orecchia | first3 = L. | last4 = Sidford | first4 = A. | chapter = An Almost-Linear-Time Algorithm for Approximate Max Flow in Undirected Graphs, and its Multicommodity Generalizations | doi = 10.1137/1.9781611973402.16 | title = असतत एल्गोरिदम पर पच्चीसवीं वार्षिक एसीएम-सियाम संगोष्ठी की कार्यवाही| pages = 217 | year = 2014 | isbn = 978-1-61197-338-9 | chapter-url = http://math.mit.edu/~kelner/Publications/Docs/klos_maxflow_main.pdf | arxiv = 1304.2338 | s2cid = 10733914 | url-status = dead | archive-url = https://web.archive.org/web/20160303170302/http://math.mit.edu/~kelner/Publications/Docs/klos_maxflow_main.pdf | archive-date =2016-03-03 }}</ref><ref>{{cite web | url = http://web.mit.edu/newsoffice/2013/new-algorithm-can-dramatically-streamline-solutions-to-the-max-flow-problem-0107.html | title = नया एल्गोरिदम नाटकीय रूप से 'अधिकतम प्रवाह' समस्या के समाधान को सुव्यवस्थित कर सकता है| first = Helen | last = Knight | date = 7 January 2014 | access-date = 8 January 2014 | publisher = MIT News}}</ref> क्रमशः, लगभग इष्टतम अधिकतम प्रवाह ज्ञात करें किन्तु केवल अप्रत्यक्ष रेखांकन में काम करें।


2013 में जेम्स बी. ओर्लिन ने एक वर्णन करते हुए एक पेपर प्रकाशित किया <math>O(|V| |E|)</math> कलन विधि।<ref name="orlin" />
2013 में जेम्स बी. ओर्लिन ने वर्णन करते हुए पेपर प्रकाशित किया <math>O(|V| |E|)</math> कलन विधि है।<ref name="orlin" />


2022 में ली चेन, रासमस किन्ग, यांग पी. लियू, रिचर्ड पेंग, मैक्सिमिलियन प्रोबस्ट गुटेनबर्ग और सुशांत सचदेवा ने एक लगभग-रैखिक समय एल्गोरिदम प्रकाशित किया जो चल रहा है <math>O(|E|^{1+o(1)})</math> न्यूनतम-लागत प्रवाह समस्या के लिए|न्यूनतम-लागत प्रवाह समस्या जिसमें से अधिकतम प्रवाह समस्या एक विशेष मामला है।<ref name="almost linear" /><ref>{{Cite web |last=Klarreich |first=Erica |date=2022-06-08 |title=शोधकर्ताओं ने नेटवर्क प्रवाह के लिए 'एब्सर्डली फास्ट' एल्गोरिथम हासिल किया|url=https://www.quantamagazine.org/researchers-achieve-absurdly-fast-algorithm-for-network-flow-20220608/ |access-date=2022-06-08 |website=Quanta Magazine |language=en}}</ref> [[एकल स्रोत सबसे छोटी पथ समस्या]] | सिंगल-सोर्स शॉर्टेस्ट पाथ (एसएसएसपी) समस्या के लिए नकारात्मक भार के साथ न्यूनतम-लागत प्रवाह समस्या का एक और विशेष मामला लगभग-रैखिक समय में एक एल्गोरिथ्म भी रिपोर्ट किया गया है।<ref>{{Cite arXiv |last1=Bernstein |first1=Aaron |last2=Nanongkai |first2=Danupon |last3=Wulff-Nilsen |first3=Christian |date=2022-10-30 |title=नेगेटिव-वेट सिंगल-सोर्स शॉर्टेस्ट पाथ इन नियर-लीनियर टाइम|class=cs.DS |eprint=2203.03456 }}</ref><ref>{{Cite web |last=Brubaker |first=Ben |date=2023-01-18 |title=अंत में, नकारात्मक रेखांकन पर सबसे छोटे रास्तों के लिए एक तेज़ एल्गोरिथम|url=https://www.quantamagazine.org/finally-a-fast-algorithm-for-shortest-paths-on-negative-graphs-20230118/ |access-date=2023-01-25 |website=Quanta Magazine |language=en}}</ref> दोनों एल्गोरिदम को कंप्यूटर विज्ञान की नींव पर 2022 संगोष्ठी में सर्वश्रेष्ठ पेपर माना गया।<ref>{{Cite web |title=FOCS 2022 |url=https://focs2022.eecs.berkeley.edu/awards.html |access-date=2023-01-25 |website=focs2022.eecs.berkeley.edu}}</ref><ref>{{Cite web |last=Santosh |first=Nagarakatte |title=FOCS 2022 Best Paper Award for Prof. Aaron Bernstein's Paper |url=https://www.cs.rutgers.edu/news-events/news/news-item/focs-2022-best-paper-award-for-prof-aaron-bernstein-s-paper |access-date=2023-01-25 |website=www.cs.rutgers.edu |language=en-gb}}</ref>
2022 में ली चेन, रासमस किन्ग, यांग पी. लियू, रिचर्ड पेंग, मैक्सिमिलियन प्रोबस्ट गुटेनबर्ग और सुशांत सचदेवा ने लगभग-रैखिक समय एल्गोरिदम प्रकाशित किया जो चल रहा है <math>O(|E|^{1+o(1)})</math> न्यूनतम-व्यय प्रवाह समस्या के लिए जिसमें से अधिकतम प्रवाह समस्या विशेष स्थिति है।<ref name="almost linear" /><ref>{{Cite web |last=Klarreich |first=Erica |date=2022-06-08 |title=शोधकर्ताओं ने नेटवर्क प्रवाह के लिए 'एब्सर्डली फास्ट' एल्गोरिथम हासिल किया|url=https://www.quantamagazine.org/researchers-achieve-absurdly-fast-algorithm-for-network-flow-20220608/ |access-date=2022-06-08 |website=Quanta Magazine |language=en}}</ref> [[एकल स्रोत सबसे छोटी पथ समस्या]] (एसएसएसपी) समस्या के लिए नकारात्मक भार के साथ न्यूनतम-व्यय प्रवाह समस्या का और विशेष स्थिति लगभग-रैखिक समय में एल्गोरिथ्म भी प्रतिवेदन किया गया है।<ref>{{Cite arXiv |last1=Bernstein |first1=Aaron |last2=Nanongkai |first2=Danupon |last3=Wulff-Nilsen |first3=Christian |date=2022-10-30 |title=नेगेटिव-वेट सिंगल-सोर्स शॉर्टेस्ट पाथ इन नियर-लीनियर टाइम|class=cs.DS |eprint=2203.03456 }}</ref><ref>{{Cite web |last=Brubaker |first=Ben |date=2023-01-18 |title=अंत में, नकारात्मक रेखांकन पर सबसे छोटे रास्तों के लिए एक तेज़ एल्गोरिथम|url=https://www.quantamagazine.org/finally-a-fast-algorithm-for-shortest-paths-on-negative-graphs-20230118/ |access-date=2023-01-25 |website=Quanta Magazine |language=en}}</ref> दोनों एल्गोरिदम को कंप्यूटर विज्ञान की नींव पर 2022 संगोष्ठी में सर्वश्रेष्ठ पेपर माना गया।<ref>{{Cite web |title=FOCS 2022 |url=https://focs2022.eecs.berkeley.edu/awards.html |access-date=2023-01-25 |website=focs2022.eecs.berkeley.edu}}</ref><ref>{{Cite web |last=Santosh |first=Nagarakatte |title=FOCS 2022 Best Paper Award for Prof. Aaron Bernstein's Paper |url=https://www.cs.rutgers.edu/news-events/news/news-item/focs-2022-best-paper-award-for-prof-aaron-bernstein-s-paper |access-date=2023-01-25 |website=www.cs.rutgers.edu |language=en-gb}}</ref>
== परिभाषा ==
[[File:Simpe_flow_network.svg|thumb|upright=0.8|प्रवाह नेटवर्क, स्रोत एस और सिंक टी के साथ। किनारे के आगे की संख्याएँ क्षमताएँ हैं।]]पहले हम कुछ अंकन स्थापित करते हैं:
*माना <math>N = (V, E)</math> वाला नेटवर्क है जो क्रमशः <math>N</math> का <math>s, t \in V</math> स्रोत और सिंक है।
*यदि <math>g</math>, <math>N</math> के किनारों पर फलन है, तो इसका मान <math>(u,v) \in E</math> पर <math>g_{uv}</math> या <math>g(u,v).</math> द्वारा दर्शाया जाता है
'''परिभाषा''' किनारे की क्षमता प्रवाह की अधिकतम मात्रा है जो किनारे से निकल सकती है। औपचारिक रूप से यह <math>c: E \to \R^+.</math> रुपरेखा है ।


'''परिभाषा''' प्रवाह रुपरेखा है जो <math>f : E \to \R</math> निम्नलिखित को संतुष्ट करता है:
* क्षमता प्रतिबंध किनारे का प्रवाह दूसरे शब्दों में इसकी क्षमता से अधिक नहीं हो सकता है:
* प्रवाह का संरक्षण स्रोत और सिंक को छोड़कर, नोड में प्रवेश करने वाले प्रवाहों का योग उस नोड से बाहर निकलने वाले प्रवाहों के योग के समान होना चाहिए। या:
::<math>\forall v \in V \setminus \{s, t\}: \quad \sum_{u:(u, v) \in E} f_{uv} = \sum_{u:(v, u) \in E} f_{vu}.</math>
<math>f_{uv} = -f_{vu}</math> प्रवाह विषम सममित हैं: सभी के लिए <math>(u, v) \in E.</math>


== परिभाषा ==
परिभाषा प्रवाह का मान स्रोत से सिंक तक जाने वाले प्रवाह की मात्रा है। औपचारिक रूप से प्रवाह के लिए <math>f : E \to \R^+</math> इसके द्वारा दिया गया है:
[[File:Simpe_flow_network.svg|thumb|upright=0.8|एक प्रवाह नेटवर्क, स्रोत एस और सिंक टी के साथ। किनारे के आगे की संख्याएँ क्षमताएँ हैं।]]पहले हम कुछ अंकन स्थापित करते हैं:
* होने देना <math>N = (V, E)</math> के साथ एक नेटवर्क हो <math>s, t \in V</math> स्रोत और सिंक होने के नाते <math>N</math> क्रमश।
* अगर <math>g</math> के किनारों पर एक समारोह है <math>N</math> फिर इसका मूल्य <math>(u,v) \in E</math> द्वारा निरूपित किया जाता है <math>g_{uv}</math> या <math>g(u,v).</math>
परिभाषा। किनारे की क्षमता प्रवाह की अधिकतम मात्रा है जो किनारे से गुजर सकती है। औपचारिक रूप से यह एक नक्शा है <math>c: E \to \R^+.</math>
परिभाषा। एक प्रवाह एक नक्शा है <math>f : E \to \R</math> जो निम्नलिखित को संतुष्ट करता है:
* क्षमता बाधा। किनारे का प्रवाह दूसरे शब्दों में इसकी क्षमता से अधिक नहीं हो सकता है: <math>f_{uv} \leq c_{uv}</math> सभी के लिए <math>(u, v) \in E.</math>
* प्रवाह का संरक्षण। स्रोत और सिंक को छोड़कर, नोड में प्रवेश करने वाले प्रवाहों का योग उस नोड से बाहर निकलने वाले प्रवाहों के योग के बराबर होना चाहिए। या:
::<math>\forall v \in V \setminus \{s, t\}: \quad \sum_{u:(u, v) \in E} f_{uv} = \sum_{u:(v, u) \in E} f_{vu}.</math>
टिप्पणी। प्रवाह विषम सममित हैं: <math>f_{uv} = -f_{vu}</math> सभी के लिए <math>(u, v) \in E.</math>
परिभाषा। प्रवाह का मान स्रोत से सिंक तक जाने वाले प्रवाह की मात्रा है। औपचारिक रूप से एक प्रवाह के लिए <math>f : E \to \R^+</math> इसके द्वारा दिया गया है:
:<math>|f| = \sum_{v:\ (s,v) \in E} f_{sv} - \sum_{u:\ (u,s) \in E} f_{us}.</math>
:<math>|f| = \sum_{v:\ (s,v) \in E} f_{sv} - \sum_{u:\ (u,s) \in E} f_{us}.</math>
परिभाषा। अधिकतम प्रवाह समस्या स्रोत से सिंक तक जितना संभव हो उतना प्रवाह मार्ग है, दूसरे शब्दों में प्रवाह को ढूंढें <math>f_\textrm{max}</math> अधिकतम मूल्य के साथ।
परिभाषा अधिकतम प्रवाह समस्या स्रोत से सिंक तक जितना संभव हो उतना प्रवाह मार्ग है, दूसरे शब्दों में प्रवाह <math>f_\textrm{max}</math> को अधिकतम मूल्य के साथ खोजते है।


ध्यान दें कि कई अधिकतम प्रवाह मौजूद हो सकते हैं, और यदि मनमाना वास्तविक (या यहां तक ​​​​कि मनमाना तर्कसंगत) प्रवाह के मूल्यों की अनुमति है (केवल पूर्णांकों के बजाय), तो या तो एक अधिकतम प्रवाह होता है, या असीम रूप से कई होते हैं, क्योंकि असीम रूप से कई रैखिक संयोजन होते हैं आधार अधिकतम प्रवाह। दूसरे शब्दों में, अगर हम भेजते हैं <math>x</math> किनारे पर प्रवाह की इकाइयाँ <math>u</math> एक अधिकतम प्रवाह में, और <math>y > x</math> प्रवाह की इकाइयाँ <math>u</math> दूसरे अधिकतम प्रवाह में, फिर प्रत्येक के लिए <math>\Delta \in [0, y-x]</math> हम भेज सकते हैं <math>x+\Delta</math> इकाइयों पर <math>u</math> और एक और अधिकतम प्रवाह प्राप्त करने के लिए तदनुसार शेष किनारों पर प्रवाह को रूट करें। यदि प्रवाह मान कोई वास्तविक या परिमेय संख्या हो सकती है, तो ऐसे अपरिमित रूप से अनेक होते हैं <math>\Delta</math> प्रत्येक जोड़ी के लिए मान <math>x, y</math>.
ध्यान दें कि कई अधिकतम प्रवाह उपस्थित हो सकते हैं और यदि इच्छानुसार वास्तविक (या यहां तक ​​​​कि इच्छानुसार तर्कसंगत) प्रवाह के मूल्यों की अनुमति है (केवल पूर्णांकों के अतिरिक्त), तो या तो अधिकतम प्रवाह होता है, या असीमित रूप से कई होते हैं, क्योंकि असीमित रूप से कई रैखिक संयोजन होते हैं आधार अधिकतम प्रवाह दूसरे शब्दों में, यदि हम भेजते हैं <math>x</math> किनारे पर प्रवाह की इकाइयाँ <math>u</math> अधिकतम प्रवाह में, और <math>y > x</math> प्रवाह की इकाइयाँ <math>u</math> दूसरे अधिकतम प्रवाह में, फिर प्रत्येक के लिए <math>\Delta \in [0, y-x]</math> हम भेज सकते हैं <math>x+\Delta</math> इकाइयों पर <math>u</math> और अधिकतम प्रवाह प्राप्त करने के लिए तदनुसार शेष किनारों पर प्रवाह को रूट करें। यदि प्रवाह मान कोई वास्तविक या परिमेय संख्या हो सकती है, तो ऐसे अपरिमित रूप <math>\Delta</math> से अनेक होते हैं प्रत्येक <math>x, y</math> जोड़ी के लिए मान है।


== एल्गोरिदम ==
== एल्गोरिदम ==
निम्न तालिका अधिकतम प्रवाह समस्या को हल करने के लिए एल्गोरिदम सूचीबद्ध करती है।
निम्न तालिका अधिकतम प्रवाह समस्या को हल करने के लिए एल्गोरिदम सूचीबद्ध करती है। यहाँ, <math>V</math> और <math>E</math> नेटवर्क के कोने और किनारों की संख्या को निरूपित करें। मूल्य <math>U</math> सभी क्षमताओं को पूर्णांक मानों में बदलने के बाद सबसे बड़ी धार क्षमता को संदर्भित करता है (यदि नेटवर्क में [[अपरिमेय संख्या]] क्षमताएं हैं, <math>U</math> अनंत हो सकता है)।
यहाँ, <math>V</math> और <math>E</math> नेटवर्क के कोने और किनारों की संख्या को निरूपित करें।
मूल्य <math>U</math> सभी क्षमताओं को पूर्णांक मानों में बदलने के बाद सबसे बड़ी धार क्षमता को संदर्भित करता है
(यदि नेटवर्क में [[अपरिमेय संख्या]] क्षमताएं हैं, <math>U</math> अनंत हो सकता है)।


{| class="wikitable"
{| class="wikitable"
! Method
! विधि
! Complexity
! जटिलता
! Description
! विवरण
|-
|-
| [[Linear programming]]
| [[Linear programming|लीनियर प्रोग्रामिंग]]
|
|
| Constraints given by the definition of a [[flow network|legal flow]]. See the [[Max-flow min-cut theorem#Linear program formulation|linear program]] here.
| वैधानिक प्रवाह की परिभाषा द्वारा दी गई बाधाएं। यहां रैखिक कार्यक्रम देखें।
|-
|-
| [[Ford–Fulkerson algorithm]]
| [[Ford–Fulkerson algorithm|फोर्ड-फुलकर्सन एल्गोरिथम]]
| <math>O(E^2U)</math>
| <math>O(E^2U)</math>
| As long as there is an open path through the residual graph, send the minimum of the residual capacities on that path.
| जब तक अवशिष्ट ग्राफ के माध्यम से खुला मार्ग है, उस पथ पर न्यूनतम अवशिष्ट क्षमता भेजें।
|-
|-
| [[Edmonds–Karp algorithm]]
| [[Edmonds–Karp algorithm|एडमंड्स-कार्प एल्गोरिथम]]
| <math>O(VE^2)</math>
| <math>O(VE^2)</math>
| A specialization of Ford–Fulkerson, finding augmenting paths with [[breadth-first search]].
| फोर्ड-फुलकर्सन की विशेषज्ञता, चौड़ाई-प्रथम खोज के साथ संवर्द्धित पथ ढूँढना।
|-
|-
| [[Dinic's algorithm]]
| [[Dinic's algorithm|डिनिक का एल्गोरिदम]]
| <math>O(V^2E)</math>
| <math>O(V^2E)</math>
| In each phase the algorithms builds a layered graph with [[breadth-first search]] on the [[residual graph]]. The maximum flow in a layered graph can be calculated in <math>O(VE)</math> time, and the maximum number of phases is <math>V-1</math>. In networks with unit capacities, Dinic's algorithm terminates in <math>O(\min\{V^{2/3}, E^{1/2}\}E)</math> time.
| प्रत्येक चरण में एल्गोरिदम अवशिष्ट ग्राफ पर चौड़ाई-पहली खोज के साथ स्तरित ग्राफ बनाता है। स्तरित ग्राफ में अधिकतम प्रवाह की गणना की जा सकती है <math>O(VE)</math> समय, और चरणों की अधिकतम संख्या है <math>V-1</math>. इकाई क्षमता वाले नेटवर्क में, डिनिक का एल्गोरिदम में समाप्त होता है <math>O(\min\{V^{2/3}, E^{1/2}\}E)</math> समय.
|-
|-
| MKM (Malhotra, Kumar, Maheshwari) algorithm<ref>{{Cite journal | last1 = Malhotra | first1 =V.M.| last2 = Kumar | first2 = M. Pramodh| last3 = Maheshwari | first3 = S.N.| doi = 10.1016/0020-0190(78)90016-9| title = An <math>O(|V|^3)</math> algorithm for finding maximum flows in networks| journal = Information Processing Letters| volume = 7| issue = 6| pages = 277–278 | year = 1978| url =https://eprints.utas.edu.au/160/1/iplFlow.pdf}}</ref>
| एमकेएम (मल्होत्रा, कुमार, माहेश्वरी) एल्गोरिथम<ref>{{Cite journal | last1 = Malhotra | first1 =V.M.| last2 = Kumar | first2 = M. Pramodh| last3 = Maheshwari | first3 = S.N.| doi = 10.1016/0020-0190(78)90016-9| title = An <math>O(|V|^3)</math> algorithm for finding maximum flows in networks| journal = Information Processing Letters| volume = 7| issue = 6| pages = 277–278 | year = 1978| url =https://eprints.utas.edu.au/160/1/iplFlow.pdf}}</ref>
| <math>O(V^3)</math>
| <math>O(V^3)</math>
| A modification of Dinic's algorithm with a different approach to constructing blocking flows. Refer to the [[#{{harvid|Malhotra|Kumar|Maheshwari|1978}}|original paper]].
| अवरुद्ध प्रवाह के निर्माण के लिए अलग दृष्टिकोण के साथ डिनिक का संदेश का संशोधन। मूल पेपर का संदर्भ लें।
|-
|-
| [[Dinic's algorithm]] with dynamic trees
| [[Dinic's algorithm|डिनिक का एल्गोरिदम]] गतिशील वृक्षों के साथ
| <math>O(VE \log V)</math>
| <math>O(VE \log V)</math>
| The [[dynamic trees]] data structure speeds up the maximum flow computation in the layered graph to <math>O(VE \log V)</math>.
| डायनेमिक ट्री डेटा संरचना स्तरित ग्राफ़ में अधिकतम प्रवाह संगणना को गति देती है <math>O(VE \log V)</math>.
|-
|-
| General [[push–relabel algorithm]]<ref name="goldberg1988"/>
| सामान्य पुश-रिलेबल एल्गोरिथम<ref name="goldberg1988"/>
| <math>O(V^2E)</math>
| <math>O(V^2E)</math>
| The push relabel algorithm maintains a preflow, i.e. a flow function with the possibility of excess in the vertices. The algorithm runs while there is a vertex with positive excess, i.e. an active vertex in the graph. The push operation increases the flow on a residual edge, and a height function on the vertices controls through which residual edges can flow be pushed. The height function is changed by the relabel operation. The proper definitions of these operations guarantee that the resulting flow function is a maximum flow.
| पुश रीलेबल एल्गोरिथम प्रीफ्लो बनाए रखता है, अर्थात वर्टिकल में अधिकता की संभावना के साथ फ्लो फलन या एल्गोरिथम तब चलता है जब धनात्मक आधिक्य वाला शीर्ष होता है, अर्थात ग्राफ़ में सक्रिय शीर्ष। पुश ऑपरेशन अवशिष्ट किनारे पर प्रवाह को बढ़ाता है, और शीर्षों पर ऊंचाई फलन नियंत्रित करता है जिसके माध्यम से अवशिष्ट किनारों को प्रवाहित किया जा सकता है। ऊंचाई फलन को रीलेबल ऑपरेशन द्वारा बदल दिया जाता है। इन परिचालनों की उचित परिभाषाएं आश्वासन देती हैं कि परिणामी प्रवाह फलन अधिकतम प्रवाह है।
|-
|-
| [[Push–relabel algorithm]] with ''FIFO'' vertex selection rule<ref name="goldberg1988"/>
| फीफो शीर्ष चयन नियम के साथ पुश-रीलेबल एल्गोरिथम<ref name="goldberg1988"/>
| <math>O(V^3)</math>
| <math>O(V^3)</math>
| Push-relabel algorithm variant which always selects the most recently active vertex, and performs push operations while the excess is positive and there are admissible residual edges from this vertex.
| पुश-रीलेबल एल्गोरिथम वैरिएंट जो सदैव सबसे वर्तमान में सक्रिय वर्टेक्स का चयन करता है और पुश ऑपरेशंस करता है जबकि अतिरिक्त सकारात्मक होता है और इस वर्टेक्स से स्वीकार्य अवशिष्ट किनारे होते हैं।
|-
|-
|-
|-
| [[Push–relabel algorithm]] with ''maximum distance'' vertex selection rule<ref name="cheriyan1988">{{cite book
| अधिकतम दूरी वर्टेक्स चयन नियम के साथ पुश-रीलेबल एल्गोरिथम<ref name="cheriyan1988">{{cite book
  | last1 = Cheriyan
  | last1 = Cheriyan
  | first1 = J.
  | first1 = J.
Line 92: Line 90:
  }}</ref>
  }}</ref>
| <math>O(V^2 \sqrt{E})</math>
| <math>O(V^2 \sqrt{E})</math>
| Push-relabel algorithm variant which always selects the most distant vertex from <math>s</math> or <math>t</math> (i.e. the highest label vertex) but otherwise proceeds as the FIFO algorithm.
| पुश-रीलेबल एल्गोरिथम वैरिएंट जो सदैव 𝑠 या 𝑡 (अर्थात उच्चतम लेबल शीर्ष) से सबसे दूर के शीर्ष का चयन करता है, किन्तु अन्यथा फीफो एल्गोरिथ्म के रूप में आगे बढ़ता है।
|-
|-
| [[Push-relabel algorithm]] with dynamic trees<ref name="goldberg1988">{{Cite journal
| डायनेमिक ट्री के साथ पुश-रीलेबल एल्गोरिथम<ref name="goldberg1988">{{Cite journal
  | last1 = Goldberg | first1 = A. V. | author-link1 = Andrew V. Goldberg
  | last1 = Goldberg | first1 = A. V. | author-link1 = Andrew V. Goldberg
  | last2 = Tarjan | first2 = R. E. | author-link2 = Robert E. Tarjan
  | last2 = Tarjan | first2 = R. E. | author-link2 = Robert E. Tarjan
Line 109: Line 107:
}}</ref>
}}</ref>
| <math>O\left( VE \log \frac{V^2}{E} \right)</math>
| <math>O\left( VE \log \frac{V^2}{E} \right)</math>
| The algorithm builds limited size trees on the residual graph regarding to the height function. These trees provide multilevel push operations, i.e. pushing along an entire saturating ''path'' instead of a single edge.
| एल्गोरिथ्म ऊंचाई कार्य के संबंध में अवशिष्ट ग्राफ पर सीमित आकार के पेड़ बनाता है। ये पेड़ बहुस्तरीय पुश ऑपरेशंस प्रदान करते हैं, अर्थात किनारे के अतिरिक्त पूरे संतृप्त पथ के साथ धक्का देता है।
|-
|-
| KRT (King, Rao, Tarjan)'s algorithm<ref>{{Cite journal | last1 = King | first1 = V.| last2 = Rao | first2 = S.| last3 = Tarjan | first3 = R.| doi = 10.1006/jagm.1994.1044| title = A Faster Deterministic Maximum Flow Algorithm| journal = Journal of Algorithms| volume = 17| issue = 3| pages = 447–474| year = 1994| s2cid = 15493}}</ref>
| केआरटी (राजा, राव, टार्जन) का एल्गोरिदम
| <math>O\left( VE \log_{\frac{E}{V \log V}} V \right)</math>
| <math>O\left( VE \log_{\frac{E}{V \log V}} V \right)</math>
|
|
|-
|-
| Binary blocking flow algorithm<ref>{{Cite journal | last1 = Goldberg | first1 = A. V. | author-link1 = Andrew V. Goldberg| last2 = Rao | first2 = S. | doi = 10.1145/290179.290181 | title = Beyond the flow decomposition barrier | journal = [[Journal of the ACM]]| volume = 45 | issue = 5 | pages = 783 | year = 1998 | s2cid = 96030 }}</ref>
| बाइनरी ब्लॉकिंग फ्लो एल्गोरिथम<ref>{{Cite journal | last1 = Goldberg | first1 = A. V. | author-link1 = Andrew V. Goldberg| last2 = Rao | first2 = S. | doi = 10.1145/290179.290181 | title = Beyond the flow decomposition barrier | journal = [[Journal of the ACM]]| volume = 45 | issue = 5 | pages = 783 | year = 1998 | s2cid = 96030 }}</ref>
| <math>O\left( E \cdot \min\{V^{2/3}, E^{1/2}\} \cdot \log \frac{V^2}{E} \cdot \log U \right)</math>
| <math>O\left( E \cdot \min\{V^{2/3}, E^{1/2}\} \cdot \log \frac{V^2}{E} \cdot \log U \right)</math>
|
|
|-
|-
| James B Orlin's + KRT (King, Rao, Tarjan)'s algorithm<ref name="orlin">{{Cite book | last1 = Orlin | first1 = James B.| title = Proceedings of the 45th annual ACM symposium on Symposium on theory of computing – STOC '13| doi = 10.1145/2488608.2488705| chapter = Max flows in O(nm) time, or better| journal = STOC '13 Proceedings of the Forty-Fifth Annual ACM Symposium on Theory of Computing| pages = 765–774| year = 2013| isbn = 9781450320290| citeseerx = 10.1.1.259.5759| s2cid = 207205207}}</ref>
| जेम्स बी ओरलिन का + केआरटी (राजा, राव, टारजन) का एल्गोरिदम<ref name="orlin">{{Cite book | last1 = Orlin | first1 = James B.| title = Proceedings of the 45th annual ACM symposium on Symposium on theory of computing – STOC '13| doi = 10.1145/2488608.2488705| chapter = Max flows in O(nm) time, or better| journal = STOC '13 Proceedings of the Forty-Fifth Annual ACM Symposium on Theory of Computing| pages = 765–774| year = 2013| isbn = 9781450320290| citeseerx = 10.1.1.259.5759| s2cid = 207205207}}</ref>
| <math>O(VE)</math>
| <math>O(VE)</math>
| Orlin's algorithm solves max-flow in <math>O(VE)</math> time for <math>E \leq O(V^{\frac{16}{15} - \epsilon})</math> while KRT solves it in <math>O(VE)</math> for <math>E > V^{1+\epsilon}</math>.
| ओर्लिन का एल्गोरिदम अधिकतम प्रवाह को हल करता है <math>O(VE)</math> के लिए समय <math>E \leq O(V^{\frac{16}{15} - \epsilon})</math> जबकि केआरटी इसे हल करता है <math>O(VE)</math> के लिए <math>E > V^{1+\epsilon}</math>.
|-
|-
| Kathuria-Liu-Sidford algorithm<ref>{{cite book |last1=Kathuria |first1=T. |last2=Liu |first2=Y.P. |last3=Sidford |first3=A. |title=Unit Capacity Maxflow in Almost <math> O(m^{4/3}) </math> Time |date= 16–19 November 2020 |publisher=IEEE |location=Durham, NC, USA |pages=119–130}}</ref>
| कथूरिया-लियू-सिडफोर्ड एल्गोरिथ्म
| <math> E^{4/3+o(1)}U^{1/3} </math>
| <math> E^{4/3+o(1)}U^{1/3} </math>
| Interior point methods and edge boosting using <math>\ell_p</math>-norm flows. Builds on earlier algorithm of Madry, which achieved runtime <math> \tilde O(E^{10/7}U^{1/7}) </math>.<ref>{{cite book |last1=Madry |first1=Aleksander |title=Computing Maximum Flow with Augmenting Electrical Flows |date=9-11 October 2016 |publisher=IEEE |location=New Brunswick, New Jersey |pages=593–602}}</ref>
| ℓ 𝑝 - मानक प्रवाह का उपयोग करके आंतरिक बिंदु विधियां और बढ़त वृद्धि। मैड्री के पहले के एल्गोरिथम पर बनाता है, जिसने रनटाइम प्राप्त किया था <math> \tilde O(E^{10/7}U^{1/7}) </math>.<ref>{{cite book |last1=Madry |first1=Aleksander |title=Computing Maximum Flow with Augmenting Electrical Flows |date=9-11 October 2016 |publisher=IEEE |location=New Brunswick, New Jersey |pages=593–602}}</ref>
|-
|-
| BLNPSSSW / BLLSSSW algorithm<ref>{{cite book |last1=Brand |first1=J. vd |last2=Lee |first2=Y.T. |last3=Nanongkai |first3=D. |last4=Peng |first4=R. |last5=Saranurak |first5=T. |last6=Sidford |first6=A. |last7=Song |first7=Z. |last8=Wang |first8=D. |title=Bipartite Matching in Nearly-linear Time on Moderately Dense Graphs |date= 16–19 November 2020 |publisher=IEEE |location=Durham, NC, USA |pages=919–930}}</ref>
| बीएलएनपीएसएसएसडब्ल्यू / बीएलएलएसएसएसडब्ल्यू एल्गोरिदम<ref>{{cite book |last1=Brand |first1=J. vd |last2=Lee |first2=Y.T. |last3=Nanongkai |first3=D. |last4=Peng |first4=R. |last5=Saranurak |first5=T. |last6=Sidford |first6=A. |last7=Song |first7=Z. |last8=Wang |first8=D. |title=Bipartite Matching in Nearly-linear Time on Moderately Dense Graphs |date= 16–19 November 2020 |publisher=IEEE |location=Durham, NC, USA |pages=919–930}}</ref>
<ref>{{cite arXiv |last1=Brand |first1=J. vd |last2=Lee |first2=Y.T. |last3=Liu |first3=Y.P. |last4=Saranurak |first4=T. |last5=Sidford |first5=A |last6=Song |first6=Z. |last7=Wang |first7=D. |title=Minimum Cost Flows, MDPs, and ℓ1-Regression in Nearly Linear Time for Dense Instances |year=2021 |class=cs.DS |eprint=2101.05719}}</ref>
<ref>{{cite arXiv |last1=Brand |first1=J. vd |last2=Lee |first2=Y.T. |last3=Liu |first3=Y.P. |last4=Saranurak |first4=T. |last5=Sidford |first5=A |last6=Song |first6=Z. |last7=Wang |first7=D. |title=Minimum Cost Flows, MDPs, and ℓ1-Regression in Nearly Linear Time for Dense Instances |year=2021 |class=cs.DS |eprint=2101.05719}}</ref>
| <math>\tilde O((E + V^{3/2}) \log U)</math>
| <math>\tilde O((E + V^{3/2}) \log U)</math>
| Interior point methods and dynamic maintenance of electric flows with expander decompositions.
| विस्तारक अपघटन के साथ विद्युत प्रवाह के आंतरिक बिंदु विधि और गतिशील रखरखाव।
|-
|-
| Gao-Liu-Peng algorithm<ref>{{Cite arXiv | last1 = Gao | first1 = Y.| last2 = Liu | first2 = Y.P.| last3 = Peng | first3 = R.| title = Fully Dynamic Electrical Flows: Sparse Maxflow Faster Than Goldberg-Rao| year = 2021| class = cs.DS| eprint = 2101.07233}}</ref>
| गाओ लियू पेंग एल्गोरिथम<ref>{{Cite arXiv | last1 = Gao | first1 = Y.| last2 = Liu | first2 = Y.P.| last3 = Peng | first3 = R.| title = Fully Dynamic Electrical Flows: Sparse Maxflow Faster Than Goldberg-Rao| year = 2021| class = cs.DS| eprint = 2101.07233}}</ref>
| <math>\tilde O(E^{\frac 32 - \frac 1{328}} \log U)</math>
| <math>\tilde O(E^{\frac 32 - \frac 1{328}} \log U)</math>
| Gao, Liu, and Peng's algorithm revolves around dynamically maintaining the augmenting electrical flows at the core of the interior point method based algorithm from [Mądry JACM ‘16]. This entails designing data structures that, in limited settings, return edges with large electric energy in a graph undergoing resistance updates.
| गाओ, लियू, और पेंग का एल्गोरिदम [माद्री जेएसीएम '16] से आंतरिक बिंदु विधि आधारित एल्गोरिदम के मूल में बढ़ते विद्युत प्रवाह को गतिशील रूप से बनाए रखने के आसपास घूमता है। यह डेटा संरचनाओं को डिजाइन करने पर जोर देता है, जो सीमित सेटिंग्स में, प्रतिरोध अद्यतनों के दौर से गुजर रहे ग्राफ में बड़ी विद्युत ऊर्जा के साथ किनारों को लौटाते हैं।
|-
|-
| Chen, Kyng, Liu, Peng, Gutenberg and Sachdeva's algorithm<ref name="almost linear">{{Cite arXiv | last1 = Chen | first1 = L.| last2 = Kyng | first2 = R.| last3 = Liu | first3 = Y.P.| last4 = Gutenberg | first4 = M.P. | last5 = Sachdeva | first5 = S. | title = Maximum Flow and Minimum-Cost Flow in Almost-Linear Time| year = 2022| class = cs.DS| eprint = 2203.00671}}</ref>
| चेन, किंग, लियू, पेंग, गुटेनबर्ग और सचदेवा का एल्गोरिदम<ref name="almost linear">{{Cite arXiv | last1 = Chen | first1 = L.| last2 = Kyng | first2 = R.| last3 = Liu | first3 = Y.P.| last4 = Gutenberg | first4 = M.P. | last5 = Sachdeva | first5 = S. | title = Maximum Flow and Minimum-Cost Flow in Almost-Linear Time| year = 2022| class = cs.DS| eprint = 2203.00671}}</ref>
|<math>O(E^{1+o(1)} \log U)</math>
|<math>O(E^{1+o(1)} \log U)</math>
| Chen, Kyng, Liu, Peng, Gutenberg and Sachdeva's algorithm solves maximum flow and minimum-cost flow in almost linear time by building the flow through a sequence of <math>E^{1+o(1)}</math> approximate undirected minimum-ratio cycles, each of which is computed and processed in amortized <math>E^{o(1)}</math> time using a dynamic data structure.  
| चेन, किंग, लियू, पेंग, गुटेनबर्ग और सचदेवा के एल्गोरिदम प्रवाह के अनुक्रम के माध्यम से प्रवाह का निर्माण करके लगभग रैखिक समय में अधिकतम प्रवाह और न्यूनतम व्यय प्रवाह को हल करते हैं <math>E^{1+o(1)}</math> अनुमानित अप्रत्यक्ष न्यूनतम-अनुपात चक्र, जिनमें से प्रत्येक की गणना और परिशोधन में संसाधित की जाती है <math>E^{o(1)}</math> समय गतिशील डेटा संरचना का उपयोग कर.  
|}
|}
अतिरिक्त एल्गोरिदम के लिए, देखें {{harvtxt|Goldberg|Tarjan|1988}}.
अतिरिक्त एल्गोरिदम के लिए, देखें {{harvtxt|गोल्डबर्ग|टार्जन|1988}}.


== इंटीग्रल फ्लो प्रमेय ==
== इंटीग्रल फ्लो प्रमेय ==
अभिन्न प्रवाह प्रमेय कहता है कि
अभिन्न प्रवाह प्रमेय कहता है कि
: यदि प्रवाह नेटवर्क में प्रत्येक किनारे की अभिन्न क्षमता है, तो एक अभिन्न अधिकतम प्रवाह मौजूद है।
: यदि प्रवाह नेटवर्क में प्रत्येक किनारे की अभिन्न क्षमता है, तो अभिन्न अधिकतम प्रवाह उपस्थित होती है।


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


== आवेदन ==
== आवेदन ==


=== बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या ===
=== बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या ===
[[File:Multi-source multi-sink flow problem.svg|thumb|right|चित्र 4.1.1। एक बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या का एकल-स्रोत एकल-सिंक अधिकतम प्रवाह समस्या में रूपांतरण]]एक नेटवर्क दिया <math>N = (V, E)</math> सूत्रों के एक सेट के साथ <math>S = \{s_1, \ldots, s_n\}</math> और सिंक का एक सेट <math>T = \{t_1, \ldots, t_m\}</math> केवल एक स्रोत और एक सिंक के बजाय, हमें अधिकतम प्रवाह का पता लगाना है <math>N</math>. हम बहु-स्रोत बहु-सिंक समस्या को अधिकतम प्रवाह समस्या में प्रत्येक शीर्ष से जोड़ने वाले समेकित स्रोत को जोड़कर बदल सकते हैं <math>S</math> और प्रत्येक शीर्ष से जुड़ा एक समेकित सिंक <math>T</math> (सुपरसोर्स और सुपरसिंक के रूप में भी जाना जाता है) प्रत्येक किनारे पर अनंत क्षमता के साथ (चित्र देखें। 4.1.1।)।
[[File:Multi-source multi-sink flow problem.svg|thumb|right|चित्र 4.1.1। बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या का एकल-स्रोत एकल-सिंक अधिकतम प्रवाह समस्या में रूपांतरण]]नेटवर्क दिया <math>N = (V, E)</math> सूत्रों के समुच्चय के साथ <math>S = \{s_1, \ldots, s_n\}</math> और सिंक का समुच्चय <math>T = \{t_1, \ldots, t_m\}</math> केवल स्रोत और सिंक के अतिरिक्त, हमें अधिकतम <math>N</math> प्रवाह का पता लगाना है हम बहु-स्रोत बहु-सिंक समस्या को अधिकतम प्रवाह समस्या में प्रत्येक शीर्ष से जोड़ने वाले समेकित स्रोत <math>S</math> को जोड़कर बदल सकते हैं और प्रत्येक शीर्ष से जुड़ा समेकित सिंक <math>T</math> (सुपरसोर्स और सुपरसिंक के रूप में भी जाना जाता है) प्रत्येक किनारे पर अनंत क्षमता के साथ (चित्र देखें। 4.1.1।)।


=== अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान ===
=== अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान ===
[[File:Maximum bipartite matching to max flow.svg|thumb|right|चित्र 4.3.1। अधिकतम द्विदलीय मिलान समस्या का अधिकतम प्रवाह समस्या में रूपांतरण]]एक द्विदलीय ग्राफ दिया <math>G = (X \cup Y, E)</math>, हमें मिलान करने वाली अधिकतम कार्डिनैलिटी मिलनी है <math>G</math>, वह मिलान है जिसमें किनारों की सबसे बड़ी संभव संख्या होती है। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है <math>N = (X \cup Y \cup \{s,t\}, E')</math>, कहाँ
[[File:Maximum bipartite matching to max flow.svg|thumb|right|चित्र 4.3.1। अधिकतम द्विदलीय मिलान समस्या का अधिकतम प्रवाह समस्या में रूपांतरण]]द्विदलीय ग्राफ दिया <math>G = (X \cup Y, E)</math>, हमें मिलान करने वाली अधिकतम कार्डिनैलिटी <math>G</math> मिलनी है , वह मिलान है जिसमें किनारों की सबसे बड़ी संभव संख्या होती है। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है <math>N = (X \cup Y \cup \{s,t\}, E')</math>, जहाँ
# <math>E'</math> किनारों को समाहित करता है <math>G</math> से निर्देशित <math>X</math> को <math>Y</math>.
#<math>E'</math> में <math>G</math> के किनारों को <math>X</math> से <math>Y</math> तक निर्देशित किया गया है
# <math>(s,x) \in E'</math> प्रत्येक के लिए <math>x \in X</math> और <math>(y,t) \in E'</math> प्रत्येक के लिए <math>y \in Y</math>.
#<math>(s,x) \in E'</math> प्रत्येक <math>x \in X</math> के लिए और <math>(y,t) \in E'</math> प्रत्येक <math>y \in Y</math> के लिए
# <math>c(e) = 1</math> प्रत्येक के लिए <math>e \in E'</math> (चित्र देखें। 4.3.1)।
# <math>c(e) = 1</math> प्रत्येक <math>e \in E'</math> के लिए (चित्र देखें। 4.3.1)।


फिर अधिकतम प्रवाह का मान <math>N</math> में अधिकतम मिलान के आकार के बराबर है <math>G</math>, और एक अधिकतम कार्डिनैलिटी मिलान उन किनारों को लेकर पाया जा सकता है जिनमें प्रवाह होता है <math>1</math> एक अभिन्न अधिकतम प्रवाह में।
तब <math>N</math> में अधिकतम प्रवाह का मान <math>G</math> में अधिकतम मिलान के आकार के समान होता है, और अधिकतम कार्डिनैलिटी मिलान उन किनारों को ले कर पाया जा सकता है जिनके पास अभिन्न अधिकतम-प्रवाह में प्रवाह <math>1</math> है।


=== निर्देशित चक्रीय ग्राफ === में न्यूनतम पथ कवर
निर्देशित चक्रीय ग्राफ में न्यूनतम पथ कवर
एक निर्देशित विश्वकोश ग्राफ दिया <math>G = (V, E)</math>, हमें प्रत्येक शीर्ष को कवर करने के लिए [[पथ (ग्राफ सिद्धांत)]] | शीर्ष-विच्छेद पथों की न्यूनतम संख्या का पता लगाना है <math>V</math>. हम एक द्विदलीय ग्राफ का निर्माण कर सकते हैं <math>G' = (V_\textrm{out} \cup V_\textrm{in}, E')</math> से <math>G</math>, कहाँ
 
निर्देशित विश्वकोश ग्राफ दिया <math>G = (V, E)</math>, हमें प्रत्येक शीर्ष को कवर करने के लिए [[पथ (ग्राफ सिद्धांत)]] | शीर्ष-विच्छेद पथों की न्यूनतम संख्या का पता लगाना है <math>V</math>. हम द्विदलीय ग्राफ का निर्माण कर सकते हैं <math>G' = (V_\textrm{out} \cup V_\textrm{in}, E')</math> से <math>G</math>, जहाँ
# <math>V_\textrm{out} = \{ v_\textrm{out} \mid v \in V \land v \text{ has outgoing edge(s)} \}</math>
# <math>V_\textrm{out} = \{ v_\textrm{out} \mid v \in V \land v \text{ has outgoing edge(s)} \}</math>
# <math>V_\textrm{in} = \{ v_\textrm{in} \mid v \in V \land v \text{ has incoming edge(s)} \}</math>
# <math>V_\textrm{in} = \{ v_\textrm{in} \mid v \in V \land v \text{ has incoming edge(s)} \}</math>
# <math>E' = \{(u_\textrm{out}, v_\textrm{in}) \in V_{out} \times V_{in} \mid (u, v) \in E \}</math>.
# <math>E' = \{(u_\textrm{out}, v_\textrm{in}) \in V_{out} \times V_{in} \mid (u, v) \in E \}</math>.


तभी यह दिखाया जा सकता है <math>G'</math> मेल खाता है <math>M</math> आकार का <math>m</math> अगर और केवल अगर <math>G</math> वर्टेक्स-डिसजॉइंट पाथ कवर है <math>C</math> युक्त <math>m</math> किनारों और <math>n-m</math> पथ, कहाँ <math>n</math> में शीर्षों की संख्या है <math>G</math>. इसलिए, अधिकतम कार्डिनैलिटी मैचिंग का पता लगाकर समस्या को हल किया जा सकता है <math>G'</math> बजाय।
तभी यह दिखाया जा सकता है <math>G'</math> मेल खाता है <math>M</math> आकार का <math>m</math> यदि और केवल यदि <math>G</math> वर्टेक्स-डिसजॉइंट पाथ कवर है <math>C</math> युक्त <math>m</math> किनारों और <math>n-m</math> पथ, जहाँ <math>n</math> में शीर्षों की संख्या है <math>G</math>. इसलिए, अधिकतम कार्डिनैलिटी मैचिंग का पता लगाकर समस्या को हल किया जा सकता है <math>G'</math> अतिरिक्त।


मान लें कि हमें एक मिलान मिल गया है <math>M</math> का <math>G'</math>, और आवरण का निर्माण किया <math>C</math> यह से। सहज रूप से, अगर दो कोने <math>u_\mathrm{out}, v_\mathrm{in}</math> में मेल खाते हैं <math>M</math>, फिर किनारा <math>(u, v)</math> में निहित है <math>C</math>. स्पष्ट रूप से किनारों की संख्या <math>C</math> है <math>m</math>. यह देखने के लिए <math>C</math> वर्टेक्स-डिसजॉइंट है, निम्नलिखित पर विचार करें:
मान लें कि हमें मिलान मिल गया है <math>M</math> का <math>G'</math>, और आवरण का निर्माण किया <math>C</math> यह से सहज रूप से, यदि दो कोने <math>u_\mathrm{out}, v_\mathrm{in}</math> में मेल खाते हैं <math>M</math>, फिर किनारा <math>(u, v)</math> में निहित है <math>C</math>. स्पष्ट रूप से किनारों की संख्या <math>C</math> है <math>m</math>. यह देखने के लिए <math>C</math> वर्टेक्स-डिसजॉइंट है, निम्नलिखित पर विचार करें:
# प्रत्येक शीर्ष <math>v_\textrm{out}</math> में <math>G'</math> या तो में बेमेल हो सकता है <math>M</math>, जिस स्थिति में कोई किनारा नहीं बचता है <math>v</math> में <math>C</math>; या इसका मिलान किया जा सकता है, जिस स्थिति में ठीक एक किनारा बचता है <math>v</math> में <math>C</math>. किसी भी मामले में, एक किनारे से अधिक कोई शीर्ष नहीं छोड़ता है <math>v</math> में <math>C</math>.
# प्रत्येक शीर्ष <math>v_\textrm{out}</math> में <math>G'</math> या तो में बेमेल हो सकता है <math>M</math>, जिस स्थिति में कोई किनारा नहीं बचता है <math>v</math> में <math>C</math>; या इसका मिलान किया जा सकता है, जिस स्थिति में ठीक किनारा बचता है <math>v</math> में <math>C</math>. किसी भी स्थिति में, किनारे से अधिक कोई शीर्ष नहीं छोड़ता है  
# इसी प्रकार प्रत्येक शीर्ष के लिए <math>v_\textrm{in}</math> में <math>G'</math> - यदि इसका मिलान किया जाता है, तो इसमें एक आने वाला किनारा होता है <math>v</math> में <math>C</math>; अन्यथा <math>v</math> में कोई आने वाला किनारा नहीं है <math>C</math>.
# इसी प्रकार प्रत्येक शीर्ष के लिए <math>v_\textrm{in}</math> में <math>G'</math> - यदि इसका मिलान किया जाता है, तो इसमें आने वाला किनारा होता है <math>v</math> में <math>C</math>; अन्यथा <math>v</math> में कोई आने वाला किनारा <math>C</math> नहीं है .
इस प्रकार किसी भी शीर्ष में दो आने वाले या दो बाहर जाने वाले किनारे नहीं होते हैं <math>C</math>, जिसका अर्थ है सभी रास्ते अंदर <math>C</math> वर्टेक्स-डिसजॉइंट हैं।
इस प्रकार किसी भी शीर्ष में दो आने वाले या दो बाहर जाने वाले किनारे <math>C</math> नहीं होते हैं , जिसका अर्थ है सभी रास्ते अंदर <math>C</math> वर्टेक्स-डिसजॉइंट हैं।


यह दिखाने के लिए कि कवर <math>C</math> आकार है <math>n-m</math>, हम एक खाली कवर से शुरू करते हैं और इसे वृद्धिशील रूप से बनाते हैं। एक शिखर जोड़ने के लिए <math>u</math> कवर में, हम इसे या तो मौजूदा पथ में जोड़ सकते हैं, या उस शीर्ष पर शुरू होने वाली लंबाई शून्य का नया पथ बना सकते हैं। पूर्व का मामला जब भी लागू होता है <math>(u,v) \in E</math> और कवर में कुछ रास्ता शुरू होता है <math>v</math>, या <math>(v,u) \in E</math> और कुछ पथ पर समाप्त होता है <math>v</math>. बाद वाला मामला हमेशा लागू होता है। पूर्व मामले में, कवर में किनारों की कुल संख्या 1 से बढ़ जाती है और पथों की संख्या समान रहती है; बाद वाले मामले में रास्तों की संख्या बढ़ जाती है और किनारों की संख्या वही रहती है। अब यह स्पष्ट हो गया है कि सभी को कवर करने के बाद <math>n</math> शिखर, आवरण में पथों और किनारों की संख्या का योग है <math>n</math>. इसलिए, यदि कवर में किनारों की संख्या है <math>m</math>, पथों की संख्या है <math>n-m</math>.
यह दिखाने के लिए कि कवर <math>C</math> आकार है <math>n-m</math>, हम खाली कवर से प्रारंभिक करते हैं और इसे वृद्धिशील रूप से बनाते हैं। शिखर जोड़ने के लिए <math>u</math> कवर में, हम इसे या तो उपस्थिता पथ में जोड़ सकते हैं, या उस शीर्ष पर प्रारंभिक होने वाली लंबाई शून्य का नया पथ बना सकते हैं। पूर्व का स्थिति जब भी प्रयुक्त होता है <math>(u,v) \in E</math> और कवर में कुछ रास्ता प्रारंभिक होता है <math>v</math>, या <math>(v,u) \in E</math> और कुछ पथ पर समाप्त होता है <math>v</math>. बाद वाला स्थिति सदैव प्रयुक्त होता है। पूर्व स्थिति में, कवर में किनारों की कुल संख्या 1 से बढ़ जाती है और पथों की संख्या समान रहती है; बाद वाले स्थिति में रास्तों की संख्या बढ़ जाती है और किनारों की संख्या वही रहती है। अब यह स्पष्ट हो गया है कि सभी को कवर करने के बाद <math>n</math> शिखर, आवरण में पथों और किनारों की संख्या का योग है <math>n</math>. इसलिए, यदि कवर में किनारों की संख्या <math>m</math> है , पथों की संख्या <math>n-m</math> है .


=== शीर्ष क्षमता के साथ अधिकतम प्रवाह ===
=== शीर्ष क्षमता के साथ अधिकतम प्रवाह ===
[[File:Node splitting.svg|thumb|right|चित्र 4.4.1। नोड विभाजन द्वारा मूल अधिकतम प्रवाह समस्या में वर्टेक्स क्षमता बाधा के साथ अधिकतम प्रवाह समस्या का परिवर्तन]]होने देना <math>N = (V, E)</math> एक नेटवर्क हो। मान लीजिए कि बढ़त क्षमता के अलावा प्रत्येक नोड पर क्षमता है, यानी मैपिंग <math>c: V\to \R^+,</math> ऐसा कि प्रवाह <math>f</math> न केवल क्षमता की कमी और प्रवाह के संरक्षण को पूरा करना है, बल्कि वर्टेक्स क्षमता की कमी को भी पूरा करना है
[[File:Node splitting.svg|thumb|right|चित्र 4.4.1। नोड विभाजन द्वारा मूल अधिकतम प्रवाह समस्या में वर्टेक्स क्षमता बाधा के साथ अधिकतम प्रवाह समस्या का परिवर्तन]]माना <math>N = (V, E)</math> नेटवर्क हो। मान लीजिए कि बढ़त क्षमता के अतिरिक्त प्रत्येक नोड पर क्षमता है, अर्थात मैपिंग <math>c: V\to \R^+,</math> ऐसा कि प्रवाह <math>f</math> न केवल क्षमता की कमी और प्रवाह के संरक्षण को पूरा करना है, किन्तु वर्टेक्स क्षमता की कमी को भी पूरा करना है


:<math> \sum_{i\in V} f_{iv} \le c(v) \qquad \forall v \in V \backslash \{s,t\}.</math>
:<math> \sum_{i\in V} f_{iv} \le c(v) \qquad \forall v \in V \backslash \{s,t\}.</math>
दूसरे शब्दों में, शीर्ष से गुजरने वाले प्रवाह की मात्रा इसकी क्षमता से अधिक नहीं हो सकती। अधिकतम प्रवाह खोजने के लिए <math>N</math>, हम विस्तार करके समस्या को मूल अर्थ में अधिकतम प्रवाह समस्या में बदल सकते हैं <math>N</math>. सबसे पहले, प्रत्येक <math>v\in V</math> द्वारा प्रतिस्थापित किया जाता है <math>v_{\text{in}}</math> और <math>v_{\text{out}}</math>, कहाँ <math>v_{\text{in}}</math> में जाकर किनारों से जुड़ा है <math>v</math> और <math>v_{\text{out}}</math> से निकलने वाले किनारों से जुड़ा है <math>v</math>, फिर क्षमता असाइन करें <math>c(v)</math> किनारे से जोड़ने के लिए <math>v_{\text{in}}</math> और <math>v_{\text{out}}</math> (चित्र देखें। 4.4.1)। इस विस्तारित नेटवर्क में, वर्टेक्स क्षमता की कमी को हटा दिया जाता है और इसलिए समस्या को मूल अधिकतम प्रवाह समस्या के रूप में माना जा सकता है।
दूसरे शब्दों में, शीर्ष से निकलने वाले प्रवाह की मात्रा इसकी क्षमता से अधिक नहीं हो सकती। अधिकतम प्रवाह खोजने के लिए <math>N</math>, हम विस्तार करके समस्या को मूल अर्थ में अधिकतम प्रवाह समस्या <math>N</math> में बदल सकते हैं . सबसे पहले, प्रत्येक <math>v\in V</math> द्वारा प्रतिस्थापित किया जाता है <math>v_{\text{in}}</math> और <math>v_{\text{out}}</math>, जहाँ <math>v_{\text{in}}</math> में जाकर किनारों से जुड़ा है <math>v</math> और <math>v_{\text{out}}</math> से निकलने वाले किनारों से जुड़ा है <math>v</math>, फिर क्षमता असाइन करें <math>c(v)</math> किनारे से जोड़ने के लिए <math>v_{\text{in}}</math> और <math>v_{\text{out}}</math> (चित्र देखें। 4.4.1)। इस विस्तारित नेटवर्क में, वर्टेक्स क्षमता की कमी को हटा दिया जाता है और इसलिए समस्या को मूल अधिकतम प्रवाह समस्या के रूप में माना जा सकता है।


=== s से t === तक पथों की अधिकतम संख्या
==== s से t तक पथों की अधिकतम संख्या ====
एक निर्देशित ग्राफ दिया <math>G = (V, E)</math> और दो शिखर <math>s</math> और <math>t</math>, हमें पथों की अधिकतम संख्या ज्ञात करनी है <math>s</math> को <math>t</math>. इस समस्या के कई रूप हैं:
निर्देशित ग्राफ दिया <math>G = (V, E)</math> और दो शिखर <math>s</math> और <math>t</math>, हमें पथों की अधिकतम संख्या ज्ञात करनी है <math>s</math> को <math>t</math>. इस समस्या के कई रूप हैं:


1. पथ एज-डिसजॉइंट होने चाहिए। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है <math>N = (V, E)</math> से <math>G</math>, साथ <math>s</math> और <math>t</math> स्रोत और सिंक होने के नाते <math>N</math> क्रमशः, और प्रत्येक किनारे की क्षमता निर्दिष्ट करना <math>1</math>. इस नेटवर्क में अधिकतम प्रवाह है <math>k</math> अगर हैं <math>k</math> किनारे-अलग रास्ते।
1. पथ एज-डिसजॉइंट होने चाहिए। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है <math>N = (V, E)</math> से <math>G</math>, साथ <math>s</math> और <math>t</math> स्रोत और सिंक होने के नाते <math>N</math> क्रमशः, और प्रत्येक किनारे की क्षमता निर्दिष्ट करना <math>1</math>. इस नेटवर्क में अधिकतम प्रवाह है <math>k</math> यदि हैं <math>k</math> किनारे-अलग रास्ते होते है।


2. पथ स्वतंत्र होने चाहिए, अर्थात, वर्टेक्स-डिसजॉइंट (को छोड़कर) <math>s</math> और <math>t</math>). हम एक नेटवर्क बना सकते हैं <math>N = (V, E)</math> से <math>G</math> वर्टेक्स कैपेसिटी के साथ, जहां सभी वर्टिकल और सभी एज की कैपेसिटी होती है <math>1</math>. तब अधिकतम प्रवाह का मान स्वतंत्र पथों की अधिकतम संख्या के बराबर होता है <math>s</math> को <math>t</math>.
2. पथ स्वतंत्र होने चाहिए, अर्थात, वर्टेक्स-डिसजॉइंट (को छोड़कर) <math>s</math> और <math>t</math>). हम नेटवर्क बना सकते हैं इस प्रकार <math>N = (V, E)</math> से <math>G</math> वर्टेक्स योग्यता के साथ, जहां सभी वर्टिकल और सभी एज की योग्यता होती है <math>1</math>. तब अधिकतम प्रवाह का मान स्वतंत्र पथों की अधिकतम संख्या <math>s</math> को <math>t</math>. के समान होता है
 
3. पथों के किनारे-विच्छेद और/या शीर्ष असंयुक्त होने के अलावा, पथों में लंबाई की बाधा भी होती है: हम केवल उन पथों की गणना करते हैं जिनकी लंबाई ठीक है <math>k</math>, या अधिक से अधिक <math>k</math>. के छोटे मूल्यों को छोड़कर, इस समस्या के अधिकांश रूप एनपी-पूर्ण हैं <math>k</math>.<ref>{{Cite journal|last1=Itai|first1=A.|last2=Perl|first2=Y.|last3=Shiloach|first3=Y.|year=1982|title=लंबाई की कमी के साथ अधिकतम असम्बद्ध पथ खोजने की जटिलता|journal=Networks|language=en|volume=12|issue=3|pages=277–286|doi=10.1002/net.3230120306|issn=1097-0037}}</ref>


3. पथों के किनारे-विच्छेद और/या शीर्ष असंयुक्त होने के अतिरिक्त , पथों में लंबाई की बाधा भी होती है: हम केवल उन पथों की गणना करते हैं जिनकी लंबाई ठीक है <math>k</math>, या अधिक से अधिक <math>k</math>. के छोटे मूल्यों को छोड़कर, इस समस्या <math>k</math> के अधिकांश रूप एनपी-पूर्ण हैं .<ref>{{Cite journal|last1=Itai|first1=A.|last2=Perl|first2=Y.|last3=Shiloach|first3=Y.|year=1982|title=लंबाई की कमी के साथ अधिकतम असम्बद्ध पथ खोजने की जटिलता|journal=Networks|language=en|volume=12|issue=3|pages=277–286|doi=10.1002/net.3230120306|issn=1097-0037}}</ref>
=== बंद करने की समस्या ===
मुख्य लेख: बंद करने की समस्या


=== बंद करने की समस्या ===
निर्देशित ग्राफ़ का बंद होना 'सी' वर्टिकल का समुच्चय है, जैसे कोई किनारा ''सी'' नहीं छोड़ता है। क्लोजर प्रॉब्लम वर्टेक्स-वेटेड डायरेक्टेड ग्राफ में अधिकतम-वेट या न्यूनतम-वेट क्लोजर खोजने का कार्य है। अधिकतम प्रवाह समस्या में कमी का उपयोग करके इसे बहुपद समय में हल किया जा सकता है।
{{Main|Closure problem}}
एक निर्देशित ग्राफ़ का बंद होना 'सी' वर्टिकल का एक सेट है, जैसे कोई किनारा ''सी'' नहीं छोड़ता है। क्लोजर प्रॉब्लम वर्टेक्स-वेटेड डायरेक्टेड ग्राफ में अधिकतम-वेट या न्यूनतम-वेट क्लोजर खोजने का कार्य है। अधिकतम प्रवाह समस्या में कमी का उपयोग करके इसे बहुपद समय में हल किया जा सकता है।


== वास्तविक विश्व अनुप्रयोग ==
== वास्तविक विश्व अनुप्रयोग ==


=== बेसबॉल उन्मूलन ===
=== बेसबॉल उन्मूलन ===
[[File:Baseball Elimination Problem.png|thumb|बेसबॉल उन्मूलन समस्या के लिए नेटवर्क प्रवाह का निर्माण]][[बेसबॉल]] उन्मूलन समस्या में एक लीग में प्रतिस्पर्धा करने वाली n टीमें हैं। लीग सीज़न के एक विशिष्ट चरण में, w<sub>''i''</sub> जीत और आर की संख्या है<sub>''i''</sub> टीम I और r के लिए खेले जाने वाले खेलों की संख्या है<sub>ij</sub> टीम j के विरुद्ध बचे हुए खेलों की संख्या है। एक टीम का सफाया कर दिया जाता है अगर उसके पास सीजन को पहले स्थान पर खत्म करने का कोई मौका नहीं है। बेसबॉल उन्मूलन समस्या का कार्य यह निर्धारित करना है कि सीजन के दौरान प्रत्येक बिंदु पर कौन सी टीम समाप्त हो जाती है। श्वार्ट्ज<ref>{{Cite journal | last1 = Schwartz | first1 = B. L. | title = आंशिक रूप से पूर्ण टूर्नामेंट में संभावित विजेता| doi = 10.1137/1008062 | journal = [[SIAM Review]]| jstor = 2028206| volume = 8 | issue = 3 | pages = 302–308 | year = 1966 | bibcode = 1966SIAMR...8..302S }}</ref> एक तरीका प्रस्तावित किया जो इस समस्या को अधिकतम नेटवर्क प्रवाह तक कम कर देता है। इस पद्धति में यह निर्धारित करने के लिए एक नेटवर्क बनाया जाता है कि टीम k समाप्त हो गई है या नहीं।
[[File:Baseball Elimination Problem.png|thumb|बेसबॉल उन्मूलन समस्या के लिए नेटवर्क प्रवाह का निर्माण]][[बेसबॉल]] उन्मूलन समस्या में लीग में प्रतिस्पर्धा करने वाली n टीमें हैं। लीग सीज़न के विशिष्ट चरण में, w<sub>''i''</sub> जीत और आर की संख्या है टीम और ''r''<sub>ij</sub>के लिए खेले जाने वाले खेलों की संख्या है टीम ''r''<sub>ij</sub> के विरुद्ध बचे हुए खेलों की संख्या है। टीम का सफाया कर दिया जाता है यदि उसके पास सीजन को पहले स्थान पर खत्म करने का कोई मौका नहीं है। बेसबॉल उन्मूलन समस्या का कार्य यह निर्धारित करना है कि सीजन के समय प्रत्येक बिंदु पर कौन सी टीम समाप्त हो जाती है। श्वार्ट्ज<ref>{{Cite journal | last1 = Schwartz | first1 = B. L. | title = आंशिक रूप से पूर्ण टूर्नामेंट में संभावित विजेता| doi = 10.1137/1008062 | journal = [[SIAM Review]]| jstor = 2028206| volume = 8 | issue = 3 | pages = 302–308 | year = 1966 | bibcode = 1966SIAMR...8..302S }}</ref> विधि प्रस्तावित किया जो इस समस्या को अधिकतम नेटवर्क प्रवाह तक कम कर देता है। इस पद्धति में यह निर्धारित करने के लिए नेटवर्क बनाया जाता है कि टीम k समाप्त हो गई है या नहीं।
 
मान लीजिए G = (V, E) एक नेटवर्क है जिसमें s,t ∈ V क्रमशः स्रोत और सिंक है। एक गेम नोडीज जोड़ता है - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है। हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड {i, j} को i <j से V तक जोड़ते हैं, और उनमें से प्रत्येक को क्षमता ''r<sub>ij</sub>'' के साथ किनारे से जोड़ते हैं - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है . हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड {i, j} को दो टीम नोड्स i और j से जोड़ते हैं जिससे उनमें से एक जीत सुनिश्चित हो सकता है । इन किनारों पर प्रवाह मान को सीमित करने की आवश्यकता नहीं है। अंत में किनारों को टीम नोड i से सिंक नोड ''t'' तक बनाया जाता है और टीम i को {{math|''w''<sub>''k''</sub> + ''r''<sub>''k''</sub>}} से अधिक जीतने से रोकने के लिए {{math|''w''<sub>''k''</sub> + ''r''<sub>''k''</sub> – ''w''<sub>''i''</sub>}} की क्षमता निर्धारित की जाती है।


चलो जी = (वी, ई) के साथ एक नेटवर्क बनें {{math|''s'',''t'' ∈ ''V''}} क्रमशः स्रोत और सिंक है। एक गेम नोड जोड़ता है<sub>''ij''</sub> - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है। हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड को कनेक्ट करते हैं {{math|{{mset|''i'', ''j''}}}} i <j से V तक, और उनमें से प्रत्येक को क्षमता r के किनारे से s से जोड़ता है<sub>''ij''</sub> - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है। हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड को कनेक्ट करते हैं {{math|{{mset|''i'', ''j''}}}} दो टीम नोड्स i और j के साथ यह सुनिश्चित करने के लिए कि उनमें से एक जीतता है। इन किनारों पर प्रवाह मान को सीमित करने की आवश्यकता नहीं है। अंत में, किनारों को टीम नोड i से सिंक नोड टी और की क्षमता से बनाया जाता है {{math|''w''<sub>''k''</sub> + ''r''<sub>''k''</sub> – ''w''<sub>''i''</sub>}} टीम i को इससे अधिक जीतने से रोकने के लिए सेट है {{math|''w''<sub>''k''</sub> + ''r''<sub>''k''</sub>}}.
मान लीजिए S लीग में भाग लेने वाली सभी टीमों का समुच्चय है और मान लीजिए
मान लीजिए S लीग में भाग लेने वाली सभी टीमों का समुच्चय है और मान लीजिए
:<math>r(S - \{k\}) = \sum_{i,j \in \{S-\{k\}\} \atop i < j} r_{ij}</math>.
:<math>r(S - \{k\}) = \sum_{i,j \in \{S-\{k\}\} \atop i < j} r_{ij}</math>.
इस पद्धति में यह दावा किया जाता है कि टीम k को समाप्त नहीं किया जाता है यदि और केवल यदि आकार r(S - {k}) का प्रवाह मान नेटवर्क G में मौजूद है। उल्लिखित लेख में यह सिद्ध किया गया है कि यह प्रवाह मान से अधिकतम प्रवाह मान है एस से टी।
इस पद्धति में यह प्रमाणित किया जाता है कि टीम k को समाप्त नहीं किया जाता है यदि और केवल यदि आकार r(S - {k}) का प्रवाह मान नेटवर्क G में उपस्थित है। उल्लिखित लेख में यह सिद्ध किया गया है कि यह प्रवाह मान से अधिकतम प्रवाह मान है।


=== एयरलाइन शेड्यूलिंग ===
=== विमान सेवा समय-निर्धारण ===
एयरलाइन उद्योग में एक बड़ी समस्या उड़ान कर्मचारियों के समय-निर्धारण की है। एयरलाइन शेड्यूलिंग समस्या को विस्तारित अधिकतम नेटवर्क प्रवाह के अनुप्रयोग के रूप में माना जा सकता है। इस समस्या का इनपुट फ़्लाइट F का एक सेट है जिसमें यह जानकारी होती है कि प्रत्येक फ़्लाइट कहाँ और कब प्रस्थान करती है और कब आती है। एयरलाइन शेड्यूलिंग के एक संस्करण में लक्ष्य अधिकतम k कर्मचारियों के साथ व्यवहार्य शेड्यूल तैयार करना है।
विमान सेवा उद्योग में बड़ी समस्या उड़ान कर्मचारियों के समय-निर्धारण किया गया है। और विमान सेवा समय समस्या को विस्तारित अधिकतम नेटवर्क प्रवाह के अनुप्रयोग के रूप में माना जा सकता है। इस समस्या का इनपुट विमान ''F'' का समुच्चय है जिसमें यह जानकारी होती है कि प्रत्येक विमान कहाँ और कब प्रस्थान करती है और कब आती है। विमान सेवा समय के संस्करण में लक्ष्य अधिकतम ''k'' कर्मचारियों के साथ व्यवहार्य समय तैयार करना है।


इस समस्या को हल करने के लिए परिबद्ध संचलन नामक संचलन समस्या की एक भिन्नता का उपयोग किया जाता है जो प्रवाह नेटवर्क समस्याओं का सामान्यीकरण है, किनारे प्रवाह पर निचली सीमा के अतिरिक्त बाधा के साथ।
इस समस्या को हल करने के लिए परिबद्ध संचलन नामक संचलन समस्या की भिन्नता का उपयोग किया जाता है जोकी प्रवाह नेटवर्क समस्याओं का सामान्यीकरण है, किनारे प्रवाह पर निचली सीमा के अतिरिक्त प्रतिबंध किया है ।


चलो जी = (वी, ) के साथ एक नेटवर्क बनें {{math|''s'',''t'' ∈ ''V''}} स्रोत और सिंक नोड्स के रूप में। प्रत्येक उड़ान i के स्रोत और गंतव्य के लिए, V, नोड s में दो नोड जोड़ता है<sub>''i''</sub> स्रोत और नोड डी के रूप में<sub>''i''</sub> उड़ान के गंतव्य नोड के रूप में i. E में निम्नलिखित किनारों को भी जोड़ा जाता है:
''G'' = (''V'', ''E'') स्रोत और सिंक नोड्स के रूप में {{math|''s'',''t'' ∈ ''V''}} के साथ एक नेटवर्क बनें। प्रत्येक उड़ान ''i'' के स्रोत और गंतव्य के लिए, ''V'' में दो नोड जोड़े जाते हैं, नोड ''s<sub>i</sub>'' स्रोत के रूप में और नोड ''d<sub>i</sub>'' उड़ान के गंतव्य नोड के रूप में ''i,'' ''E'' में निम्नलिखित किनारों को भी जोड़ा जाता है:
# एस और प्रत्येक एस के बीच क्षमता [0, 1] वाला किनारा<sub>''i''</sub>.
# ''s'' और प्रत्येक ''s<sub>i</sub>'' के बीच क्षमता [0, 1] वाला किनारा
# प्रत्येक डी के बीच क्षमता [0, 1] वाला किनारा<sub>''i''</sub> और टी।
#E' में G के किनारों को X से a तक निर्देशित किया गया है
# एस की प्रत्येक जोड़ी के बीच क्षमता [1, 1] वाला किनारा<sub>''i''</sub> और डी<sub>''i''</sub>.
# प्रत्येक ''d<sub>i</sub>'' के बीच क्षमता [0, 1] वाला किनारा और ''t''
# प्रत्येक डी के बीच क्षमता [0, 1] वाला किनारा<sub>''i''</sub> और एस<sub>''j''</sub>, अगर स्रोत एस<sub>''j''</sub> उड़ान के गंतव्य i से उचित समय और लागत के साथ पहुंच योग्य है।
#''s<sub>i</sub>'' और ''d<sub>i</sub>'' की प्रत्येक जोड़ी के बीच क्षमता [1, 1] वाला किनारा।
# एस और टी के बीच क्षमता [0, ∞] वाला किनारा।
#प्रत्येक ''d<sub>i</sub>'' और ''s<sub>j</sub>'' के बीच क्षमता [0, 1] के साथ एक किनारा, यदि स्रोत ''s<sub>j</sub>'' उड़ान के गंतव्य i से उचित समय और व्यय के साथ पहुंच योग्य है।
# ''s'' और ''t'' के बीच क्षमता [0, ∞] वाला किनारा।


उल्लिखित विधि में, यह दावा किया गया है और सिद्ध किया गया है कि एस और टी के बीच जी में के के प्रवाह मूल्य का पता लगाना अधिकतम के कर्मचारियों के साथ उड़ान सेट एफ के लिए एक व्यवहार्य कार्यक्रम खोजने के बराबर है।<ref name="ITA">{{cite book | author = [[Thomas H. Cormen]], [[Charles E. Leiserson]], [[Ronald L. Rivest]], and [[Clifford Stein]] | title=एल्गोरिदम का परिचय, दूसरा संस्करण| chapter = 26. Maximum Flow | year = 2001 | publisher = MIT Press and McGraw-Hill | isbn = 978-0-262-03293-3 | pages=643–668| title-link=Introduction to Algorithms }}</ref>
उल्लिखित विधि में, यह प्रमाणित किया गया है और सिद्ध किया गया है कि ''s'' और ''t'' के बीच G में k के प्रवाह मूल्य का पता लगाना अधिकतम k कर्मचारियों के साथ उड़ान समुच्चय F के लिए व्यवहार्य कार्यक्रम खोजने के समान है।<ref name="ITA">{{cite book | author = [[Thomas H. Cormen]], [[Charles E. Leiserson]], [[Ronald L. Rivest]], and [[Clifford Stein]] | title=एल्गोरिदम का परिचय, दूसरा संस्करण| chapter = 26. Maximum Flow | year = 2001 | publisher = MIT Press and McGraw-Hill | isbn = 978-0-262-03293-3 | pages=643–668| title-link=Introduction to Algorithms }}</ref>
एयरलाइन शेड्यूलिंग का एक अन्य संस्करण सभी उड़ानों को निष्पादित करने के लिए न्यूनतम आवश्यक कर्मचारियों की तलाश कर रहा है। इस समस्या का उत्तर खोजने के लिए, एक द्विदलीय ग्राफ {{math|1={{var|G'}} = (''A'' ∪ ''B'', ''E'')}} वहाँ बनाया जाता है जहाँ प्रत्येक उड़ान की सेट A और सेट B में एक प्रति होती है। यदि वही विमान उड़ान i के बाद उड़ान j निष्पादित कर सकता है, {{math|''i''∈''A''}} से जुड़ा है {{math|''j''∈''B''}}. में मेल खाता है {{mvar|G'}} एफ के लिए एक शेड्यूल को प्रेरित करता है और स्पष्ट रूप से इस ग्राफ में अधिकतम द्विपक्षीय मिलान कर्मचारियों की न्यूनतम संख्या के साथ एक एयरलाइन शेड्यूल तैयार करता है।<ref name="ITA"/>जैसा कि इस लेख के अनुप्रयोग भाग में बताया गया है, अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान अधिकतम प्रवाह समस्या का एक अनुप्रयोग है।
 
विमान सेवा समय का अन्य संस्करण सभी उड़ानों को निष्पादित करने के लिए न्यूनतम आवश्यक कर्मचारियों की खोज कर रहा है। इस समस्या का उत्तर खोजने के लिए, द्विदलीय ग्राफ <var>G'</var> = (''A'' ∪ ''B'', ''E'') वहाँ बनाया जाता है। जहाँ प्रत्येक उड़ान की समुच्चय A और समुच्चय B में प्रति होती है। यदि वही विमान उड़ान ''i'' के बाद उड़ान ''j'' निष्पादित कर सकता है, i∈A j∈B से जुड़ा है। G' में मेल खाता है ''F'' के लिए समय को प्रेरित करता है और स्पष्ट रूप से इस ग्राफ में अधिकतम द्विपक्षीय मिलान कर्मचारियों की न्यूनतम संख्या के साथ विमान सेवा समय तैयार करता है।<ref name="ITA" /> जैसा कि इस लेख के अनुप्रयोग भाग में बताया गया है, अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान अधिकतम प्रवाह समस्या का अनुप्रयोग है।


=== परिसंचरण-मांग समस्या ===
=== परिसंचरण-मांग समस्या ===
कुछ कारखाने हैं जो माल का उत्पादन करते हैं और कुछ गाँव जहाँ माल पहुँचाना होता है। वे सड़कों के एक नेटवर्क से जुड़े हुए हैं जिनमें प्रत्येक सड़क की क्षमता है {{mvar|c}} अधिकतम माल के लिए जो इसके माध्यम से बह सकता है। समस्या यह पता लगाने की है कि क्या कोई संचलन है जो मांग को पूरा करता है।
कुछ कारखाने हैं जो माल का उत्पादन करते हैं और कुछ गाँव जहाँ माल पहुँचाना होता है। वे सड़कों के नेटवर्क से जुड़े हुए हैं जिनमें प्रत्येक सड़क की क्षमता है अधिकतम माल {{mvar|c}} के लिए जो इसके माध्यम से बह सकता है। समस्या यह पता लगाने की है कि क्या कोई संचलन है जो मांग को पूरा करता है। यह समस्या अधिकतम-प्रवाह समस्या में परिवर्तित हो सकती है।
यह समस्या अधिकतम-प्रवाह समस्या में परिवर्तित हो सकती है।
# स्रोत नोड जोड़ें {{mvar|s}} और इसके किनारों को हर फैक्ट्री नोड में जोड़ें {{mvar|f<sub>i</sub>}} क्षमता के साथ {{mvar|p<sub>i</sub>}} जहाँ {{mvar|p<sub>i</sub>}} कारखाने {{mvar|f<sub>i</sub>}} की उत्पादन दर है .
# स्रोत नोड जोड़ें {{mvar|s}} और इसके किनारों को हर फैक्ट्री नोड में जोड़ें {{mvar|f<sub>i</sub>}} क्षमता के साथ {{mvar|p<sub>i</sub>}} कहाँ {{mvar|p<sub>i</sub>}} कारखाने की उत्पादन दर है {{mvar|f<sub>i</sub>}}.
# सिंक नोड जोड़ें {{mvar|t}} और सभी गांवों से किनारे जोड़ें {{mvar|v<sub>i</sub>}} को {{mvar|t}} क्षमता के साथ {{mvar|d<sub>i</sub>}} जहाँ {{mvar|d<sub>i</sub>}} गांव की मांग {{mvar|v<sub>i</sub>}} दर है .
# सिंक नोड जोड़ें {{mvar|t}} और सभी गांवों से किनारे जोड़ें {{mvar|v<sub>i</sub>}} को {{mvar|t}} क्षमता के साथ {{mvar|d<sub>i</sub>}} कहाँ {{mvar|d<sub>i</sub>}} गांव की मांग दर है {{mvar|v<sub>i</sub>}}.
बता दें कि जी = (वी, ई) यह नया नेटवर्क है। संचलन उपस्थित है जो मांग को संतुष्ट करता है यदि और केवल यदि:
बता दें कि जी = (वी, ई) यह नया नेटवर्क है। एक संचलन मौजूद है जो मांग को संतुष्ट करता है यदि और केवल यदि:
: {{math|Maximum flow value(''G'')}} <math> = \sum_{i \in v} d_i </math>.
: {{math|Maximum flow value(''G'')}} <math> = \sum_{i \in v} d_i </math>.
यदि कोई संचलन मौजूद है, तो अधिकतम-प्रवाह समाधान को देखने से यह उत्तर मिलेगा कि मांगों को पूरा करने के लिए किसी विशेष सड़क पर कितना माल भेजा जाना है।
यदि कोई संचलन उपस्थित है, जिससे अधिकतम-प्रवाह समाधान को देखने से यह उत्तर मिलेगा कि मांगों को पूरा करने के लिए किसी विशेष सड़क पर कितना माल भेजा जाना है।


कुछ किनारों पर प्रवाह पर निचली सीमा जोड़कर समस्या को बढ़ाया जा सकता है।<ref>{{Cite web|url=https://www.cs.cmu.edu/~ckingsf/bioinfo-lectures/flowext.pdf|title=Max-flow extensions: circulations with demands|last=Carl Kingsford}}</ref>
कुछ किनारों पर प्रवाह पर निचली सीमा जोड़कर समस्या को बढ़ाया जा सकता है।<ref>{{Cite web|url=https://www.cs.cmu.edu/~ckingsf/bioinfo-lectures/flowext.pdf|title=Max-flow extensions: circulations with demands|last=Carl Kingsford}}</ref>
=== छवि विभाजन ===
=== छवि विभाजन ===
[[File:Maxflow imagesegmentation image.png|thumb|आकार 8x8 की स्रोत छवि।|Alt=|बाएं|110x110px]]
[[File:Maxflow imagesegmentation image.png|thumb|आकार 8x8 की स्रोत छवि।|Alt=|बाएं|110x110px]]
[[File:Maxflow imagesegmentation network.png|thumb|बिटमैप से निर्मित नेटवर्क। स्रोत बाईं ओर है, सिंक दाईं ओर है। एक किनारा जितना गहरा होता है, उसकी क्षमता उतनी ही बड़ी होती है। ए<sub>i</sub> उच्च होता है जब पिक्सेल हरा होता है, b<sub>i</sub> जब पिक्सेल हरा नहीं होता है। दंड पी<sub>ij</sub> सब बराबर हैं।<ref>{{Cite web|url=https://gitlab.com/francois.schwarzentruber/imagesegmentationwithmaxflow|title=प्रोजेक्ट इमेजेजमेंटेशनविथमैक्सफ्लो, जिसमें इन दृष्टांतों को बनाने के लिए स्रोत कोड शामिल है।|website=GitLab|language=en|url-status=dead|archive-url=https://web.archive.org/web/20191222173132/https://gitlab.com/francois.schwarzentruber/imagesegmentationwithmaxflow|archive-date=2019-12-22|access-date=2019-12-22}}</ref>]]क्लेनबर्ग और टार्डोस ने अपनी पुस्तक में [[छवि विभाजन]] के लिए एक छवि के लिए एक एल्गोरिथ्म प्रस्तुत किया है।<ref>{{Cite web|url=https://www.pearson.com/us/higher-education/program/Kleinberg-Algorithm-Design/PGM319216.html |title=एल्गोरिथम डिजाइन|website=pearson.com|language=en|access-date=2019-12-21}}</ref> वे एक छवि में पृष्ठभूमि और अग्रभूमि खोजने के लिए एक एल्गोरिथ्म प्रस्तुत करते हैं। अधिक सटीक रूप से, एल्गोरिथ्म एक बिटमैप को इनपुट के रूप में निम्नानुसार लेता है: a<sub>i</sub>≥ 0 संभावना है कि पिक्सेल i अग्रभूमि से संबंधित है, b<sub>i</sub>≥ 0 इस संभावना में कि पिक्सेल i पृष्ठभूमि से संबंधित है, और p<sub>ij</sub>यदि दो सन्निकट पिक्सेल i और j एक को अग्रभूमि में और दूसरे को पृष्ठभूमि में रखा जाता है तो यह जुर्माना है। लक्ष्य निम्नलिखित मात्रा को अधिकतम करने वाले पिक्सेल के सेट के विभाजन (ए, बी) को ढूंढना है
[[File:Maxflow imagesegmentation network.png|thumb|बिटमैप से निर्मित नेटवर्क। स्रोत बाईं ओर है, सिंक दाईं ओर है। किनारा जितना गहरा होता है, उसकी क्षमता उतनी ही बड़ी होती है। ए<sub>i</sub> उच्च होता है जब पिक्सेल हरा होता है, b<sub>i</sub> जब पिक्सेल हरा नहीं होता है। दंड पी<sub>ij</sub> सब समान हैं।<ref>{{Cite web|url=https://gitlab.com/francois.schwarzentruber/imagesegmentationwithmaxflow|title=प्रोजेक्ट इमेजेजमेंटेशनविथमैक्सफ्लो, जिसमें इन दृष्टांतों को बनाने के लिए स्रोत कोड शामिल है।|website=GitLab|language=en|url-status=dead|archive-url=https://web.archive.org/web/20191222173132/https://gitlab.com/francois.schwarzentruber/imagesegmentationwithmaxflow|archive-date=2019-12-22|access-date=2019-12-22}}</ref>]]क्लेनबर्ग और टार्डोस ने अपनी पुस्तक में [[छवि विभाजन]] के लिए छवि के लिए एल्गोरिथ्म प्रस्तुत किया है।<ref>{{Cite web|url=https://www.pearson.com/us/higher-education/program/Kleinberg-Algorithm-Design/PGM319216.html |title=एल्गोरिथम डिजाइन|website=pearson.com|language=en|access-date=2019-12-21}}</ref> वे छवि में पृष्ठभूमि और अग्रभूमि खोजने के लिए एल्गोरिथ्म प्रस्तुत करते हैं। अधिक स्पष्ट रूप से, एल्गोरिथ्म बिटमैप को इनपुट के रूप में निम्नानुसार लेता है: a<sub>i</sub>≥ 0 संभावना है कि पिक्सेल i अग्रभूमि से संबंधित है, b<sub>i</sub>≥ 0 इस संभावना में कि पिक्सेल i पृष्ठभूमि से संबंधित है, और p<sub>ij</sub>यदि दो सन्निकट पिक्सेल i और j को अग्रभूमि में और दूसरे को पृष्ठभूमि में रखा जाता है तो यह जुर्माना है। लक्ष्य निम्नलिखित मात्रा को अधिकतम करने वाले पिक्सेल के समुच्चय के विभाजन (ए, बी) को ढूंढना है


:<math>q(A, B) = \sum_{i \in A} a_i + \sum_{i \in B} b_i - \sum_{\begin{matrix}i, j \text{ adjacent} \\ |A \cap \{i, j\}| = 1 \end{matrix}} p_{ij}</math>,
:<math>q(A, B) = \sum_{i \in A} a_i + \sum_{i \in B} b_i - \sum_{\begin{matrix}i, j \text{ adjacent} \\ |A \cap \{i, j\}| = 1 \end{matrix}} p_{ij}</math>,


दरअसल, में पिक्सेल के लिए (अग्रभूमि के रूप में माना जाता है), हम प्राप्त करते हैं<sub>i</sub>; बी में सभी पिक्सल के लिए (पृष्ठभूमि के रूप में माना जाता है), हम बी प्राप्त करते हैं<sub>i</sub>. सीमा पर, दो आसन्न पिक्सेल i और j के बीच, हम p को ढीला करते हैं<sub>ij</sub>. यह मात्रा को कम करने के बराबर है
दरअसल, a<sub>i</sub> में पिक्सेल के लिए (अग्रभूमि के रूप में माना जाता है), हम प्राप्त करते हैं; बी में सभी पिक्सल के लिए (पृष्ठभूमि के रूप में माना जाता है), हम b<sub>i</sub> प्राप्त करते हैं. सीमा पर, दो आसन्न पिक्सेल i और j के बीच, हम p<sub>ij</sub> को ढीला करते हैं. यह मात्रा को कम करने के समान है


:<math>q'(A, B) = \sum_{i \in A} b_i + \sum_{i \in B} a_i + \sum_{\begin{matrix}i, j \text{ adjacent} \\ |A \cap \{i, j\}| = 1 \end{matrix}} p_{ij}</math>
:<math>q'(A, B) = \sum_{i \in A} b_i + \sum_{i \in B} a_i + \sum_{\begin{matrix}i, j \text{ adjacent} \\ |A \cap \{i, j\}| = 1 \end{matrix}} p_{ij}</math>
Line 246: Line 244:
:<math>q(A, B) = \sum_{i \in A\cup B} a_i + \sum_{i \in A\cup B} b_i - q'(A, B).</math>
:<math>q(A, B) = \sum_{i \in A\cup B} a_i + \sum_{i \in A\cup B} b_i - q'(A, B).</math>


[[File:Maxflow imagesegmentation result.png|thumb|नेटवर्क पर प्रदर्शित न्यूनतम कट (त्रिकोण बनाम वृत्त)।]]अब हम उस नेटवर्क का निर्माण करते हैं जिसके नोड पिक्सेल हैं, साथ ही एक स्रोत और एक सिंक, दाईं ओर चित्र देखें। हम स्रोत को पिक्सेल i से वजन a के किनारे से जोड़ते हैं<sub>i</sub>. हम पिक्सेल i को वज़न b के किनारे से सिंक से जोड़ते हैं<sub>i</sub>. हम पिक्सेल i को पिक्सेल j से वजन p के साथ जोड़ते हैं<sub>ij</sub>. अब, यह उस नेटवर्क में न्यूनतम कटौती (या समकक्ष अधिकतम प्रवाह) की गणना करने के लिए बनी हुई है। अंतिम आंकड़ा न्यूनतम कटौती दिखाता है।
[[File:Maxflow imagesegmentation result.png|thumb|नेटवर्क पर प्रदर्शित न्यूनतम कट (त्रिकोण बनाम वृत्त)।]]अब हम उस नेटवर्क का निर्माण करते हैं जिसके नोड पिक्सेल हैं, साथ ही स्रोत और सिंक, दाईं ओर चित्र देखें। हम स्रोत को पिक्सेल i से वजन a<sub>i</sub> के किनारे से जोड़ते हैं. हम पिक्सेल i को वज़न b<sub>i</sub> के किनारे से सिंक से जोड़ते हैं. हम पिक्सेल i को पिक्सेल j से वजन p<sub>ij</sub> के साथ जोड़ते हैं. अब, यह उस नेटवर्क में न्यूनतम कटौती (या समकक्ष अधिकतम प्रवाह) की गणना करने के लिए बनी हुई है। अंतिम आंकड़ा न्यूनतम कटौती दिखाता है।


== एक्सटेंशन ==
== एक्सटेंशन ==
1. न्यूनतम-लागत प्रवाह समस्या में, प्रत्येक किनारे (''u'',v) का एक लागत-गुणांक भी होता है ''a<sub>uv</sub>इसकी क्षमता के अलावा। यदि किनारे से प्रवाह f है<sub>uv</sub>, तो कुल लागत एक है<sub>uv</sub>f<sub>uv</sub>. सबसे छोटी लागत के साथ दिए गए आकार d का प्रवाह खोजना आवश्यक है। अधिकांश प्रकारों में, लागत-गुणांक सकारात्मक या नकारात्मक हो सकते हैं। इस समस्या के लिए विभिन्न बहुपद-समय एल्गोरिदम हैं।
1. न्यूनतम-व्यय प्रवाह समस्या में, प्रत्येक किनारे (''u'',v) का व्यय-गुणांक ''a<sub>uv</sub>'' भी होता है ''इसकी क्षमता के अतिरिक्त यदि किनारे से प्रवाह f<sub>uv</sub> है, तो कुल व्यय f<sub>uv</sub> है. सबसे छोटी व्यय के साथ दिए गए आकार d का प्रवाह खोजना आवश्यक है। अधिकांश प्रकारों में, व्यय-गुणांक सकारात्मक या नकारात्मक हो सकते हैं। इस समस्या के लिए विभिन्न बहुपद-समय एल्गोरिदम हैं।''
 
2. अधिकतम-प्रवाह समस्या को 'वियोगात्मक बाधाओं' द्वारा संवर्धित किया जा सकता है: एक नकारात्मक वियोगात्मक बाधा का कहना है कि किनारों की एक निश्चित जोड़ी एक साथ गैर-शून्य प्रवाह नहीं कर सकती है; एक सकारात्मक वियोगात्मक बाधाएँ कहती हैं कि, किनारों की एक निश्चित जोड़ी में, कम से कम एक गैर-शून्य प्रवाह होना चाहिए। नकारात्मक बाधाओं के साथ, सरल नेटवर्क के लिए भी समस्या एनपी-हार्ड हो जाती है। सकारात्मक बाधाओं के साथ, यदि आंशिक प्रवाह की अनुमति दी जाती है, तो समस्या बहुपद है, लेकिन जब प्रवाह अभिन्न होना चाहिए तो यह एनपी-हार्ड हो सकता है।<ref>{{Cite journal|last1=Schauer|first1=Joachim|last2=Pferschy|first2=Ulrich|date=1 July 2013|title=असंबद्ध बाधाओं के साथ अधिकतम प्रवाह समस्या|journal=Journal of Combinatorial Optimization|language=en|volume=26|issue=1|pages=109–119|doi=10.1007/s10878-011-9438-7|issn=1382-6905|citeseerx=10.1.1.414.4496|s2cid=6598669}}</ref>
 


2. अधिकतम-प्रवाह समस्या को 'वियोगात्मक बाधाओं' द्वारा संवर्धित किया जा सकता है: नकारात्मक वियोगात्मक बाधा का कहना है कि किनारों की निश्चित जोड़ी साथ गैर-शून्य प्रवाह नहीं कर सकती है; सकारात्मक वियोगात्मक बाधाएँ कहती हैं कि, किनारों की निश्चित जोड़ी में, कम से कम गैर-शून्य प्रवाह होना चाहिए। नकारात्मक बाधाओं के साथ, सरल नेटवर्क के लिए भी समस्या एनपी-हार्ड हो जाती है। सकारात्मक बाधाओं के साथ, यदि आंशिक प्रवाह की अनुमति दी जाती है, जिससे समस्या बहुपद है, किन्तु जब प्रवाह अभिन्न होना चाहिए जिससे यह एनपी-हार्ड हो सकता है।<ref>{{Cite journal|last1=Schauer|first1=Joachim|last2=Pferschy|first2=Ulrich|date=1 July 2013|title=असंबद्ध बाधाओं के साथ अधिकतम प्रवाह समस्या|journal=Journal of Combinatorial Optimization|language=en|volume=26|issue=1|pages=109–119|doi=10.1007/s10878-011-9438-7|issn=1382-6905|citeseerx=10.1.1.414.4496|s2cid=6598669}}</ref>
== संदर्भ ==
== संदर्भ ==
{{reflist}}
{{reflist}}


==अग्रिम पठन==
==अग्रिम पठन==
Line 284: Line 279:
* {{cite book | author =  Eugene Lawler | author-link = Eugene Lawler | title = Combinatorial Optimization: Networks and Matroids | chapter = 4. Network Flows | year = 2001 | publisher = Dover | isbn = 978-0-486-41453-9 | pages = 109–177}}
* {{cite book | author =  Eugene Lawler | author-link = Eugene Lawler | title = Combinatorial Optimization: Networks and Matroids | chapter = 4. Network Flows | year = 2001 | publisher = Dover | isbn = 978-0-486-41453-9 | pages = 109–177}}


{{DEFAULTSORT:Maximum Flow Problem}}[[Category: नेटवर्क प्रवाह की समस्या]] [[Category: ग्राफ सिद्धांत में कम्प्यूटेशनल समस्याएं]]
{{DEFAULTSORT:Maximum Flow Problem}}
 
 


[[Category: Machine Translated Page]]
[[Category:CS1 British English-language sources (en-gb)]]
[[Category:Created On 31/05/2023]]
[[Category:CS1 English-language sources (en)]]
[[Category:CS1 maint]]
[[Category:Created On 31/05/2023|Maximum Flow Problem]]
[[Category:Lua-based templates|Maximum Flow Problem]]
[[Category:Machine Translated Page|Maximum Flow Problem]]
[[Category:Pages with script errors|Maximum Flow Problem]]
[[Category:Templates Vigyan Ready|Maximum Flow Problem]]
[[Category:Templates that add a tracking category|Maximum Flow Problem]]
[[Category:Templates that generate short descriptions|Maximum Flow Problem]]
[[Category:Templates using TemplateData|Maximum Flow Problem]]
[[Category:ग्राफ सिद्धांत में कम्प्यूटेशनल समस्याएं|Maximum Flow Problem]]
[[Category:नेटवर्क प्रवाह की समस्या|Maximum Flow Problem]]

Latest revision as of 09:24, 28 June 2023

Flow network for the problem: प्रत्येक मानव (री) एक बिल्ली (wi1) और/या एक कुत्ता (wi2) अपनाने को तैयार है। हालाँकि प्रत्येक पालतू जानवर (पाई) की मनुष्यों के केवल एक उपसमूह के लिए प्राथमिकता है। मनुष्यों के लिए पालतू जानवरों के किसी भी मिलान का पता लगाएं, ताकि पालतू जानवरों की अधिकतम संख्या उसके पसंदीदा मनुष्यों में से किसी एक द्वारा अपनाई जाए। थंब

अनुकूलन (गणित) में, अधिकतम प्रवाह समस्याओं में प्रवाह नेटवर्क के माध्यम से व्यवहार्य प्रवाह खोजना सम्मिलित होता है जो अधिकतम संभव प्रवाह दर प्राप्त करता है।

अधिकतम प्रवाह समस्या को संचलन समस्या जैसे अधिक जटिल नेटवर्क प्रवाह समस्याओं के विशेष स्थिति के रूप में देखा जा सकता है। एसटी प्रवाह का अधिकतम मूल्य (अर्थात, ग्राफ सिद्धांत की शब्दावली से प्रवाह दिशा s से ग्राफ़ सिद्धांत की शब्दावली दिशा t) कट (ग्राफ सिद्धांत) की न्यूनतम क्षमता के समान होती है। और एसटी कट (अर्थात, विच्छेदित एस टी से) नेटवर्क में, जैसा कि मैक्स-फ्लो मिन-कट प्रमेय में कहा गया है।

इतिहास

अधिकतम प्रवाह समस्या प्रथम बार 1954 में टेड हैरिस (गणितज्ञ) टी द्वारा तैयार की गई थी। सोवियत रेलवे यातायात प्रवाह के सरलीकृत मॉडल के रूप में ई. हैरिस और एफ.एस. रॉस है।[1][2][3]

1955 में, लेस्टर आर. फोर्ड, जूनियर और डी. आर. फुलकर्सन या डेलबर्ट आर. फुलकर्सन ने पहला ज्ञात एल्गोरिदम, फोर्ड-फुलकर्सन एल्गोरिदम बनाया गया था।[4][5] उनके 1955 के पेपर में,[4] फोर्ड और फुलकर्सन ने लिखा है कि हैरिस और रॉस की समस्या निम्नानुसार तैयार की गई है (देखें [1] पी। 5):

रेल नेटवर्क पर विचार करें जोकी दो शहरों को कई मध्यवर्ती शहरों के माध्यम से जोड़ता है, जहां नेटवर्क के प्रत्येक लिंक में नंबर दिया गया है जो इसकी क्षमता का प्रतिनिधित्व करता है। स्थिर स्थिति की स्थिति मानते हुए, दिए गए शहर से दूसरे शहर में अधिकतम प्रवाह खोजते है।

1962 में अपनी किताब फ्लोज़ इन नेटवर्क [5] में फोर्ड और फुलकर्सन ने लिखा:

यह लेखकों को 1955 के वसंत में टी. ई. हैरिस द्वारा प्रस्तुत किया गया था, जिन्होंने जनरल एफ.एस. रॉस (सेवानिवृत्त) के साथ मिलकर रेलवे यातायात प्रवाह का सरलीकृत मॉडल तैयार किया था, और इस विशेष समस्या को मॉडल द्वारा सुझाई गई केंद्रीय समस्या के रूप में इंगित किया गया था।

जहां हैरिस और रॉस द्वारा रेल नेट क्षमताओं के मूल्यांकन के लिए 1955 की गुप्त प्रतिवेदन फंडामेंटल्स ऑफ ए मेथड को संदर्भित करता है।[3] (देखना [1] पी। 5).

इन वर्षों में, अधिकतम प्रवाह समस्या के विभिन्न उन्नत समाधानों की खोज की गई थी, विशेष रूप से एडमंड्स और कार्प और स्वतंत्र रूप से डिनिट्ज़ का सबसे छोटा संवर्द्धन पथ एल्गोरिथम; डिनिट्ज़ का ब्लॉकिंग फ्लो एल्गोरिथम; पुश-रीलेबेल अधिकतम प्रवाह एल्गोरिथम या एंड्रयू वी. गोल्डबर्ग और रॉबर्ट टार्जन का पुश-रीलेबेल एल्गोरिथम; और गोल्डबर्ग और राव का बाइनरी ब्लॉकिंग फ्लो एल्गोरिथम या शर्मन के एल्गोरिदम [6] और केलनर, ली, ओरेचिया और सिडफोर्ड,[7][8] क्रमशः, लगभग इष्टतम अधिकतम प्रवाह ज्ञात करें किन्तु केवल अप्रत्यक्ष रेखांकन में काम करें।

2013 में जेम्स बी. ओर्लिन ने वर्णन करते हुए पेपर प्रकाशित किया कलन विधि है।[9]

2022 में ली चेन, रासमस किन्ग, यांग पी. लियू, रिचर्ड पेंग, मैक्सिमिलियन प्रोबस्ट गुटेनबर्ग और सुशांत सचदेवा ने लगभग-रैखिक समय एल्गोरिदम प्रकाशित किया जो चल रहा है न्यूनतम-व्यय प्रवाह समस्या के लिए जिसमें से अधिकतम प्रवाह समस्या विशेष स्थिति है।[10][11] एकल स्रोत सबसे छोटी पथ समस्या (एसएसएसपी) समस्या के लिए नकारात्मक भार के साथ न्यूनतम-व्यय प्रवाह समस्या का और विशेष स्थिति लगभग-रैखिक समय में एल्गोरिथ्म भी प्रतिवेदन किया गया है।[12][13] दोनों एल्गोरिदम को कंप्यूटर विज्ञान की नींव पर 2022 संगोष्ठी में सर्वश्रेष्ठ पेपर माना गया।[14][15]

परिभाषा

प्रवाह नेटवर्क, स्रोत एस और सिंक टी के साथ। किनारे के आगे की संख्याएँ क्षमताएँ हैं।

पहले हम कुछ अंकन स्थापित करते हैं:

  • माना वाला नेटवर्क है जो क्रमशः का स्रोत और सिंक है।
  • यदि , के किनारों पर फलन है, तो इसका मान पर या द्वारा दर्शाया जाता है

परिभाषा किनारे की क्षमता प्रवाह की अधिकतम मात्रा है जो किनारे से निकल सकती है। औपचारिक रूप से यह रुपरेखा है ।

परिभाषा प्रवाह रुपरेखा है जो निम्नलिखित को संतुष्ट करता है:

  • क्षमता प्रतिबंध किनारे का प्रवाह दूसरे शब्दों में इसकी क्षमता से अधिक नहीं हो सकता है:
  • प्रवाह का संरक्षण स्रोत और सिंक को छोड़कर, नोड में प्रवेश करने वाले प्रवाहों का योग उस नोड से बाहर निकलने वाले प्रवाहों के योग के समान होना चाहिए। या:

प्रवाह विषम सममित हैं: सभी के लिए

परिभाषा प्रवाह का मान स्रोत से सिंक तक जाने वाले प्रवाह की मात्रा है। औपचारिक रूप से प्रवाह के लिए इसके द्वारा दिया गया है:

परिभाषा अधिकतम प्रवाह समस्या स्रोत से सिंक तक जितना संभव हो उतना प्रवाह मार्ग है, दूसरे शब्दों में प्रवाह को अधिकतम मूल्य के साथ खोजते है।

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

एल्गोरिदम

निम्न तालिका अधिकतम प्रवाह समस्या को हल करने के लिए एल्गोरिदम सूचीबद्ध करती है। यहाँ, और नेटवर्क के कोने और किनारों की संख्या को निरूपित करें। मूल्य सभी क्षमताओं को पूर्णांक मानों में बदलने के बाद सबसे बड़ी धार क्षमता को संदर्भित करता है (यदि नेटवर्क में अपरिमेय संख्या क्षमताएं हैं, अनंत हो सकता है)।

विधि जटिलता विवरण
लीनियर प्रोग्रामिंग वैधानिक प्रवाह की परिभाषा द्वारा दी गई बाधाएं। यहां रैखिक कार्यक्रम देखें।
फोर्ड-फुलकर्सन एल्गोरिथम जब तक अवशिष्ट ग्राफ के माध्यम से खुला मार्ग है, उस पथ पर न्यूनतम अवशिष्ट क्षमता भेजें।
एडमंड्स-कार्प एल्गोरिथम फोर्ड-फुलकर्सन की विशेषज्ञता, चौड़ाई-प्रथम खोज के साथ संवर्द्धित पथ ढूँढना।
डिनिक का एल्गोरिदम प्रत्येक चरण में एल्गोरिदम अवशिष्ट ग्राफ पर चौड़ाई-पहली खोज के साथ स्तरित ग्राफ बनाता है। स्तरित ग्राफ में अधिकतम प्रवाह की गणना की जा सकती है समय, और चरणों की अधिकतम संख्या है . इकाई क्षमता वाले नेटवर्क में, डिनिक का एल्गोरिदम में समाप्त होता है समय.
एमकेएम (मल्होत्रा, कुमार, माहेश्वरी) एल्गोरिथम[16] अवरुद्ध प्रवाह के निर्माण के लिए अलग दृष्टिकोण के साथ डिनिक का संदेश का संशोधन। मूल पेपर का संदर्भ लें।
डिनिक का एल्गोरिदम गतिशील वृक्षों के साथ डायनेमिक ट्री डेटा संरचना स्तरित ग्राफ़ में अधिकतम प्रवाह संगणना को गति देती है .
सामान्य पुश-रिलेबल एल्गोरिथम[17] पुश रीलेबल एल्गोरिथम प्रीफ्लो बनाए रखता है, अर्थात वर्टिकल में अधिकता की संभावना के साथ फ्लो फलन या एल्गोरिथम तब चलता है जब धनात्मक आधिक्य वाला शीर्ष होता है, अर्थात ग्राफ़ में सक्रिय शीर्ष। पुश ऑपरेशन अवशिष्ट किनारे पर प्रवाह को बढ़ाता है, और शीर्षों पर ऊंचाई फलन नियंत्रित करता है जिसके माध्यम से अवशिष्ट किनारों को प्रवाहित किया जा सकता है। ऊंचाई फलन को रीलेबल ऑपरेशन द्वारा बदल दिया जाता है। इन परिचालनों की उचित परिभाषाएं आश्वासन देती हैं कि परिणामी प्रवाह फलन अधिकतम प्रवाह है।
फीफो शीर्ष चयन नियम के साथ पुश-रीलेबल एल्गोरिथम[17] पुश-रीलेबल एल्गोरिथम वैरिएंट जो सदैव सबसे वर्तमान में सक्रिय वर्टेक्स का चयन करता है और पुश ऑपरेशंस करता है जबकि अतिरिक्त सकारात्मक होता है और इस वर्टेक्स से स्वीकार्य अवशिष्ट किनारे होते हैं।
अधिकतम दूरी वर्टेक्स चयन नियम के साथ पुश-रीलेबल एल्गोरिथम[18] पुश-रीलेबल एल्गोरिथम वैरिएंट जो सदैव 𝑠 या 𝑡 (अर्थात उच्चतम लेबल शीर्ष) से सबसे दूर के शीर्ष का चयन करता है, किन्तु अन्यथा फीफो एल्गोरिथ्म के रूप में आगे बढ़ता है।
डायनेमिक ट्री के साथ पुश-रीलेबल एल्गोरिथम[17] एल्गोरिथ्म ऊंचाई कार्य के संबंध में अवशिष्ट ग्राफ पर सीमित आकार के पेड़ बनाता है। ये पेड़ बहुस्तरीय पुश ऑपरेशंस प्रदान करते हैं, अर्थात किनारे के अतिरिक्त पूरे संतृप्त पथ के साथ धक्का देता है।
केआरटी (राजा, राव, टार्जन) का एल्गोरिदम
बाइनरी ब्लॉकिंग फ्लो एल्गोरिथम[19]
जेम्स बी ओरलिन का + केआरटी (राजा, राव, टारजन) का एल्गोरिदम[9] ओर्लिन का एल्गोरिदम अधिकतम प्रवाह को हल करता है के लिए समय जबकि केआरटी इसे हल करता है के लिए .
कथूरिया-लियू-सिडफोर्ड एल्गोरिथ्म ℓ 𝑝 - मानक प्रवाह का उपयोग करके आंतरिक बिंदु विधियां और बढ़त वृद्धि। मैड्री के पहले के एल्गोरिथम पर बनाता है, जिसने रनटाइम प्राप्त किया था .[20]
बीएलएनपीएसएसएसडब्ल्यू / बीएलएलएसएसएसडब्ल्यू एल्गोरिदम[21]

[22]

विस्तारक अपघटन के साथ विद्युत प्रवाह के आंतरिक बिंदु विधि और गतिशील रखरखाव।
गाओ लियू पेंग एल्गोरिथम[23] गाओ, लियू, और पेंग का एल्गोरिदम [माद्री जेएसीएम '16] से आंतरिक बिंदु विधि आधारित एल्गोरिदम के मूल में बढ़ते विद्युत प्रवाह को गतिशील रूप से बनाए रखने के आसपास घूमता है। यह डेटा संरचनाओं को डिजाइन करने पर जोर देता है, जो सीमित सेटिंग्स में, प्रतिरोध अद्यतनों के दौर से गुजर रहे ग्राफ में बड़ी विद्युत ऊर्जा के साथ किनारों को लौटाते हैं।
चेन, किंग, लियू, पेंग, गुटेनबर्ग और सचदेवा का एल्गोरिदम[10] चेन, किंग, लियू, पेंग, गुटेनबर्ग और सचदेवा के एल्गोरिदम प्रवाह के अनुक्रम के माध्यम से प्रवाह का निर्माण करके लगभग रैखिक समय में अधिकतम प्रवाह और न्यूनतम व्यय प्रवाह को हल करते हैं अनुमानित अप्रत्यक्ष न्यूनतम-अनुपात चक्र, जिनमें से प्रत्येक की गणना और परिशोधन में संसाधित की जाती है समय गतिशील डेटा संरचना का उपयोग कर.

अतिरिक्त एल्गोरिदम के लिए, देखें गोल्डबर्ग & टार्जन (1988).

इंटीग्रल फ्लो प्रमेय

अभिन्न प्रवाह प्रमेय कहता है कि

यदि प्रवाह नेटवर्क में प्रत्येक किनारे की अभिन्न क्षमता है, तो अभिन्न अधिकतम प्रवाह उपस्थित होती है।

प्रमाणित न केवल यह है कि प्रवाह का मान पूर्णांक है, जो अधिकतम-प्रवाह न्यूनतम-कट प्रमेय से सीधे अनुसरण करता है, किन्तु यह कि 'हर किनारे' पर प्रवाह अभिन्न है। यह कई असतत गणित अनुप्रयोगों (नीचे देखें) के लिए महत्वपूर्ण है, जहां किनारे पर प्रवाह एन्कोड कर सकता है कि उस किनारे से संबंधित आइटम को समुच्चय में सम्मिलित किया जाना है या नहीं।

आवेदन

बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या

चित्र 4.1.1। बहु-स्रोत बहु-सिंक अधिकतम प्रवाह समस्या का एकल-स्रोत एकल-सिंक अधिकतम प्रवाह समस्या में रूपांतरण

नेटवर्क दिया सूत्रों के समुच्चय के साथ और सिंक का समुच्चय केवल स्रोत और सिंक के अतिरिक्त, हमें अधिकतम प्रवाह का पता लगाना है हम बहु-स्रोत बहु-सिंक समस्या को अधिकतम प्रवाह समस्या में प्रत्येक शीर्ष से जोड़ने वाले समेकित स्रोत को जोड़कर बदल सकते हैं और प्रत्येक शीर्ष से जुड़ा समेकित सिंक (सुपरसोर्स और सुपरसिंक के रूप में भी जाना जाता है) प्रत्येक किनारे पर अनंत क्षमता के साथ (चित्र देखें। 4.1.1।)।

अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान

चित्र 4.3.1। अधिकतम द्विदलीय मिलान समस्या का अधिकतम प्रवाह समस्या में रूपांतरण

द्विदलीय ग्राफ दिया , हमें मिलान करने वाली अधिकतम कार्डिनैलिटी मिलनी है , वह मिलान है जिसमें किनारों की सबसे बड़ी संभव संख्या होती है। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है , जहाँ

  1. में के किनारों को से तक निर्देशित किया गया है
  2. प्रत्येक के लिए और प्रत्येक के लिए
  3. प्रत्येक के लिए (चित्र देखें। 4.3.1)।

तब में अधिकतम प्रवाह का मान में अधिकतम मिलान के आकार के समान होता है, और अधिकतम कार्डिनैलिटी मिलान उन किनारों को ले कर पाया जा सकता है जिनके पास अभिन्न अधिकतम-प्रवाह में प्रवाह है।

निर्देशित चक्रीय ग्राफ में न्यूनतम पथ कवर

निर्देशित विश्वकोश ग्राफ दिया , हमें प्रत्येक शीर्ष को कवर करने के लिए पथ (ग्राफ सिद्धांत) | शीर्ष-विच्छेद पथों की न्यूनतम संख्या का पता लगाना है . हम द्विदलीय ग्राफ का निर्माण कर सकते हैं से , जहाँ

  1. .

तभी यह दिखाया जा सकता है मेल खाता है आकार का यदि और केवल यदि वर्टेक्स-डिसजॉइंट पाथ कवर है युक्त किनारों और पथ, जहाँ में शीर्षों की संख्या है . इसलिए, अधिकतम कार्डिनैलिटी मैचिंग का पता लगाकर समस्या को हल किया जा सकता है अतिरिक्त।

मान लें कि हमें मिलान मिल गया है का , और आवरण का निर्माण किया यह से सहज रूप से, यदि दो कोने में मेल खाते हैं , फिर किनारा में निहित है . स्पष्ट रूप से किनारों की संख्या है . यह देखने के लिए वर्टेक्स-डिसजॉइंट है, निम्नलिखित पर विचार करें:

  1. प्रत्येक शीर्ष में या तो में बेमेल हो सकता है , जिस स्थिति में कोई किनारा नहीं बचता है में ; या इसका मिलान किया जा सकता है, जिस स्थिति में ठीक किनारा बचता है में . किसी भी स्थिति में, किनारे से अधिक कोई शीर्ष नहीं छोड़ता है
  2. इसी प्रकार प्रत्येक शीर्ष के लिए में - यदि इसका मिलान किया जाता है, तो इसमें आने वाला किनारा होता है में ; अन्यथा में कोई आने वाला किनारा नहीं है .

इस प्रकार किसी भी शीर्ष में दो आने वाले या दो बाहर जाने वाले किनारे नहीं होते हैं , जिसका अर्थ है सभी रास्ते अंदर वर्टेक्स-डिसजॉइंट हैं।

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

शीर्ष क्षमता के साथ अधिकतम प्रवाह

चित्र 4.4.1। नोड विभाजन द्वारा मूल अधिकतम प्रवाह समस्या में वर्टेक्स क्षमता बाधा के साथ अधिकतम प्रवाह समस्या का परिवर्तन

माना नेटवर्क हो। मान लीजिए कि बढ़त क्षमता के अतिरिक्त प्रत्येक नोड पर क्षमता है, अर्थात मैपिंग ऐसा कि प्रवाह न केवल क्षमता की कमी और प्रवाह के संरक्षण को पूरा करना है, किन्तु वर्टेक्स क्षमता की कमी को भी पूरा करना है

दूसरे शब्दों में, शीर्ष से निकलने वाले प्रवाह की मात्रा इसकी क्षमता से अधिक नहीं हो सकती। अधिकतम प्रवाह खोजने के लिए , हम विस्तार करके समस्या को मूल अर्थ में अधिकतम प्रवाह समस्या में बदल सकते हैं . सबसे पहले, प्रत्येक द्वारा प्रतिस्थापित किया जाता है और , जहाँ में जाकर किनारों से जुड़ा है और से निकलने वाले किनारों से जुड़ा है , फिर क्षमता असाइन करें किनारे से जोड़ने के लिए और (चित्र देखें। 4.4.1)। इस विस्तारित नेटवर्क में, वर्टेक्स क्षमता की कमी को हटा दिया जाता है और इसलिए समस्या को मूल अधिकतम प्रवाह समस्या के रूप में माना जा सकता है।

s से t तक पथों की अधिकतम संख्या

निर्देशित ग्राफ दिया और दो शिखर और , हमें पथों की अधिकतम संख्या ज्ञात करनी है को . इस समस्या के कई रूप हैं:

1. पथ एज-डिसजॉइंट होने चाहिए। नेटवर्क बनाकर इस समस्या को अधिकतम प्रवाह समस्या में बदला जा सकता है से , साथ और स्रोत और सिंक होने के नाते क्रमशः, और प्रत्येक किनारे की क्षमता निर्दिष्ट करना . इस नेटवर्क में अधिकतम प्रवाह है यदि हैं किनारे-अलग रास्ते होते है।

2. पथ स्वतंत्र होने चाहिए, अर्थात, वर्टेक्स-डिसजॉइंट (को छोड़कर) और ). हम नेटवर्क बना सकते हैं इस प्रकार से वर्टेक्स योग्यता के साथ, जहां सभी वर्टिकल और सभी एज की योग्यता होती है . तब अधिकतम प्रवाह का मान स्वतंत्र पथों की अधिकतम संख्या को . के समान होता है

3. पथों के किनारे-विच्छेद और/या शीर्ष असंयुक्त होने के अतिरिक्त , पथों में लंबाई की बाधा भी होती है: हम केवल उन पथों की गणना करते हैं जिनकी लंबाई ठीक है , या अधिक से अधिक . के छोटे मूल्यों को छोड़कर, इस समस्या के अधिकांश रूप एनपी-पूर्ण हैं .[24]

बंद करने की समस्या

मुख्य लेख: बंद करने की समस्या

निर्देशित ग्राफ़ का बंद होना 'सी' वर्टिकल का समुच्चय है, जैसे कोई किनारा सी नहीं छोड़ता है। क्लोजर प्रॉब्लम वर्टेक्स-वेटेड डायरेक्टेड ग्राफ में अधिकतम-वेट या न्यूनतम-वेट क्लोजर खोजने का कार्य है। अधिकतम प्रवाह समस्या में कमी का उपयोग करके इसे बहुपद समय में हल किया जा सकता है।

वास्तविक विश्व अनुप्रयोग

बेसबॉल उन्मूलन

बेसबॉल उन्मूलन समस्या के लिए नेटवर्क प्रवाह का निर्माण

बेसबॉल उन्मूलन समस्या में लीग में प्रतिस्पर्धा करने वाली n टीमें हैं। लीग सीज़न के विशिष्ट चरण में, wi जीत और आर की संख्या है टीम और rijके लिए खेले जाने वाले खेलों की संख्या है टीम rij के विरुद्ध बचे हुए खेलों की संख्या है। टीम का सफाया कर दिया जाता है यदि उसके पास सीजन को पहले स्थान पर खत्म करने का कोई मौका नहीं है। बेसबॉल उन्मूलन समस्या का कार्य यह निर्धारित करना है कि सीजन के समय प्रत्येक बिंदु पर कौन सी टीम समाप्त हो जाती है। श्वार्ट्ज[25] विधि प्रस्तावित किया जो इस समस्या को अधिकतम नेटवर्क प्रवाह तक कम कर देता है। इस पद्धति में यह निर्धारित करने के लिए नेटवर्क बनाया जाता है कि टीम k समाप्त हो गई है या नहीं।

मान लीजिए G = (V, E) एक नेटवर्क है जिसमें s,t ∈ V क्रमशः स्रोत और सिंक है। एक गेम नोडीज जोड़ता है - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है। हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड {i, j} को i <j से V तक जोड़ते हैं, और उनमें से प्रत्येक को क्षमता rij के साथ किनारे से जोड़ते हैं - जो इन दो टीमों के बीच नाटकों की संख्या का प्रतिनिधित्व करता है . हम प्रत्येक टीम के लिए एक टीम नोड भी जोड़ते हैं और प्रत्येक गेम नोड {i, j} को दो टीम नोड्स i और j से जोड़ते हैं जिससे उनमें से एक जीत सुनिश्चित हो सकता है । इन किनारों पर प्रवाह मान को सीमित करने की आवश्यकता नहीं है। अंत में किनारों को टीम नोड i से सिंक नोड t तक बनाया जाता है और टीम i को wk + rk से अधिक जीतने से रोकने के लिए wk + rkwi की क्षमता निर्धारित की जाती है।

मान लीजिए S लीग में भाग लेने वाली सभी टीमों का समुच्चय है और मान लीजिए

.

इस पद्धति में यह प्रमाणित किया जाता है कि टीम k को समाप्त नहीं किया जाता है यदि और केवल यदि आकार r(S - {k}) का प्रवाह मान नेटवर्क G में उपस्थित है। उल्लिखित लेख में यह सिद्ध किया गया है कि यह प्रवाह मान से अधिकतम प्रवाह मान है।

विमान सेवा समय-निर्धारण

विमान सेवा उद्योग में बड़ी समस्या उड़ान कर्मचारियों के समय-निर्धारण किया गया है। और विमान सेवा समय समस्या को विस्तारित अधिकतम नेटवर्क प्रवाह के अनुप्रयोग के रूप में माना जा सकता है। इस समस्या का इनपुट विमान F का समुच्चय है जिसमें यह जानकारी होती है कि प्रत्येक विमान कहाँ और कब प्रस्थान करती है और कब आती है। विमान सेवा समय के संस्करण में लक्ष्य अधिकतम k कर्मचारियों के साथ व्यवहार्य समय तैयार करना है।

इस समस्या को हल करने के लिए परिबद्ध संचलन नामक संचलन समस्या की भिन्नता का उपयोग किया जाता है जोकी प्रवाह नेटवर्क समस्याओं का सामान्यीकरण है, किनारे प्रवाह पर निचली सीमा के अतिरिक्त प्रतिबंध किया है ।

G = (V, E) स्रोत और सिंक नोड्स के रूप में s,tV के साथ एक नेटवर्क बनें। प्रत्येक उड़ान i के स्रोत और गंतव्य के लिए, V में दो नोड जोड़े जाते हैं, नोड si स्रोत के रूप में और नोड di उड़ान के गंतव्य नोड के रूप में i, E में निम्नलिखित किनारों को भी जोड़ा जाता है:

  1. s और प्रत्येक si के बीच क्षमता [0, 1] वाला किनारा
  2. E' में G के किनारों को X से a तक निर्देशित किया गया है
  3. प्रत्येक di के बीच क्षमता [0, 1] वाला किनारा और t
  4. si और di की प्रत्येक जोड़ी के बीच क्षमता [1, 1] वाला किनारा।
  5. प्रत्येक di और sj के बीच क्षमता [0, 1] के साथ एक किनारा, यदि स्रोत sj उड़ान के गंतव्य i से उचित समय और व्यय के साथ पहुंच योग्य है।
  6. s और t के बीच क्षमता [0, ∞] वाला किनारा।

उल्लिखित विधि में, यह प्रमाणित किया गया है और सिद्ध किया गया है कि s और t के बीच G में k के प्रवाह मूल्य का पता लगाना अधिकतम k कर्मचारियों के साथ उड़ान समुच्चय F के लिए व्यवहार्य कार्यक्रम खोजने के समान है।[26]

विमान सेवा समय का अन्य संस्करण सभी उड़ानों को निष्पादित करने के लिए न्यूनतम आवश्यक कर्मचारियों की खोज कर रहा है। इस समस्या का उत्तर खोजने के लिए, द्विदलीय ग्राफ G' = (AB, E) वहाँ बनाया जाता है। जहाँ प्रत्येक उड़ान की समुच्चय A और समुच्चय B में प्रति होती है। यदि वही विमान उड़ान i के बाद उड़ान j निष्पादित कर सकता है, i∈A j∈B से जुड़ा है। G' में मेल खाता है F के लिए समय को प्रेरित करता है और स्पष्ट रूप से इस ग्राफ में अधिकतम द्विपक्षीय मिलान कर्मचारियों की न्यूनतम संख्या के साथ विमान सेवा समय तैयार करता है।[26] जैसा कि इस लेख के अनुप्रयोग भाग में बताया गया है, अधिकतम कार्डिनैलिटी द्विपक्षीय मिलान अधिकतम प्रवाह समस्या का अनुप्रयोग है।

परिसंचरण-मांग समस्या

कुछ कारखाने हैं जो माल का उत्पादन करते हैं और कुछ गाँव जहाँ माल पहुँचाना होता है। वे सड़कों के नेटवर्क से जुड़े हुए हैं जिनमें प्रत्येक सड़क की क्षमता है अधिकतम माल c के लिए जो इसके माध्यम से बह सकता है। समस्या यह पता लगाने की है कि क्या कोई संचलन है जो मांग को पूरा करता है। यह समस्या अधिकतम-प्रवाह समस्या में परिवर्तित हो सकती है।

  1. स्रोत नोड जोड़ें s और इसके किनारों को हर फैक्ट्री नोड में जोड़ें fi क्षमता के साथ pi जहाँ pi कारखाने fi की उत्पादन दर है .
  2. सिंक नोड जोड़ें t और सभी गांवों से किनारे जोड़ें vi को t क्षमता के साथ di जहाँ di गांव की मांग vi दर है .

बता दें कि जी = (वी, ई) यह नया नेटवर्क है। संचलन उपस्थित है जो मांग को संतुष्ट करता है यदि और केवल यदि:

Maximum flow value(G) .

यदि कोई संचलन उपस्थित है, जिससे अधिकतम-प्रवाह समाधान को देखने से यह उत्तर मिलेगा कि मांगों को पूरा करने के लिए किसी विशेष सड़क पर कितना माल भेजा जाना है।

कुछ किनारों पर प्रवाह पर निचली सीमा जोड़कर समस्या को बढ़ाया जा सकता है।[27]

छवि विभाजन

बाएं
बिटमैप से निर्मित नेटवर्क। स्रोत बाईं ओर है, सिंक दाईं ओर है। किनारा जितना गहरा होता है, उसकी क्षमता उतनी ही बड़ी होती है। एi उच्च होता है जब पिक्सेल हरा होता है, bi जब पिक्सेल हरा नहीं होता है। दंड पीij सब समान हैं।[28]

क्लेनबर्ग और टार्डोस ने अपनी पुस्तक में छवि विभाजन के लिए छवि के लिए एल्गोरिथ्म प्रस्तुत किया है।[29] वे छवि में पृष्ठभूमि और अग्रभूमि खोजने के लिए एल्गोरिथ्म प्रस्तुत करते हैं। अधिक स्पष्ट रूप से, एल्गोरिथ्म बिटमैप को इनपुट के रूप में निम्नानुसार लेता है: ai≥ 0 संभावना है कि पिक्सेल i अग्रभूमि से संबंधित है, bi≥ 0 इस संभावना में कि पिक्सेल i पृष्ठभूमि से संबंधित है, और pijयदि दो सन्निकट पिक्सेल i और j को अग्रभूमि में और दूसरे को पृष्ठभूमि में रखा जाता है तो यह जुर्माना है। लक्ष्य निम्नलिखित मात्रा को अधिकतम करने वाले पिक्सेल के समुच्चय के विभाजन (ए, बी) को ढूंढना है

,

दरअसल, ai में पिक्सेल के लिए (अग्रभूमि के रूप में माना जाता है), हम प्राप्त करते हैं; बी में सभी पिक्सल के लिए (पृष्ठभूमि के रूप में माना जाता है), हम bi प्राप्त करते हैं. सीमा पर, दो आसन्न पिक्सेल i और j के बीच, हम pij को ढीला करते हैं. यह मात्रा को कम करने के समान है

क्योंकि

नेटवर्क पर प्रदर्शित न्यूनतम कट (त्रिकोण बनाम वृत्त)।

अब हम उस नेटवर्क का निर्माण करते हैं जिसके नोड पिक्सेल हैं, साथ ही स्रोत और सिंक, दाईं ओर चित्र देखें। हम स्रोत को पिक्सेल i से वजन ai के किनारे से जोड़ते हैं. हम पिक्सेल i को वज़न bi के किनारे से सिंक से जोड़ते हैं. हम पिक्सेल i को पिक्सेल j से वजन pij के साथ जोड़ते हैं. अब, यह उस नेटवर्क में न्यूनतम कटौती (या समकक्ष अधिकतम प्रवाह) की गणना करने के लिए बनी हुई है। अंतिम आंकड़ा न्यूनतम कटौती दिखाता है।

एक्सटेंशन

1. न्यूनतम-व्यय प्रवाह समस्या में, प्रत्येक किनारे (u,v) का व्यय-गुणांक auv भी होता है इसकी क्षमता के अतिरिक्त यदि किनारे से प्रवाह fuv है, तो कुल व्यय fuv है. सबसे छोटी व्यय के साथ दिए गए आकार d का प्रवाह खोजना आवश्यक है। अधिकांश प्रकारों में, व्यय-गुणांक सकारात्मक या नकारात्मक हो सकते हैं। इस समस्या के लिए विभिन्न बहुपद-समय एल्गोरिदम हैं।

2. अधिकतम-प्रवाह समस्या को 'वियोगात्मक बाधाओं' द्वारा संवर्धित किया जा सकता है: नकारात्मक वियोगात्मक बाधा का कहना है कि किनारों की निश्चित जोड़ी साथ गैर-शून्य प्रवाह नहीं कर सकती है; सकारात्मक वियोगात्मक बाधाएँ कहती हैं कि, किनारों की निश्चित जोड़ी में, कम से कम गैर-शून्य प्रवाह होना चाहिए। नकारात्मक बाधाओं के साथ, सरल नेटवर्क के लिए भी समस्या एनपी-हार्ड हो जाती है। सकारात्मक बाधाओं के साथ, यदि आंशिक प्रवाह की अनुमति दी जाती है, जिससे समस्या बहुपद है, किन्तु जब प्रवाह अभिन्न होना चाहिए जिससे यह एनपी-हार्ड हो सकता है।[30]

संदर्भ

  1. 1.0 1.1 1.2 Schrijver, A. (2002). "परिवहन के इतिहास और अधिकतम प्रवाह की समस्याओं पर". Mathematical Programming. 91 (3): 437–445. CiteSeerX 10.1.1.23.5134. doi:10.1007/s101070100259. S2CID 10210675.
  2. Gass, Saul I.; Assad, Arjang A. (2005). "Mathematical, algorithmic and professional developments of operations research from 1951 to 1956". ऑपरेशंस रिसर्च की एन एनोटेटेड टाइमलाइन. International Series in Operations Research & Management Science. Vol. 75. pp. 79–110. doi:10.1007/0-387-25837-X_5. ISBN 978-1-4020-8116-3.
  3. 3.0 3.1 Harris, T. E.; Ross, F. S. (1955). "रेल नेट क्षमताओं के मूल्यांकन के लिए एक विधि के मूल सिद्धांत" (PDF). Research Memorandum. Archived from the original (PDF) on 8 January 2014.
  4. 4.0 4.1 Ford, L. R.; Fulkerson, D. R. (1956). "एक नेटवर्क के माध्यम से अधिकतम प्रवाह". Canadian Journal of Mathematics. 8: 399–404. doi:10.4153/CJM-1956-045-5.
  5. 5.0 5.1 Ford, L.R., Jr.; Fulkerson, D.R., Flows in Networks, Princeton University Press (1962).
  6. Sherman, Jonah (2013). "Nearly Maximum Flows in Nearly Linear Time". Proceedings of the 54th Annual IEEE Symposium on Foundations of Computer Science. pp. 263–269. arXiv:1304.2077. doi:10.1109/FOCS.2013.36. ISBN 978-0-7695-5135-7. S2CID 14681906.
  7. Kelner, J. A.; Lee, Y. T.; Orecchia, L.; Sidford, A. (2014). "An Almost-Linear-Time Algorithm for Approximate Max Flow in Undirected Graphs, and its Multicommodity Generalizations" (PDF). असतत एल्गोरिदम पर पच्चीसवीं वार्षिक एसीएम-सियाम संगोष्ठी की कार्यवाही. p. 217. arXiv:1304.2338. doi:10.1137/1.9781611973402.16. ISBN 978-1-61197-338-9. S2CID 10733914. Archived from the original (PDF) on 2016-03-03.
  8. Knight, Helen (7 January 2014). "नया एल्गोरिदम नाटकीय रूप से 'अधिकतम प्रवाह' समस्या के समाधान को सुव्यवस्थित कर सकता है". MIT News. Retrieved 8 January 2014.
  9. 9.0 9.1 Orlin, James B. (2013). "Max flows in O(nm) time, or better". Proceedings of the 45th annual ACM symposium on Symposium on theory of computing – STOC '13. pp. 765–774. CiteSeerX 10.1.1.259.5759. doi:10.1145/2488608.2488705. ISBN 9781450320290. S2CID 207205207. {{cite book}}: |journal= ignored (help)
  10. 10.0 10.1 Chen, L.; Kyng, R.; Liu, Y.P.; Gutenberg, M.P.; Sachdeva, S. (2022). "Maximum Flow and Minimum-Cost Flow in Almost-Linear Time". arXiv:2203.00671 [cs.DS].
  11. Klarreich, Erica (2022-06-08). "शोधकर्ताओं ने नेटवर्क प्रवाह के लिए 'एब्सर्डली फास्ट' एल्गोरिथम हासिल किया". Quanta Magazine (in English). Retrieved 2022-06-08.
  12. Bernstein, Aaron; Nanongkai, Danupon; Wulff-Nilsen, Christian (2022-10-30). "नेगेटिव-वेट सिंगल-सोर्स शॉर्टेस्ट पाथ इन नियर-लीनियर टाइम". arXiv:2203.03456 [cs.DS].
  13. Brubaker, Ben (2023-01-18). "अंत में, नकारात्मक रेखांकन पर सबसे छोटे रास्तों के लिए एक तेज़ एल्गोरिथम". Quanta Magazine (in English). Retrieved 2023-01-25.
  14. "FOCS 2022". focs2022.eecs.berkeley.edu. Retrieved 2023-01-25.
  15. Santosh, Nagarakatte. "FOCS 2022 Best Paper Award for Prof. Aaron Bernstein's Paper". www.cs.rutgers.edu (in British English). Retrieved 2023-01-25.
  16. Malhotra, V.M.; Kumar, M. Pramodh; Maheshwari, S.N. (1978). "An algorithm for finding maximum flows in networks" (PDF). Information Processing Letters. 7 (6): 277–278. doi:10.1016/0020-0190(78)90016-9.
  17. 17.0 17.1 17.2 Goldberg, A. V.; Tarjan, R. E. (1988). "A new approach to the maximum-flow problem". Journal of the ACM. 35 (4): 921. doi:10.1145/48014.61051. S2CID 52152408.
  18. Cheriyan, J.; Maheshwari, S. N. (1988). "Analysis of preflow push algorithms for maximum network flow". Foundations of Software Technology and Theoretical Computer Science. Lecture Notes in Computer Science. Vol. 338. pp. 30–48. doi:10.1007/3-540-50517-2_69. ISBN 978-3-540-50517-4. ISSN 0302-9743.
  19. Goldberg, A. V.; Rao, S. (1998). "Beyond the flow decomposition barrier". Journal of the ACM. 45 (5): 783. doi:10.1145/290179.290181. S2CID 96030.
  20. Madry, Aleksander (9–11 October 2016). Computing Maximum Flow with Augmenting Electrical Flows. New Brunswick, New Jersey: IEEE. pp. 593–602.{{cite book}}: CS1 maint: date format (link)
  21. Brand, J. vd; Lee, Y.T.; Nanongkai, D.; Peng, R.; Saranurak, T.; Sidford, A.; Song, Z.; Wang, D. (16–19 November 2020). Bipartite Matching in Nearly-linear Time on Moderately Dense Graphs. Durham, NC, USA: IEEE. pp. 919–930.
  22. Brand, J. vd; Lee, Y.T.; Liu, Y.P.; Saranurak, T.; Sidford, A; Song, Z.; Wang, D. (2021). "Minimum Cost Flows, MDPs, and ℓ1-Regression in Nearly Linear Time for Dense Instances". arXiv:2101.05719 [cs.DS].
  23. Gao, Y.; Liu, Y.P.; Peng, R. (2021). "Fully Dynamic Electrical Flows: Sparse Maxflow Faster Than Goldberg-Rao". arXiv:2101.07233 [cs.DS].
  24. Itai, A.; Perl, Y.; Shiloach, Y. (1982). "लंबाई की कमी के साथ अधिकतम असम्बद्ध पथ खोजने की जटिलता". Networks (in English). 12 (3): 277–286. doi:10.1002/net.3230120306. ISSN 1097-0037.
  25. Schwartz, B. L. (1966). "आंशिक रूप से पूर्ण टूर्नामेंट में संभावित विजेता". SIAM Review. 8 (3): 302–308. Bibcode:1966SIAMR...8..302S. doi:10.1137/1008062. JSTOR 2028206.
  26. 26.0 26.1 Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein (2001). "26. Maximum Flow". एल्गोरिदम का परिचय, दूसरा संस्करण. MIT Press and McGraw-Hill. pp. 643–668. ISBN 978-0-262-03293-3.{{cite book}}: CS1 maint: multiple names: authors list (link)
  27. Carl Kingsford. "Max-flow extensions: circulations with demands" (PDF).
  28. "प्रोजेक्ट इमेजेजमेंटेशनविथमैक्सफ्लो, जिसमें इन दृष्टांतों को बनाने के लिए स्रोत कोड शामिल है।". GitLab (in English). Archived from the original on 2019-12-22. Retrieved 2019-12-22.
  29. "एल्गोरिथम डिजाइन". pearson.com (in English). Retrieved 2019-12-21.
  30. Schauer, Joachim; Pferschy, Ulrich (1 July 2013). "असंबद्ध बाधाओं के साथ अधिकतम प्रवाह समस्या". Journal of Combinatorial Optimization (in English). 26 (1): 109–119. CiteSeerX 10.1.1.414.4496. doi:10.1007/s10878-011-9438-7. ISSN 1382-6905. S2CID 6598669.

अग्रिम पठन