बहुपद मूल्यांकन: Difference between revisions

From Vigyanwiki
(Created page with "{{short description|Algorithms for polynomial evaluation}} गणित और कंप्यूटर विज्ञान में, बहुपद मूल्...")
 
No edit summary
Line 1: Line 1:
{{short description|Algorithms for polynomial evaluation}}
{{short description|Algorithms for polynomial evaluation}}


गणित और [[कंप्यूटर विज्ञान]] में, [[बहुपद]] मूल्यांकन एक बहुपद के मूल्य की गणना को संदर्भित करता है जब इसके [[अनिश्चित (चर)]] को कुछ मूल्यों के लिए प्रतिस्थापित किया जाता है। दूसरे शब्दों में, बहुपद का मूल्यांकन <math>P(x_1, x_2) = 2x_1x_2 + x_1^3 + 4</math> पर <math>x_1=2, x_2=3</math> कंप्यूटिंग के होते हैं <math>P(2,3)= 2\cdot 2\cdot 3 + 2^3+4=24.</math> यह सभी देखें {{slink|Polynomial ring|Polynomial evaluation}}
गणित और [[कंप्यूटर विज्ञान]] में, [[बहुपद]] मूल्यांकन एक बहुपद के मूल्य की गणना को संदर्भित करता है तथा इसके [[अनिश्चित (चर)|अनिश्चित चर]] को कुछ मूल्यों के लिए प्रतिस्थापित किया जाता है। दूसरे शब्दों में, बहुपद के मूल्यांकन <math>P(x_1, x_2) = 2x_1x_2 + x_1^3 + 4</math> पर <math>x_1=2, x_2=3</math>, <math>P(2,3)= 2\cdot 2\cdot 3 + 2^3+4=24.</math> में कंप्यूटिंग समिम्लित है,तथा {{slink| बहुपद वलय | बहुपद मूल्यांकन}} भी देखें


[[अविभाज्य बहुपद]] के मूल्यांकन के लिए <math>a_nx^n+a_{n-1}x^{n-1}+\cdots +a_0,</math> सबसे भोली विधि का उपयोग करेगा <math>n</math> गणना करने के लिए गुणन <math>a_n x^n</math>, उपयोग <math>n-1</math> गणना करने के लिए गुणन <math>a_{n-1} x^{n-1}</math> और इसी तरह कुल मिलाकर <math>\tfrac{n(n+1)}{2}</math> गुणन और <math>n</math> जोड़।
[[अविभाज्य बहुपद]] के मूल्यांकन के लिए <math>a_nx^n+a_{n-1}x^{n-1}+\cdots +a_0,</math> सबसे सरल विधि का उपयोग करेंगे <math>n</math> गुणन की गणना करने के लिए <math>a_n x^n</math>, का,तथा  <math>n-1</math> गुणन की गणना करने के लिए <math>a_{n-1} x^{n-1}</math> उपयोग करेंगे और इसी तरह कुल मिलाकर <math>\tfrac{n(n+1)}{2}</math> से गुणन करेंगेऔर <math>n</math> को जोड़ देंगे।हॉर्नर के नियम जैसे बेहतर विधियों का उपयोग करके <math>n</math> गुणन और <math>n</math> जोड़ को न्यूनतम किया जा सकता है। यदि कुछ प्रीप्रोसेसिंग की अनुमति दी जाती है, तो और भी बचत संभव है।
हॉर्नर के नियम जैसे बेहतर तरीकों का उपयोग करके इसे कम किया जा सकता है <math>n</math> गुणन और <math>n</math> जोड़। यदि कुछ प्रीप्रोसेसिंग की अनुमति दी जाती है, तो और भी बचत संभव है।


== पृष्ठभूमि ==
== पृष्ठभूमि ==
व्यवहार में यह समस्या अक्सर उत्पन्न होती है। [[कम्प्यूटेशनल ज्यामिति]] में, [[टेलर बहुपद]]ों का उपयोग करके फ़ंक्शन सन्निकटन की गणना करने के लिए बहुपदों का उपयोग किया जाता है। [[क्रिप्टोग्राफी]] और [[हैश तालिका]] में, [[के-स्वतंत्र हैशिंग]] की गणना करने के लिए बहुपद का उपयोग किया जाता है।
अभ्यास में यह समस्या सामान्यतया उत्पन्न होती है। [[कम्प्यूटेशनल ज्यामिति]] में, [[टेलर बहुपद|टेलर बहुपदों]] का उपयोग करके फ़ंक्शन सन्निकटन की गणना करने के लिए बहुपदों का उपयोग किया जाता है। [[क्रिप्टोग्राफी]] और [[हैश तालिका]] में, [[के-स्वतंत्र हैशिंग|k-स्वतंत्र हैशिंग]] की गणना करने के लिए बहुपद का उपयोग किया जाता है।


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


== सामान्य तरीके ==
== सामान्य विधि ==


=== हॉर्नर का नियम ===
=== हॉर्नर का नियम ===
{{see also|Horner's method}}
{{see also|हॉर्नर की विधि}}


हॉर्नर की विधि बार-बार ब्रैकेटिंग का उपयोग करके बहुपद का मूल्यांकन करती है:
हॉर्नर की विधि बार-बार ब्रैकेटिंग का उपयोग करके बहुपद का मूल्यांकन करती है:
Line 79: Line 78:
समतुल्य हॉर्नर फॉर्म में सुधार (यानी <math>P(x) = 1 + x (1 + x (1/2 + x(1/6 + x/24)))</math>) 1 गुणन द्वारा।
समतुल्य हॉर्नर फॉर्म में सुधार (यानी <math>P(x) = 1 + x (1 + x (1/2 + x(1/6 + x/24)))</math>) 1 गुणन द्वारा।


कुछ सामान्य विधियों में [[नुथ-ईव एल्गोरिथम]] और [[राबिन-विनोग्राद एल्गोरिथम]] शामिल हैं।
कुछ सामान्य विधियों में [[नुथ-ईव एल्गोरिथम]] और [[राबिन-विनोग्राद एल्गोरिथम]] समिम्लितहैं।


=== बहु बिंदु मूल्यांकन ===
=== बहु बिंदु मूल्यांकन ===
Line 97: Line 96:




ऐसे मामले में जहां जिन बिंदुओं पर हम बहुपदों का मूल्यांकन करना चाहते हैं, उनकी कुछ संरचना है, सरल तरीके मौजूद हैं।
ऐसे इस्थिति में जहां जिन बिंदुओं पर हम बहुपदों का मूल्यांकन करना चाहते हैं, उनकी कुछ संरचना है, सरल तरीके मौजूद हैं।
उदाहरण के लिए, नुथ<ref>{{Cite book |last=Knuth |first=Donald |title=[[Art of Computer Programming]] |publisher=[[Addison-Wesley]] |year=2005 |isbn=9780201853926 |volume=2: Seminumerical Algorithms |author-link=Donald Knuth}}</ref> खंड 4.6.4
उदाहरण के लिए, नुथ<ref>{{Cite book |last=Knuth |first=Donald |title=[[Art of Computer Programming]] |publisher=[[Addison-Wesley]] |year=2005 |isbn=9780201853926 |volume=2: Seminumerical Algorithms |author-link=Donald Knuth}}</ref> खंड 4.6.4
प्रकार के बहुपद मानों को सारणीबद्ध करने के लिए एक विधि देता है
प्रकार के बहुपद मानों को सारणीबद्ध करने के लिए एक विधि देता है
Line 105: Line 104:
=== गतिशील मूल्यांकन ===
=== गतिशील मूल्यांकन ===


मामले में जहां <math>x_1, \dots, x_m</math> पहले से पता नहीं होता,
इस्थिति में जहां <math>x_1, \dots, x_m</math> पहले से पता नहीं होता,
केदलया और उमंस<ref>{{Cite journal|last=Kedlaya|first=Kiran S.|author-link=Kiran Kedlaya|last2=Umans|first2=Christopher|author-link2=Chris Umans|date=2011|title=तेजी से बहुपद गुणनखंडन और मॉड्यूलर रचना|journal=[[SIAM Journal on Computing]]|volume=40|issue=6|pages=1767–1802|doi=10.1137/08073408x|hdl=1721.1/71792|hdl-access=free}}</ref> आकार के परिमित क्षेत्र में बहुपदों के मूल्यांकन के लिए एक डेटा संरचना प्रदान की <math>F_q</math> समय के भीतर <math>(\log n)^{O(1)}(\log_2 q)^{1+o(1)}</math> कुछ प्रारंभिक प्रीप्रोसेसिंग के बाद प्रति मूल्यांकन।
केदलया और उमंस<ref>{{Cite journal|last=Kedlaya|first=Kiran S.|author-link=Kiran Kedlaya|last2=Umans|first2=Christopher|author-link2=Chris Umans|date=2011|title=तेजी से बहुपद गुणनखंडन और मॉड्यूलर रचना|journal=[[SIAM Journal on Computing]]|volume=40|issue=6|pages=1767–1802|doi=10.1137/08073408x|hdl=1721.1/71792|hdl-access=free}}</ref> आकार के परिमित क्षेत्र में बहुपदों के मूल्यांकन के लिए एक डेटा संरचना प्रदान की <math>F_q</math> समय के भीतर <math>(\log n)^{O(1)}(\log_2 q)^{1+o(1)}</math> कुछ प्रारंभिक प्रीप्रोसेसिंग के बाद प्रति मूल्यांकन।
यह [[कैस्पर ग्रीन लार्सन]] द्वारा दिखाया गया था<ref>{{Cite journal|last=Larsen|first=K. G.|author-link=Kasper Green Larsen|date=2012|title=उच्च सेल जांच बहुपदों के मूल्यांकन के लिए निचली सीमा|journal=[[Symposium on Foundations of Computer Science]]|publisher=[[IEEE]]|volume=53|pages=293–301|doi=10.1109/FOCS.2012.21}}</ref> अनिवार्य रूप से इष्टतम होना।
यह [[कैस्पर ग्रीन लार्सन]] द्वारा दिखाया गया था<ref>{{Cite journal|last=Larsen|first=K. G.|author-link=Kasper Green Larsen|date=2012|title=उच्च सेल जांच बहुपदों के मूल्यांकन के लिए निचली सीमा|journal=[[Symposium on Foundations of Computer Science]]|publisher=[[IEEE]]|volume=53|pages=293–301|doi=10.1109/FOCS.2012.21}}</ref> अनिवार्य रूप से इष्टतम होना।
Line 129: Line 128:


एक विशेष रूप से दिलचस्प प्रकार का बहुपद घात है <math>x^n</math>.
एक विशेष रूप से दिलचस्प प्रकार का बहुपद घात है <math>x^n</math>.
ऐसे बहुपदों की गणना हमेशा की जा सकती है <math>O(\log n)</math> संचालन।
ऐसे बहुपदों की गणना सदैव की जा सकती है <math>O(\log n)</math> संचालन।
मान लीजिए, उदाहरण के लिए, हमें गणना करने की आवश्यकता है <math>x^{16}</math>; हम बस के साथ शुरू कर सकते हैं <math>x</math> और गुणा करें <math>x</math> पाने के <math>x^2</math>.
मान लीजिए, उदाहरण के लिए, हमें गणना करने की आवश्यकता है <math>x^{16}</math>; हम बस के साथ शुरू कर सकते हैं <math>x</math> और गुणा करें <math>x</math> पाने के <math>x^2</math>.
इसके बाद हम उसे प्राप्त करने के लिए उसी से गुणा कर सकते हैं <math>x^4</math> और इतने पर पाने के लिए <math>x^8</math> और <math>x^{16}</math> केवल चार गुणा में।
इसके बाद हम उसे प्राप्त करने के लिए उसी से गुणा कर सकते हैं <math>x^4</math> और इतने पर पाने के लिए <math>x^8</math> और <math>x^{16}</math> केवल चार गुणा में।
अन्य शक्तियां जैसे <math>x^5</math> इसी तरह पहली कंप्यूटिंग द्वारा कुशलतापूर्वक गणना की जा सकती है <math>x^4</math> 2 गुणा करके और फिर गुणा करके <math>x</math>.
अन्य शक्तियां जैसे <math>x^5</math> इसी तरह पहली कंप्यूटिंग द्वारा कुशलतापूर्वक गणना की जा सकती है <math>x^4</math> 2 गुणा करके और फिर गुणा करके <math>x</math>.


किसी दी गई शक्ति की गणना करने का सबसे कुशल तरीका <math>x^n</math> अतिरिक्त-श्रृंखला घातांक द्वारा प्रदान किया जाता है। हालांकि, इसके लिए प्रत्येक प्रतिपादक के लिए एक विशिष्ट एल्गोरिदम डिजाइन करने की आवश्यकता होती है, और इन एल्गोरिदम को डिजाइन करने के लिए आवश्यक गणना कठिन (एनपी-पूर्ण) होती है, इसलिए प्रभावी संगणनाओं के लिए आमतौर पर वर्ग द्वारा घातांक को प्राथमिकता दी जाती है।
किसी दी गई शक्ति की गणना करने का सबसे कुशल तरीका <math>x^n</math> अतिरिक्त-श्रृंखला घातांक द्वारा प्रदान किया जाता है। हालांकि, इसके लिए प्रत्येक प्रतिपादक के लिए एक विशिष्ट एल्गोरिदम डिजाइन करने की आवश्यकता होती है, और इन एल्गोरिदम को डिजाइन करने के लिए आवश्यक गणना कठिन (एनपी-पूर्ण) होती है, इसलिए प्रभावी संगणनाओं के लिए सामान्यत पर वर्ग द्वारा घातांक को प्राथमिकता दी जाती है।


=== बहुपद परिवार ===
=== बहुपद परिवार ===


अक्सर बहुपद प्रसिद्ध से भिन्न रूप में दिखाई देते हैं <math>a_n x^n + \dots + a_1 x + a_0</math>.
सामान्यतया बहुपद प्रसिद्ध से भिन्न रूप में दिखाई देते हैं <math>a_n x^n + \dots + a_1 x + a_0</math>.
[[चेबिशेव रूप]] में बहुपदों के लिए हम [[क्लेंशॉ एल्गोरिथम]] का उपयोग कर सकते हैं।
[[चेबिशेव रूप]] में बहुपदों के लिए हम [[क्लेंशॉ एल्गोरिथम]] का उपयोग कर सकते हैं।
बेजियर रूप में बहुपदों के लिए हम डी कास्टलजौ के एल्गोरिदम का उपयोग कर सकते हैं,
बेजियर रूप में बहुपदों के लिए हम डी कास्टलजौ के एल्गोरिदम का उपयोग कर सकते हैं,
Line 151: Line 150:
कम से कम यह बाध्यता धारण करती है यदि केवल उन प्रकार के संचालन की अनुमति दी जाती है, जो लंबाई की तथाकथित बहुपद श्रृंखला को जन्म देती है <math><n^2/\log n</math>.
कम से कम यह बाध्यता धारण करती है यदि केवल उन प्रकार के संचालन की अनुमति दी जाती है, जो लंबाई की तथाकथित बहुपद श्रृंखला को जन्म देती है <math><n^2/\log n</math>.


स्ट्रैसन द्वारा दिए गए बहुपद में बहुत बड़े गुणांक हैं, लेकिन संभाव्य तरीकों से, कोई दिखा सकता है कि केवल 0 और 1 के गुणांक वाले बहुपदों का अस्तित्व होना चाहिए, जैसे कि मूल्यांकन के लिए कम से कम आवश्यकता होती है <math>\Omega(n/\log n)</math> गुणन।<ref>{{Citation|last=Schnorr|first=C. P.|title=On the additive complexity of polynomials and some new lower bounds|date=1979|url=|work=[[Theoretical Computer Science (journal)|Theoretical Computer Science]]|volume=67|pages=286–297|editor-last=|editor-first=|place=|publisher=[[Springer Publishing|Springer]]|doi=10.1007/3-540-09118-1_30|isbn=|access-date=|author-link=Claus P. Schnorr}}</ref>
स्ट्रैसन द्वारा दिए गए बहुपद में बहुत बड़े गुणांक हैं, लेकिन संभाव्य विधियों से, कोई दिखा सकता है कि केवल 0 और 1 के गुणांक वाले बहुपदों का अस्तित्व होना चाहिए, जैसे कि मूल्यांकन के लिए कम से कम आवश्यकता होती है <math>\Omega(n/\log n)</math> गुणन।<ref>{{Citation|last=Schnorr|first=C. P.|title=On the additive complexity of polynomials and some new lower bounds|date=1979|url=|work=[[Theoretical Computer Science (journal)|Theoretical Computer Science]]|volume=67|pages=286–297|editor-last=|editor-first=|place=|publisher=[[Springer Publishing|Springer]]|doi=10.1007/3-540-09118-1_30|isbn=|access-date=|author-link=Claus P. Schnorr}}</ref>
अन्य साधारण बहुपदों के लिए, जटिलता अज्ञात है।
अन्य साधारण बहुपदों के लिए, जटिलता अज्ञात है।
बहुपद <math>(x+1)(x+2)\cdots(x+n)</math> समय पर गणना करने योग्य नहीं होने का अनुमान है <math>(\log n)^{c}</math> किसी के लिए <math>c</math>.
बहुपद <math>(x+1)(x+2)\cdots(x+n)</math> समय पर गणना करने योग्य नहीं होने का अनुमान है <math>(\log n)^{c}</math> किसी के लिए <math>c</math>.

Revision as of 19:55, 15 March 2023

गणित और कंप्यूटर विज्ञान में, बहुपद मूल्यांकन एक बहुपद के मूल्य की गणना को संदर्भित करता है तथा इसके अनिश्चित चर को कुछ मूल्यों के लिए प्रतिस्थापित किया जाता है। दूसरे शब्दों में, बहुपद के मूल्यांकन पर , में कंप्यूटिंग समिम्लित है,तथा बहुपद वलय § बहुपद मूल्यांकन भी देखें

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

पृष्ठभूमि

अभ्यास में यह समस्या सामान्यतया उत्पन्न होती है। कम्प्यूटेशनल ज्यामिति में, टेलर बहुपदों का उपयोग करके फ़ंक्शन सन्निकटन की गणना करने के लिए बहुपदों का उपयोग किया जाता है। क्रिप्टोग्राफी और हैश तालिका में, k-स्वतंत्र हैशिंग की गणना करने के लिए बहुपद का उपयोग किया जाता है।

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

सामान्य विधि

हॉर्नर का नियम

हॉर्नर की विधि बार-बार ब्रैकेटिंग का उपयोग करके बहुपद का मूल्यांकन करती है:

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

बहुभिन्नरूपी

यदि बहुपद बहुभिन्नरूपी है, तो हॉर्नर के नियम को चर के कुछ क्रम पर पुनरावर्ती रूप से लागू किया जा सकता है। उदा.

रूप में लिखा जा सकता है

इस दृष्टिकोण का एक कुशल संस्करण कार्निसर और गैस्का द्वारा वर्णित किया गया था।[1]


एस्ट्रिन की योजना

हालांकि हॉर्नर के नियम (प्रीप्रोसेसिंग के बिना) की तुलना में कम संगणना करना संभव नहीं है, आधुनिक कंप्यूटरों पर मूल्यांकन का क्रम कम्प्यूटेशनल दक्षता के लिए बहुत मायने रख सकता है। एस्ट्रिन की योजना के रूप में जाना जाने वाला एक तरीका पेड़ जैसे पैटर्न में एक (एकल भिन्न) बहुपद की गणना करता है:

वर्ग द्वारा घातांक द्वारा संयुक्त, यह संगणना को समानांतर करने की अनुमति देता है।

प्रीप्रोसेसिंग के साथ मूल्यांकन

मनमाने बहुपदों का मूल्यांकन कम के साथ किया जा सकता है अगर हम पहले प्रीप्रोसेस करते हैं तो हॉर्नर के नियम की तुलना में संचालन की आवश्यकता होती है गुणांक .

एक उदाहरण सबसे पहले Motzkin ने दिया था[2] जिसने नोट किया

रूप में लिखा जा सकता है

जहां मान के आधार पर अग्रिम गणना की जाती है . हॉर्नर के 4 की तुलना में मोट्ज़किन की विधि केवल 3 गुणन का उपयोग करती है।

प्रत्येक के लिए मान विस्तार करके आसानी से परिकलित किया जा सकता है और गुणांकों की बराबरी करना:


उदाहरण

टेलर विस्तार की गणना करने के लिए , हम एक कारक 24 तक बढ़ा सकते हैं, उपरोक्त चरणों को लागू कर सकते हैं, और वापस स्केल कर सकते हैं। यह हमें तीन गुणन संगणना देता है

समतुल्य हॉर्नर फॉर्म में सुधार (यानी ) 1 गुणन द्वारा।

कुछ सामान्य विधियों में नुथ-ईव एल्गोरिथम और राबिन-विनोग्राद एल्गोरिथम समिम्लितहैं।

बहु बिंदु मूल्यांकन

ए का मूल्यांकन करें -डिग्री बहुपद कई बिंदुओं में से किया जा सकता है हॉर्नर की विधि का उपयोग करके गुणन बार। उपरोक्त प्रीप्रोसेसिंग दृष्टिकोण का उपयोग करके, इसे दो के कारक से कम किया जा सकता है, अर्थात गुणन। हालांकि, बेहतर करना संभव है। समय की आवश्यकता को कम करना संभव है .[3] विचार दो बहुपदों को परिभाषित करना है जो क्रमशः पहले और दूसरे भाग में शून्य हैं: और . हम फिर गणना करते हैं और बहुपद विभाजन का उपयोग करके, जो में किया जा सकता है एक तेज फूरियर रूपांतरण का उपयोग करते हुए समय। इसका मतलब यह है और निर्माण द्वारा, कहाँ और अधिक से अधिक डिग्री के बहुपद हैं . कैसे के कारण और परिभाषित किया गया था, हमारे पास है

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


ऐसे इस्थिति में जहां जिन बिंदुओं पर हम बहुपदों का मूल्यांकन करना चाहते हैं, उनकी कुछ संरचना है, सरल तरीके मौजूद हैं। उदाहरण के लिए, नुथ[4] खंड 4.6.4 प्रकार के बहुपद मानों को सारणीबद्ध करने के लिए एक विधि देता है


गतिशील मूल्यांकन

इस्थिति में जहां पहले से पता नहीं होता, केदलया और उमंस[5] आकार के परिमित क्षेत्र में बहुपदों के मूल्यांकन के लिए एक डेटा संरचना प्रदान की समय के भीतर कुछ प्रारंभिक प्रीप्रोसेसिंग के बाद प्रति मूल्यांकन। यह कैस्पर ग्रीन लार्सन द्वारा दिखाया गया था[6] अनिवार्य रूप से इष्टतम होना।

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

विशिष्ट बहुपद

जबकि सामान्य बहुपदों की आवश्यकता होती है संचालन का मूल्यांकन करने के लिए, कुछ बहुपदों की गणना बहुत तेजी से की जा सकती है। उदाहरण के लिए, बहुपद केवल एक गुणन और एक जोड़ का उपयोग करके गणना की जा सकती है


शक्तियों का मूल्यांकन

एक विशेष रूप से दिलचस्प प्रकार का बहुपद घात है . ऐसे बहुपदों की गणना सदैव की जा सकती है संचालन। मान लीजिए, उदाहरण के लिए, हमें गणना करने की आवश्यकता है ; हम बस के साथ शुरू कर सकते हैं और गुणा करें पाने के . इसके बाद हम उसे प्राप्त करने के लिए उसी से गुणा कर सकते हैं और इतने पर पाने के लिए और केवल चार गुणा में। अन्य शक्तियां जैसे इसी तरह पहली कंप्यूटिंग द्वारा कुशलतापूर्वक गणना की जा सकती है 2 गुणा करके और फिर गुणा करके .

किसी दी गई शक्ति की गणना करने का सबसे कुशल तरीका अतिरिक्त-श्रृंखला घातांक द्वारा प्रदान किया जाता है। हालांकि, इसके लिए प्रत्येक प्रतिपादक के लिए एक विशिष्ट एल्गोरिदम डिजाइन करने की आवश्यकता होती है, और इन एल्गोरिदम को डिजाइन करने के लिए आवश्यक गणना कठिन (एनपी-पूर्ण) होती है, इसलिए प्रभावी संगणनाओं के लिए सामान्यत पर वर्ग द्वारा घातांक को प्राथमिकता दी जाती है।

बहुपद परिवार

सामान्यतया बहुपद प्रसिद्ध से भिन्न रूप में दिखाई देते हैं . चेबिशेव रूप में बहुपदों के लिए हम क्लेंशॉ एल्गोरिथम का उपयोग कर सकते हैं। बेजियर रूप में बहुपदों के लिए हम डी कास्टलजौ के एल्गोरिदम का उपयोग कर सकते हैं, और B-splines के लिए De Boor's एल्गोरिथम है।

कठिन बहुपद

तथ्य यह है कि कुछ बहुपदों की गणना सामान्य बहुपदों की तुलना में काफी तेजी से की जा सकती है, यह प्रश्न सुझाता है: क्या हम एक साधारण बहुपद का उदाहरण दे सकते हैं जिसकी गणना इसकी डिग्री से बहुत कम समय में नहीं की जा सकती है? वोल्कर स्ट्रास ने दिखाया है[7] वह बहुपद

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

स्ट्रैसन द्वारा दिए गए बहुपद में बहुत बड़े गुणांक हैं, लेकिन संभाव्य विधियों से, कोई दिखा सकता है कि केवल 0 और 1 के गुणांक वाले बहुपदों का अस्तित्व होना चाहिए, जैसे कि मूल्यांकन के लिए कम से कम आवश्यकता होती है गुणन।[8] अन्य साधारण बहुपदों के लिए, जटिलता अज्ञात है। बहुपद समय पर गणना करने योग्य नहीं होने का अनुमान है किसी के लिए . यह इस तथ्य से समर्थित है, कि यदि इसकी तेजी से गणना की जा सकती है, तो RSA (क्रिप्टोसिस्टम) को तोड़ते हुए बहुपद समय में पूर्णांक गुणनखंड की गणना की जा सकती है।[9]


मैट्रिक्स बहुपद

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

मैट्रिक्स बहुपद महत्वपूर्ण हैं उदाहरण के लिए मैट्रिक्स एक्सपोनेंशियल # मैट्रिक्स एक्सपोनेंशियल कंप्यूटिंग।

पैटर्सन और स्टॉकमेयर [10] डिग्री की गणना करने का तरीका दिखाया बहुपद केवल का उपयोग कर गैर अदिश गुणन और अदिश गुणन। इस प्रकार डिग्री का एक मैट्रिक्स बहुपद n में मूल्यांकन किया जा सकता है समय। अगर यह इससे कम है वह है, मानक एल्गोरिथम के साथ एकल मैट्रिक्स गुणन से तेज़।

यह विधि इस प्रकार काम करती है: एक बहुपद के लिए

होने देना k सबसे छोटा पूर्णांक हो जो इससे छोटा न हो शक्तियाँ के साथ गणना की जाती है मैट्रिक्स गुणन, और द्वारा बार-बार गुणा करके गणना की जाती है अब,

,

कहाँ के लिए in. इसके लिए बस आवश्यकता है अधिक गैर-अदिश गुणन।

क्रोनकर उत्पाद का उपयोग करके हम इसे संक्षेप में लिख सकते हैं:

.

इस पद्धति का प्रत्यक्ष अनुप्रयोग उपयोग करता है गैर-अदिश गुणन, लेकिन इसे बहुपद_मूल्यांकन#Evaluation_with_preprocessing के साथ जोड़कर, पैटर्सन और स्टॉकमेयर दिखाते हैं कि आप इसे कम कर सकते हैं .

यह भी देखें

  • एस्ट्रिन की योजना आधुनिक कंप्यूटर आर्किटेक्चर पर समानांतरकरण की सुविधा के लिए
  • अंकगणित सर्किट जटिलता सिद्धांत विभिन्न बहुपदों के मूल्यांकन के कम्प्यूटेशनल जटिलता सिद्धांत का अध्ययन करता है।

संदर्भ

  1. Carnicer, J.; Gasca, M. (1990). "बहुभिन्नरूपी बहुपदों और उनके डेरिवेटिव का मूल्यांकन". Mathematics of Computation. 54 (189): 231–243. doi:10.2307/2008692.
  2. Motzkin, T. S. (1955). "बहुपदों का मूल्यांकन और तर्कसंगत कार्यों का मूल्यांकन". Bulletin of the American Mathematical Society. 61 (163): 10.
  3. Von Zur Gathen, Joachim; Jürgen, Gerhard (2013). आधुनिक कंप्यूटर बीजगणित. Cambridge University Press. Chapter 10. ISBN 9781139856065.
  4. Knuth, Donald (2005). Art of Computer Programming. Vol. 2: Seminumerical Algorithms. Addison-Wesley. ISBN 9780201853926.
  5. Kedlaya, Kiran S.; Umans, Christopher (2011). "तेजी से बहुपद गुणनखंडन और मॉड्यूलर रचना". SIAM Journal on Computing. 40 (6): 1767–1802. doi:10.1137/08073408x. hdl:1721.1/71792.
  6. Larsen, K. G. (2012). "उच्च सेल जांच बहुपदों के मूल्यांकन के लिए निचली सीमा". Symposium on Foundations of Computer Science. IEEE. 53: 293–301. doi:10.1109/FOCS.2012.21.
  7. Strassen, Volker (1974). "परिमेय गुणांक वाले बहुपद जिनकी गणना करना कठिन है". SIAM Journal on Computing (in English). 3 (2): 128–149. doi:10.1137/0203010.
  8. Schnorr, C. P. (1979), "On the additive complexity of polynomials and some new lower bounds", Theoretical Computer Science, Springer, vol. 67, pp. 286–297, doi:10.1007/3-540-09118-1_30
  9. Chen, Xi, Neeraj Kayal, and Avi Wigderson. Partial derivatives in arithmetic complexity and beyond. Now Publishers Inc, 2011.
  10. Paterson, Michael S.; Stockmeyer, Larry J. (1973). "बहुपदों का मूल्यांकन करने के लिए आवश्यक नॉनस्केलर गुणन की संख्या पर". SIAM Journal on Computing (in English). 2 (1): 60–66. doi:10.1137/0202007.