फाइबोनैचि खोज तकनीक: Difference between revisions
(Created page with "{{About|the programming algorithm|the technique for finding extremum of a mathematical function|Golden section search}} {{Technical|date=July 2013}} कंप्यूट...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{ | [[कंप्यूटर विज्ञान]] में, '''फाइबोनैचि खोज तकनीक''' एक विभाजन और जीत एल्गोरिदम का उपयोग करके [[क्रमबद्ध सरणी]] को खोजने की एक विधि है जो [[फाइबोनैचि संख्या]]ओं की सहायता से संभावित स्थानों को सीमित करती है।<ref name="Ferguson1960">{{cite journal |doi=10.1145/367487.367496 |first=David E. |last=Ferguson |title=फाइबोनैशियन खोज|journal=Communications of the ACM |volume=3 |issue=12 |year=1960 |page=648 |s2cid=7982182 |doi-access=free }} Note that the running time analysis is this article is flawed, as pointed out by Overholt in 1972 (published 1973).</ref> [[बाइनरी खोज एल्गोरिदम]] की तुलना में जहां क्रमबद्ध सरणी को दो समान आकार के भागों में विभाजित किया जाता है, जिनमें से एक की आगे जांच की जाती है, फाइबोनैचि खोज सरणी को दो भागों में विभाजित करती है जिनके आकार लगातार फाइबोनैचि संख्या होते हैं। औसतन, इससे लगभग 4% अधिक तुलनाएँ क्रियान्वित की जाती हैं,<ref name="Overholt">{{cite journal |doi=10.1007/BF01933527 |first=K. J. |last=Overholt |title=फाइबोनैचि खोज विधि की दक्षता|journal=BIT Numerical Mathematics |volume=13 |issue=1 |year=1973 |pages=92–96 |s2cid=120681132 }}</ref> लेकिन इसका फायदा यह है कि किसी को एक्सेस किए गए सरणी तत्वों के सूचकांकों की गणना करने के लिए केवल जोड़ और घटाव की आवश्यकता होती है, जबकि चिरसम्मत बाइनरी खोज के लिए बिट-शिफ्ट ([[बिटवाइज़ ऑपरेशन]] देखें), विभाजन या गुणा की आवश्यकता होती है।<ref name="Ferguson1960" />फाइबोनैचि खोज के पहली बार प्रकाशित होने के समय जो ऑपरेशन कम आम थे। फाइबोनैचि खोज में O(लॉग एन) की औसत और सबसे खराब स्थिति वाली जटिलता है ([[ बिग ओ अंकन |बिग ओ अंकन]] देखें)। | ||
{{ | |||
फाइबोनैचि अनुक्रम में यह गुण होता है कि एक संख्या अपने दो पूर्ववर्तियों का योग होती है। इसलिए अनुक्रम की गणना बार-बार जोड़कर की जा सकती है। दो लगातार संख्याओं का अनुपात स्वर्णिम अनुपात, 1.618 के नज़दीक पहुंचता है... बाइनरी खोज खोज क्षेत्र को समान भागों (1:1) में विभाजित करके काम करती है। फाइबोनैचि खोज सरल ऑपरेशनों का उपयोग करते हुए इसे 1:1.618 तक पहुंचने वाले भागों में विभाजित कर सकती है। | |||
फाइबोनैचि अनुक्रम में यह गुण होता है कि एक संख्या अपने दो पूर्ववर्तियों का योग होती है। इसलिए अनुक्रम की गणना बार-बार जोड़कर की जा सकती है। दो लगातार संख्याओं का अनुपात स्वर्णिम अनुपात, 1.618 के | |||
यदि खोजे जा रहे तत्वों में गैर-समान एक्सेस मेमोरी स्टोरेज है (यानी, स्टोरेज स्थान तक पहुंचने के लिए आवश्यक समय एक्सेस किए गए स्थान के आधार पर भिन्न होता है), तो फाइबोनैचि खोज को एक्सेस करने के लिए आवश्यक औसत समय को थोड़ा कम करने में बाइनरी खोज पर लाभ हो सकता है एक भंडारण स्थान. यदि खोज निष्पादित करने वाली मशीन में सीधे मैप किया गया [[सीपीयू कैश]] है, तो बाइनरी खोज से अधिक कैश मिस हो सकता है क्योंकि जिन तत्वों तक पहुंच होती है वे प्रायः केवल कुछ कैश लाइनों में एकत्रित होते हैं; इसे सरणी को ऐसे भागों में विभाजित करके कम किया जाता है जिनमें दो की शक्तियाँ नहीं होती हैं। यदि डेटा को चुंबकीय टेप डेटा स्टोरेज पर संग्रहीत किया जाता है, जहां खोज समय वर्तमान प्रमुख स्थिति पर निर्भर करता है, तो लंबे समय तक खोज समय और अधिक तुलनाओं के बीच एक ट्रेडऑफ एक खोज एल्गोरिदम को जन्म दे सकता है जो फाइबोनैचि खोज के समान ही तिरछा है। | |||
फाइबोनैचि खोज [[ स्वर्ण खंड खोज ]] से ली गई है, जो एक अंतराल में एक [[यूनिमॉडल फ़ंक्शन|यूनिमॉडल फलन]] के अधिकतम या न्यूनतम की खोज के लिए [[जैक किफ़र (सांख्यिकीविद्)]] (1953) द्वारा एक एल्गोरिदम है।<ref>{{cite journal |doi=10.1090/S0002-9939-1953-0055639-3 |first=J. |last=Kiefer |title=अधिकतम के लिए अनुक्रमिक मिनिमैक्स खोज|journal=Proceedings of the American Mathematical Society |volume=4 |year=1953 |issue=3 |pages=502–506 |doi-access=free }}</ref> | |||
==एल्गोरिदम== | ==एल्गोरिदम== | ||
मान लीजिए कि k को फाइबोनैचि संख्याओं की सारणी F में एक तत्व के रूप में परिभाषित किया गया है। | मान लीजिए कि ''k'' को फाइबोनैचि संख्याओं की सारणी F में एक तत्व के रूप में परिभाषित किया गया है। n = F<sub>m</sub> सरणी का आकार है. यदि n एक फाइबोनैचि संख्या नहीं है, तो मान लीजिए F<sub>m</sub> में वह सबसे छोटी संख्या F हो जो ''n'' से बड़ी हो। | ||
फाइबोनैचि संख्याओं की सारणी को परिभाषित किया गया है जहां | फाइबोनैचि संख्याओं की सारणी को परिभाषित किया गया है जहां F<sub>''k''+2</sub> = F<sub>''k''+1</sub>+ F<sub>k</sub>, जब k ≥ 0, F<sub>1</sub> = 1, और F<sub>0</sub>= 1. | ||
यह जांचने के लिए कि कोई आइटम क्रमित संख्याओं की सूची में है या नहीं, इन चरणों का पालन करें: | यह जांचने के लिए कि कोई आइटम क्रमित संख्याओं की सूची में है या नहीं, इन चरणों का पालन करें: | ||
# | #समुच्चय ''k = m''. | ||
#यदि k = 0 है, तो रुकें। कोई मेल नहीं है; आइटम सरणी में नहीं है. | #यदि k = 0 है, तो रुकें। कोई मेल नहीं है; आइटम सरणी में नहीं है. | ||
# | #F<sub>''k''−1</sub> में तत्व के साथ आइटम की तुलना करें. | ||
#यदि आइटम मेल खाता है, तो रुकें। | #यदि आइटम मेल खाता है, तो रुकें। | ||
#यदि आइटम प्रविष्टि F | #यदि आइटम प्रविष्टि F<sub>''k''−1</sub> से कम है, स्थिति F<sub>''k''−1</sub>+ 1 से तत्वों को हटा दें से ''n''. k = k −1 समुच्चय करें और चरण 2 पर वापस लौटें। | ||
#यदि आइटम प्रविष्टि F | #यदि आइटम प्रविष्टि F<sub>''k''−1</sub> से बड़ा है, स्थिति 1 से F<sub>''k''−1</sub> तक के तत्वों को हटा दें. शेष तत्वों को 1 से F<sub>''k''−2</sub> तक पुनः क्रमांकित करें, k = k − 2 समुच्चय करें, और चरण 2 पर वापस लौटें। | ||
वैकल्पिक कार्यान्वयन (नुथ द्वारा सॉर्टिंग और सर्चिंग से)।<ref>{{cite book |first=Donald E. |last=Knuth |title=[[The Art of Computer Programming]] |edition=Second |volume=3 |page=418 |date=2003 }}</ref>): | वैकल्पिक कार्यान्वयन (नुथ द्वारा सॉर्टिंग और सर्चिंग से)।<ref>{{cite book |first=Donald E. |last=Knuth |title=[[The Art of Computer Programming]] |edition=Second |volume=3 |page=418 |date=2003 }}</ref>): | ||
अभिलेखों की एक तालिका दी गई | अभिलेखों की एक तालिका दी गई ''R''<sub>1</sub>, ''R''<sub>2</sub>, ..., ''R''<sub>N</sub> जिनकी कुंजियाँ बढ़ते क्रम में हैं ''K''<sub>1</sub>< ''K''<sub>2</sub>< ... < ''K''<sub>N</sub>, एल्गोरिथम किसी दिए गए तर्क K की खोज करता है। मान लें N+1 = ''F<sub>k</sub>''<sub>+1</sub> | ||
चरण 1. [आरंभ करें] ''i'' ← ''F''<sub>''k''</sub>, | |||
चरण 1. [आरंभ करें] ''i'' ← ''F''<sub>''k''</sub>, ''p'' ← F<sub>''k''-1</sub>, q← F<sub>''k''-2</sub> (पूरे एल्गोरिथम में, p और q लगातार फाइबोनैचि संख्याएं होंगी) | |||
'चरण दो।' [तुलना करें] यदि K < K<sub>i</sub>, चरण 3 पर जाएँ; यदि K > K<sub>i</sub>चरण 4 पर जाएँ; और यदि K = K<sub>i</sub>, एल्गोरिथम सफलतापूर्वक समाप्त हो जाता है। | 'चरण दो।' [तुलना करें] यदि K < K<sub>i</sub>, चरण 3 पर जाएँ; यदि K > K<sub>i</sub> चरण 4 पर जाएँ; और यदि K = K<sub>i</sub>, एल्गोरिथम सफलतापूर्वक समाप्त हो जाता है। | ||
'चरण 3।' [ | 'चरण 3।' [ घटना i] यदि q=0, एल्गोरिथ्म असफल रूप से समाप्त हो जाता है। अन्यथा समुच्चय करें (i, p, q) ← (i - q, q, p - q) (जो p और q को फाइबोनैचि अनुक्रम में एक स्थान पीछे ले जाता है); फिर चरण 2 पर वापस लौटें | ||
'चरण 4।' [ | 'चरण 4।' [वृद्धि i] यदि p=1, एल्गोरिथ्म असफल रूप से समाप्त हो जाता है। अन्यथा समुच्चय करें (i,p,q) ← (i + q, p - q, 2q - p) (जो फाइबोनैचि अनुक्रम में ''p'' और ''q'' को दो स्थान पीछे ले जाता है); और चरण 2 पर वापस लौटें | ||
ऊपर प्रस्तुत एल्गोरिदम के दो प्रकार हमेशा वर्तमान अंतराल को बड़े और छोटे उपअंतराल में विभाजित करते हैं। मूल एल्गोरिथ्म,<ref name="Ferguson1960" />हालाँकि, चरण 4 में नए अंतराल को छोटे और बड़े उपअंतराल में विभाजित किया जाएगा। इसका फायदा यह है कि नया i पुराने i के | ऊपर प्रस्तुत एल्गोरिदम के दो प्रकार हमेशा वर्तमान अंतराल को बड़े और छोटे उपअंतराल में विभाजित करते हैं। मूल एल्गोरिथ्म,<ref name="Ferguson1960" />हालाँकि, चरण 4 में नए अंतराल को छोटे और बड़े उपअंतराल में विभाजित किया जाएगा। इसका फायदा यह है कि नया ''i'' पुराने ''i'' के नज़दीक है और चुंबकीय टेप पर खोज को तेज करने के लिए अधिक उपयुक्त है। | ||
==यह भी देखें== | ==यह भी देखें== |
Revision as of 20:50, 11 July 2023
कंप्यूटर विज्ञान में, फाइबोनैचि खोज तकनीक एक विभाजन और जीत एल्गोरिदम का उपयोग करके क्रमबद्ध सरणी को खोजने की एक विधि है जो फाइबोनैचि संख्याओं की सहायता से संभावित स्थानों को सीमित करती है।[1] बाइनरी खोज एल्गोरिदम की तुलना में जहां क्रमबद्ध सरणी को दो समान आकार के भागों में विभाजित किया जाता है, जिनमें से एक की आगे जांच की जाती है, फाइबोनैचि खोज सरणी को दो भागों में विभाजित करती है जिनके आकार लगातार फाइबोनैचि संख्या होते हैं। औसतन, इससे लगभग 4% अधिक तुलनाएँ क्रियान्वित की जाती हैं,[2] लेकिन इसका फायदा यह है कि किसी को एक्सेस किए गए सरणी तत्वों के सूचकांकों की गणना करने के लिए केवल जोड़ और घटाव की आवश्यकता होती है, जबकि चिरसम्मत बाइनरी खोज के लिए बिट-शिफ्ट (बिटवाइज़ ऑपरेशन देखें), विभाजन या गुणा की आवश्यकता होती है।[1]फाइबोनैचि खोज के पहली बार प्रकाशित होने के समय जो ऑपरेशन कम आम थे। फाइबोनैचि खोज में O(लॉग एन) की औसत और सबसे खराब स्थिति वाली जटिलता है (बिग ओ अंकन देखें)।
फाइबोनैचि अनुक्रम में यह गुण होता है कि एक संख्या अपने दो पूर्ववर्तियों का योग होती है। इसलिए अनुक्रम की गणना बार-बार जोड़कर की जा सकती है। दो लगातार संख्याओं का अनुपात स्वर्णिम अनुपात, 1.618 के नज़दीक पहुंचता है... बाइनरी खोज खोज क्षेत्र को समान भागों (1:1) में विभाजित करके काम करती है। फाइबोनैचि खोज सरल ऑपरेशनों का उपयोग करते हुए इसे 1:1.618 तक पहुंचने वाले भागों में विभाजित कर सकती है।
यदि खोजे जा रहे तत्वों में गैर-समान एक्सेस मेमोरी स्टोरेज है (यानी, स्टोरेज स्थान तक पहुंचने के लिए आवश्यक समय एक्सेस किए गए स्थान के आधार पर भिन्न होता है), तो फाइबोनैचि खोज को एक्सेस करने के लिए आवश्यक औसत समय को थोड़ा कम करने में बाइनरी खोज पर लाभ हो सकता है एक भंडारण स्थान. यदि खोज निष्पादित करने वाली मशीन में सीधे मैप किया गया सीपीयू कैश है, तो बाइनरी खोज से अधिक कैश मिस हो सकता है क्योंकि जिन तत्वों तक पहुंच होती है वे प्रायः केवल कुछ कैश लाइनों में एकत्रित होते हैं; इसे सरणी को ऐसे भागों में विभाजित करके कम किया जाता है जिनमें दो की शक्तियाँ नहीं होती हैं। यदि डेटा को चुंबकीय टेप डेटा स्टोरेज पर संग्रहीत किया जाता है, जहां खोज समय वर्तमान प्रमुख स्थिति पर निर्भर करता है, तो लंबे समय तक खोज समय और अधिक तुलनाओं के बीच एक ट्रेडऑफ एक खोज एल्गोरिदम को जन्म दे सकता है जो फाइबोनैचि खोज के समान ही तिरछा है।
फाइबोनैचि खोज स्वर्ण खंड खोज से ली गई है, जो एक अंतराल में एक यूनिमॉडल फलन के अधिकतम या न्यूनतम की खोज के लिए जैक किफ़र (सांख्यिकीविद्) (1953) द्वारा एक एल्गोरिदम है।[3]
एल्गोरिदम
मान लीजिए कि k को फाइबोनैचि संख्याओं की सारणी F में एक तत्व के रूप में परिभाषित किया गया है। n = Fm सरणी का आकार है. यदि n एक फाइबोनैचि संख्या नहीं है, तो मान लीजिए Fm में वह सबसे छोटी संख्या F हो जो n से बड़ी हो।
फाइबोनैचि संख्याओं की सारणी को परिभाषित किया गया है जहां Fk+2 = Fk+1+ Fk, जब k ≥ 0, F1 = 1, और F0= 1.
यह जांचने के लिए कि कोई आइटम क्रमित संख्याओं की सूची में है या नहीं, इन चरणों का पालन करें:
- समुच्चय k = m.
- यदि k = 0 है, तो रुकें। कोई मेल नहीं है; आइटम सरणी में नहीं है.
- Fk−1 में तत्व के साथ आइटम की तुलना करें.
- यदि आइटम मेल खाता है, तो रुकें।
- यदि आइटम प्रविष्टि Fk−1 से कम है, स्थिति Fk−1+ 1 से तत्वों को हटा दें से n. k = k −1 समुच्चय करें और चरण 2 पर वापस लौटें।
- यदि आइटम प्रविष्टि Fk−1 से बड़ा है, स्थिति 1 से Fk−1 तक के तत्वों को हटा दें. शेष तत्वों को 1 से Fk−2 तक पुनः क्रमांकित करें, k = k − 2 समुच्चय करें, और चरण 2 पर वापस लौटें।
वैकल्पिक कार्यान्वयन (नुथ द्वारा सॉर्टिंग और सर्चिंग से)।[4]):
अभिलेखों की एक तालिका दी गई R1, R2, ..., RN जिनकी कुंजियाँ बढ़ते क्रम में हैं K1< K2< ... < KN, एल्गोरिथम किसी दिए गए तर्क K की खोज करता है। मान लें N+1 = Fk+1
चरण 1. [आरंभ करें] i ← Fk, p ← Fk-1, q← Fk-2 (पूरे एल्गोरिथम में, p और q लगातार फाइबोनैचि संख्याएं होंगी)
'चरण दो।' [तुलना करें] यदि K < Ki, चरण 3 पर जाएँ; यदि K > Ki चरण 4 पर जाएँ; और यदि K = Ki, एल्गोरिथम सफलतापूर्वक समाप्त हो जाता है।
'चरण 3।' [ घटना i] यदि q=0, एल्गोरिथ्म असफल रूप से समाप्त हो जाता है। अन्यथा समुच्चय करें (i, p, q) ← (i - q, q, p - q) (जो p और q को फाइबोनैचि अनुक्रम में एक स्थान पीछे ले जाता है); फिर चरण 2 पर वापस लौटें
'चरण 4।' [वृद्धि i] यदि p=1, एल्गोरिथ्म असफल रूप से समाप्त हो जाता है। अन्यथा समुच्चय करें (i,p,q) ← (i + q, p - q, 2q - p) (जो फाइबोनैचि अनुक्रम में p और q को दो स्थान पीछे ले जाता है); और चरण 2 पर वापस लौटें
ऊपर प्रस्तुत एल्गोरिदम के दो प्रकार हमेशा वर्तमान अंतराल को बड़े और छोटे उपअंतराल में विभाजित करते हैं। मूल एल्गोरिथ्म,[1]हालाँकि, चरण 4 में नए अंतराल को छोटे और बड़े उपअंतराल में विभाजित किया जाएगा। इसका फायदा यह है कि नया i पुराने i के नज़दीक है और चुंबकीय टेप पर खोज को तेज करने के लिए अधिक उपयुक्त है।
यह भी देखें
- खोज एल्गोरिदम
संदर्भ
- ↑ 1.0 1.1 1.2 Ferguson, David E. (1960). "फाइबोनैशियन खोज". Communications of the ACM. 3 (12): 648. doi:10.1145/367487.367496. S2CID 7982182. Note that the running time analysis is this article is flawed, as pointed out by Overholt in 1972 (published 1973).
- ↑ Overholt, K. J. (1973). "फाइबोनैचि खोज विधि की दक्षता". BIT Numerical Mathematics. 13 (1): 92–96. doi:10.1007/BF01933527. S2CID 120681132.
- ↑ Kiefer, J. (1953). "अधिकतम के लिए अनुक्रमिक मिनिमैक्स खोज". Proceedings of the American Mathematical Society. 4 (3): 502–506. doi:10.1090/S0002-9939-1953-0055639-3.
- ↑ Knuth, Donald E. (2003). The Art of Computer Programming. Vol. 3 (Second ed.). p. 418.
- Lourakis, Manolis. "Fibonaccian search in C". Retrieved January 18, 2007. Implements the above algorithm (not Ferguson's original one).