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

From Vigyanwiki
(Created page with "{{short description|Algorithms for polynomial evaluation}} गणित और कंप्यूटर विज्ञान में, बहुपद मूल्...")
 
No edit summary
 
(7 intermediate revisions by 3 users not shown)
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|हॉर्नर की विधि}}


हॉर्नर की विधि बार-बार ब्रैकेटिंग का उपयोग करके बहुपद का मूल्यांकन करती है:
हॉर्नर विधि बार-बार ब्रैकेटिंग का उपयोग करके बहुपद का मूल्यांकन करती है:
<math display="block">\begin{align}
<math display="block">\begin{align}
a_0 + &a_1x + a_2x^2 + a_3x^3 + \cdots + a_nx^n \\
a_0 + &a_1x + a_2x^2 + a_3x^3 + \cdots + a_nx^n \\
  &= a_0 + x \bigg(a_1 + x \Big(a_2 + x \big(a_3 + \cdots + x(a_{n-1} + x\,a_n) \cdots \big) \Big) \bigg).
  &= a_0 + x \bigg(a_1 + x \Big(a_2 + x \big(a_3 + \cdots + x(a_{n-1} + x\,a_n) \cdots \big) \Big) \bigg).
\end{align}</math>
\end{align}</math>
यह विधि गुणन और जोड़ की संख्या को घटाकर केवल कर देती है <math>n</math>
यह विधि गुणन और जोड़ की संख्या को घटाकर केवल <math>n</math> कर देती है ,
हॉर्नर की विधि इतनी सामान्य है कि कई कंप्यूटर प्रोसेसर में एक कंप्यूटर निर्देश गुणा-जमा ऑपरेशन जोड़ा गया है, जो एक संयुक्त चरण में जोड़ और गुणा संचालन करने की अनुमति देता है।
 
हॉर्नर विधि इतनी सामान्य है,कि कई कंप्यूटर प्रोसेसर में एक कंप्यूटर निर्देश गुणा-संचय ऑपरेशन जोड़ा गया है, जो एक संयुक्त चरण में जोड़ और गुणा ऑपरेशन करने की अनुमति देता है।


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


यदि बहुपद बहुभिन्नरूपी है, तो हॉर्नर के नियम को चर के कुछ क्रम पर पुनरावर्ती रूप से लागू किया जा सकता है।
यदि बहुपद बहुभिन्नरूपी है, तो हॉर्नर के नियम को चर के कुछ क्रम पर पुनरावर्ती रूप से प्रारंभ किया जा सकता है।
उदा.
 
उदाहरण.
:<math>P(x, y) = 4 + x + 2 x y + 2 x^2 y + x^2 y^2</math>
:<math>P(x, y) = 4 + x + 2 x y + 2 x^2 y + x^2 y^2</math>
रूप में लिखा जा सकता है
के रूप में लिखा जा सकता है
:<math>\begin{align}
:<math>\begin{align}
P(x, y) &= 4 + x (1 + y(2) + x (y(2 + y)))
P(x, y) &= 4 + x (1 + y(2) + x (y(2 + y)))
Line 39: Line 40:


==== एस्ट्रिन की योजना ====
==== एस्ट्रिन की योजना ====
{{see also|Estrin's scheme}}
{{see also|एस्ट्रिन की योजना}}


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


<math display="block">\begin{align}
<math display="block">\begin{align}
P(x) = (a_0 + a_1 x) + (a_2 + a_3 x) x^2 + ((a_4 + a_5 x) + (a_6 + a_7 x) x^2)x^4.
P(x) = (a_0 + a_1 x) + (a_2 + a_3 x) x^2 + ((a_4 + a_5 x) + (a_6 + a_7 x) x^2)x^4.
\end{align}</math>
\end{align}</math>
वर्ग द्वारा घातांक द्वारा संयुक्त, यह संगणना को समानांतर करने की अनुमति देता है।
वर्ग और घातांक द्वारा संयुक्त संगणना को समानांतर करने की अनुमति देता है।


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


मनमाने बहुपदों का मूल्यांकन कम के साथ किया जा सकता है
मनमाने बहुपदों का मूल्यांकन न्यूनतम के सापेक्ष किया जा सकता है अगर हम पहले प्रीप्रोसेस करते हैं तो हॉर्नर के नियम की सापेक्ष में संचालन की आवश्यकता होती है गुणांक <math>a_n, \dots, a_0</math>.
अगर हम पहले प्रीप्रोसेस करते हैं तो हॉर्नर के नियम की तुलना में संचालन की आवश्यकता होती है
गुणांक <math>a_n, \dots, a_0</math>.


एक उदाहरण सबसे पहले Motzkin ने दिया था<ref>{{Cite journal|last=Motzkin|first=T. S.|date=1955|title=बहुपदों का मूल्यांकन और तर्कसंगत कार्यों का मूल्यांकन|journal=[[Bulletin of the American Mathematical Society]]|volume=61|issue=163|pages=10|issn=}}</ref> जिसने नोट किया
एक उदाहरण सबसे पहले मोट्ज़किन ने दिया था<ref>{{Cite journal|last=Motzkin|first=T. S.|date=1955|title=बहुपदों का मूल्यांकन और तर्कसंगत कार्यों का मूल्यांकन|journal=[[Bulletin of the American Mathematical Society]]|volume=61|issue=163|pages=10|issn=}}</ref> जिन्होंने यह नोट किया था
:<math>P(x)=x^4 + a_3 x^3 + a_2 x^2 + a_1 x + a_0</math>
:<math>P(x)=x^4 + a_3 x^3 + a_2 x^2 + a_1 x + a_0</math>
रूप में लिखा जा सकता है
के रूप में लिखा जा सकता है
:<math>y = (x+\beta_0)x+\beta_1,\quad P(x)=(y+x+\beta_2)y+\beta_3,</math>
:<math>y = (x+\beta_0)x+\beta_1,\quad P(x)=(y+x+\beta_2)y+\beta_3,</math>
जहां मान <math>\beta_0, \dots, \beta_3</math> के आधार पर अग्रिम गणना की जाती है <math>a_0, \dots, a_3</math>.
जहां मान <math>\beta_0, \dots, \beta_3</math> के आधार पर अग्रिम गणना की जाती है <math>a_0, \dots, a_3</math>.हॉर्नर के 4 के सापेक्ष में मोट्ज़किन की विधि केवल 3 गुणन का उपयोग करती है।
हॉर्नर के 4 की तुलना में मोट्ज़किन की विधि केवल 3 गुणन का उपयोग करती है।


प्रत्येक के लिए मान <math>\beta_i</math> विस्तार करके आसानी से परिकलित किया जा सकता है <math>P(x)</math> और गुणांकों की बराबरी करना:
प्रत्येक के लिए मान <math>\beta_i</math> विस्तार करके आसानी से परिकलित किया जा सकता है <math>P(x)</math> और गुणांकों की समान करना:
:<math>\begin{align}
:<math>\begin{align}
\beta_0&=\tfrac12(a_3-1),\quad
\beta_0&=\tfrac12(a_3-1),\quad
Line 73: Line 71:


==== उदाहरण ====
==== उदाहरण ====
[[टेलर विस्तार]] की गणना करने के लिए <math>\exp(x) \approx 1+x+x^2/2+x^3/6+x^4/24</math>,
[[टेलर विस्तार]] की गणना करने के लिए <math>\exp(x) \approx 1+x+x^2/2+x^3/6+x^4/24</math>, हम एक कारक को 24 तक बढ़ा सकते हैं, उपरोक्त चरणों को प्रारंभ कर सकते हैं, और स्केल वापस कर सकते हैं।यह हमें तीन बार गुणन संगणना देता है
हम एक कारक 24 तक बढ़ा सकते हैं, उपरोक्त चरणों को लागू कर सकते हैं, और वापस स्केल कर सकते हैं।
यह हमें तीन गुणन संगणना देता है
:<math>y = (x+1.5)x+11.625,\quad P(x)=(y+x-15)y/24+2.63477.</math>
:<math>y = (x+1.5)x+11.625,\quad P(x)=(y+x-15)y/24+2.63477.</math>
समतुल्य हॉर्नर फॉर्म में सुधार (यानी <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 गुणन द्वारा।


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


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


ए का मूल्यांकन करें <math>n</math>-डिग्री बहुपद <math>P(x)</math> कई बिंदुओं में <math>x_1, \dots, x_m</math> से किया जा सकता है <math>mn</math> हॉर्नर की विधि का उपयोग करके गुणन <math>m</math> बार। उपरोक्त प्रीप्रोसेसिंग दृष्टिकोण का उपयोग करके, इसे दो के कारक से कम किया जा सकता है, अर्थात <math>mn/2</math> गुणन। हालांकि, बेहतर करना संभव है।
एक  <math>n</math>-डिग्री बहुपद और <math>P(x)</math> तथा कई बिंदुओं का मूल्यांकन  <math>x_1, \dots, x_m</math> से किया जा सकता है हॉर्नर  विधि का उपयोग करके <math>mn</math> का गुणन <math>m</math> बार किया जाता हैं। प्रीप्रोसेसिंग दृष्टिकोण का उपरोक्त उपयोग करके, इसे दो के कारक से न्यूनतम, अर्थात <math>mn/2</math> गुणन किया जा सकता है। यद्यपि , इससे बेहतर करना संभव है।
समय की आवश्यकता को कम करना संभव है <math>O\big((n + m) \log^2(n + m)\big)</math>.<ref>{{cite book |last1=Von Zur Gathen |first1=Joachim |title=आधुनिक कंप्यूटर बीजगणित|last2=Jürgen |first2=Gerhard |publisher=[[Cambridge University Press]] |year=2013 |isbn=9781139856065 |at=Chapter 10 |author-link=Joachim von zur Gathen}}</ref>
 
विचार दो बहुपदों को परिभाषित करना है जो क्रमशः पहले और दूसरे भाग में शून्य हैं: <math>m_0(x)=(x-x_1)\cdots(x-x_{n/2})</math> और <math>m_1(x)=(x-x_{n/2+1})\cdots(x-x_{n})</math>.
समय की आवश्यकता को <math>O\big((n + m) \log^2(n + m)\big)</math> न्यूनतम करना संभव है .<ref>{{cite book |last1=Von Zur Gathen |first1=Joachim |title=आधुनिक कंप्यूटर बीजगणित|last2=Jürgen |first2=Gerhard |publisher=[[Cambridge University Press]] |year=2013 |isbn=9781139856065 |at=Chapter 10 |author-link=Joachim von zur Gathen}}</ref>वो सिद्धांत जो दो बहुपदों को परिभाषित करता है तथा जो क्रमशः पहले और दूसरे भाग में शून्य हैं:तथा<math>m_0(x)=(x-x_1)\cdots(x-x_{n/2})</math> और <math>m_1(x)=(x-x_{n/2+1})\cdots(x-x_{n})</math>.हम पुनः गणना करते हैं <math>R_0 = P \bmod m_0</math> और <math>R_1 = P \bmod m_1</math> [[बहुपद विभाजन]] का उपयोग करके, जो में किया जा सकता है <math>O(n\log n)</math> एक तीव्र फूरियर रूपांतरण का उपयोग करते समय हुए था। इसका मतलब यह है <math>P(x) = Q(x)m_0(x) + R_0(x)</math> और <math>P(x) = Q(x)m_1(x) + R_1(x)</math> निर्माण द्वारा, जहाँ <math>R_0</math> और <math>R_1</math> अधिकतम डिग्री के बहुपद हैं <math>n/2</math>.जिसके कारण <math>m_0</math> और <math>m_1</math> परिभाषित किया गया था, और हमारे पास है
हम फिर गणना करते हैं <math>R_0 = P \bmod m_0</math> और <math>R_1 = P \bmod m_1</math> [[बहुपद विभाजन]] का उपयोग करके, जो में किया जा सकता है <math>O(n\log n)</math> एक तेज फूरियर रूपांतरण का उपयोग करते हुए समय।
इसका मतलब यह है <math>P(x) = Q(x)m_0(x) + R_0(x)</math> और <math>P(x) = Q(x)m_1(x) + R_1(x)</math> निर्माण द्वारा, कहाँ <math>R_0</math> और <math>R_1</math> अधिक से अधिक डिग्री के बहुपद हैं <math>n/2</math>.
कैसे के कारण <math>m_0</math> और <math>m_1</math> परिभाषित किया गया था, हमारे पास है
:<math>\begin{align}
:<math>\begin{align}
R_0(x_i) &= P(x_i) \quad\text{for } i \le n/2 \quad\text{and}\\
R_0(x_i) &= P(x_i) \quad\text{for } i \le n/2 \quad\text{and}\\
R_1(x_i) &= P(x_i) \quad\text{for } i > n/2.
R_1(x_i) &= P(x_i) \quad\text{for } i > n/2.
\end{align}</math>
\end{align}</math>
इस प्रकार गणना करने के लिए <math>P</math> सब पर <math>n</math> की <math>x_i</math>, यह छोटे बहुपदों की गणना करने के लिए पर्याप्त है <math>R_0</math> और <math>R_1</math> प्रत्येक आधे अंक पर।
इस प्रकार गणना करने के लिए <math>P</math> सब पर <math>n</math> की <math>x_i</math>, यह छोटे बहुपदों की गणना करने के लिए पर्याप्त है <math>R_0</math> और <math>R_1</math> प्रत्येक आधे अंक पर।यह हमें एक डिवाइड-एंड-कॉन्कर एल्गोरिथम देता है <math>T(n) = 2T(n/2) + n\log n</math>, जो <math>T(n)=O(n(\log n)^2)</math> [[मास्टर प्रमेय (एल्गोरिदम का विश्लेषण)]] द्वारा ये दर्शाता हे।
यह हमें एक फूट डालो और जीतो एल्गोरिथम देता है <math>T(n) = 2T(n/2) + n\log n</math>, जो ये दर्शाता हे <math>T(n)=O(n(\log n)^2)</math> [[मास्टर प्रमेय (एल्गोरिदम का विश्लेषण)]] द्वारा।




ऐसे मामले में जहां जिन बिंदुओं पर हम बहुपदों का मूल्यांकन करना चाहते हैं, उनकी कुछ संरचना है, सरल तरीके मौजूद हैं।
 
उदाहरण के लिए, नुथ<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 प्रकार के बहुपद मानों को सारणीबद्ध करने के लिए एक विधि देता है  
प्रकार के बहुपद मानों को सारणीबद्ध करने के लिए एक विधि देता है
:<math>P(x_0 + h), P(x_0 + 2h), \dots.</math>
:<math>P(x_0 + h), P(x_0 + 2h), \dots.</math>


Line 105: Line 96:
=== गतिशील मूल्यांकन ===
=== गतिशील मूल्यांकन ===


मामले में जहां <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=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=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> अनिवार्य रूप से इष्टतम होना।


विचार रूपांतरित करना है <math>P(x)</math> डिग्री का <math>n</math> एक [[बहुभिन्नरूपी बहुपद]] में <math>f(x_1, x_2, \dots, x_m)</math>, ऐसा है कि <math>P(x) = f(x, x^d, x^{d^2}, \dots, x^{d^m})</math> और व्यक्तिगत डिग्री <math>f</math> अधिक से अधिक है <math>d</math>.
विचार रूपांतरित हो गया था  <math>P(x)</math> डिग्री <math>n</math> के एक [[बहुभिन्नरूपी बहुपद]] में <math>f(x_1, x_2, \dots, x_m)</math>, ऐसा है कि <math>P(x) = f(x, x^d, x^{d^2}, \dots, x^{d^m})</math> और व्यक्तिगत डिग्री <math>f</math> से <math>d</math>. अधिकतम है क्योंकी यह समाप्त हो गया है और <math>\bmod q</math>, सबसे बड़ा मूल्य <math>f</math> ले (ओवर <math>\mathbb {Z} )</math> ,<math>{\displaystyle M=d^{m}(q-1)^{dm}}</math> सकता है । [[चीनी शेष प्रमेय]] का उपयोग करना, यह मूल्यांकन करने के लिए पर्याप्त है <math>f</math> मॉड्यूलो विभिन्न प्राइम्स <math>p_1, \dots, p_\ell</math> एक उत्पाद के सापेक्ष न्यूनतम से न्यूनतम <math>M</math>. प्रत्येक अभाज्य को <math>\log M = O(dm\log q)</math> मोटे तौर पर लिया जा सकता है , और आवश्यक अभाज्य संख्याओं की संख्या, <math>\ell</math>, लगभग समान है। इस प्रक्रिया को पुनरावर्ती रूप से करते हुए, हम अभाज्य संख्या जितनी छोटी संख्या  <math>\log\log q</math>. प्राप्त कर सकते हैं  इसका अर्थ है कि हम <math>f</math> में सभी संभावित मूल्यों पर <math>T = (\log\log q)^m</math> समय और स्थान के सापेक्ष  गणना और स्टोर कर सकते हैं।अगर हम लेते हैं <math>d = \log q</math>, हम पाते हैं <math>m = \tfrac{\log n}{\log\log q}</math>, इसलिए समय/स्थान की आवश्यकता <math>n^\frac{\log\log q}{\log\log\log q}.</math> उचित है।
चूंकि यह खत्म हो गया है <math>\bmod q</math>, सबसे बड़ा मूल्य <math>f</math> ले सकता है (ओवर <math>\mathbb Z</math>) है <math>M = d^m (q-1)^{dm}</math>.
 
[[चीनी शेष प्रमेय]] का उपयोग करना, यह मूल्यांकन करने के लिए पर्याप्त है <math>f</math> मॉड्यूलो विभिन्न प्राइम्स <math>p_1, \dots, p_\ell</math> एक उत्पाद के साथ कम से कम <math>M</math>.
केदलया और उमंस के आगे यह दर्शाते हैं कि इस तीव्र प्रीप्रोसेसिंग को मल्टीपॉइंट मूल्यांकन के सापेक्ष कैसे जोड़ा जाए। यह बहुपद [[मॉड्यूलर रचना]] जैसे कई महत्वपूर्ण बीजगणितीय समस्याओं के लिए इष्टतम एल्गोरिदम की अनुमति देता है।
प्रत्येक प्रधान को मोटे तौर पर लिया जा सकता है <math>\log M = O(dm\log q)</math>, और आवश्यक अभाज्य संख्याओं की संख्या, <math>\ell</math>, लगभग समान है।
इस प्रक्रिया को पुनरावर्ती रूप से करते हुए, हम अभाज्य संख्या जितनी छोटी प्राप्त कर सकते हैं <math>\log\log q</math>.
इसका मतलब है कि हम गणना और स्टोर कर सकते हैं <math>f</math> में सभी संभावित मूल्यों पर <math>T = (\log\log q)^m</math> समय और स्थान।
अगर हम लेते हैं <math>d = \log q</math>, हम पाते हैं <math>m = \tfrac{\log n}{\log\log q}</math>, इसलिए समय/स्थान की आवश्यकता उचित है <math>n^\frac{\log\log q}{\log\log\log q}.</math>
Kedlaya और Umans आगे दिखाते हैं कि इस प्रीप्रोसेसिंग को तेज़ (FFT) मल्टीपॉइंट मूल्यांकन के साथ कैसे जोड़ा जाए।
यह बहुपद [[मॉड्यूलर रचना]] जैसे कई महत्वपूर्ण बीजगणितीय समस्याओं के लिए इष्टतम एल्गोरिदम की अनुमति देता है।


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


जबकि सामान्य बहुपदों की आवश्यकता होती है <math>\Omega(n)</math> संचालन का मूल्यांकन करने के लिए, कुछ बहुपदों की गणना बहुत तेजी से की जा सकती है।
जब सामान्य बहुपदों की आवश्यकता <math>\Omega(n)</math> संचालन के मूल्यांकन करने के लिए होती है, कुछ बहुपदों की गणना बहुत तीव्रता से की जा सकती है।उदाहरण के लिए, बहुपद <math>P(x)=x^2+2x+1</math> केवल एक गुणन और एक जोड़ का उपयोग करके गणना की जा सकती है क्योंकी <math>P(x)=(x+1)^2</math> होता है
उदाहरण के लिए, बहुपद <math>P(x)=x^2+2x+1</math> केवल एक गुणन और एक जोड़ का उपयोग करके गणना की जा सकती है <math>P(x)=(x+1)^2</math>




=== शक्तियों का मूल्यांकन ===
=== शक्तियों का मूल्यांकन ===
{{main|Exponentiation by squaring|Addition-chain exponentiation}}
{{main|वर्ग करके घातांक|जोड़-श्रृंखला घातांक}}


एक विशेष रूप से दिलचस्प प्रकार का बहुपद घात है <math>x^n</math>.
एक विशेष रूप से दिलचस्प प्रकार का बहुपद घात <math>x^n</math> है .ऐसे बहुपदों की सदैव गणना <math>O(\log n)</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^5</math> इसी तरह पहली कंप्यूटिंग द्वारा <math>x^4</math> 2 गुणा करके और पुनः गुणा करके <math>x</math>. कुशलतापूर्वक गणना की जा सकती है।
ऐसे बहुपदों की गणना हमेशा की जा सकती है <math>O(\log n)</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^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> भिन्न रूप में दिखाई देते हैं .[[चेबिशेव रूप]] में बहुपदों के लिए हम [[क्लेंशॉ एल्गोरिथम]] का उपयोग कर सकते हैं।बेजियर रूप में बहुपदों के लिए हम डी कास्टलजौ के एल्गोरिदम का उपयोग कर सकते हैं,और [[B-spline|बी-स्प्लिंस]] के लिए डी बूर का एल्गोरिदम है।
[[चेबिशेव रूप]] में बहुपदों के लिए हम [[क्लेंशॉ एल्गोरिथम]] का उपयोग कर सकते हैं।
बेजियर रूप में बहुपदों के लिए हम डी कास्टलजौ के एल्गोरिदम का उपयोग कर सकते हैं,
और [[B-spline]]s के लिए De Boor's एल्गोरिथम है।


=== कठिन बहुपद ===
=== कठिन बहुपद ===


तथ्य यह है कि कुछ बहुपदों की गणना सामान्य बहुपदों की तुलना में काफी तेजी से की जा सकती है, यह प्रश्न सुझाता है: क्या हम एक साधारण बहुपद का उदाहरण दे सकते हैं जिसकी गणना इसकी डिग्री से बहुत कम समय में नहीं की जा सकती है?
तथ्य यह है कि कुछ बहुपदों की गणना सामान्य बहुपदों की सापेक्ष में काफी तीव्रता से की जा सकती है, यह प्रश्न सुझाता है: क्या हम एक साधारण बहुपद का उदाहरण दे सकते हैं जिसकी गणना इसकी डिग्री से बहुत न्यूनतम समय में नहीं की जा सकती है? [[वोल्कर स्ट्रास]] ने दर्शाया है<ref>{{Cite journal|last=Strassen|first=Volker|author-link=Volker Strassen|date=1974|title=परिमेय गुणांक वाले बहुपद जिनकी गणना करना कठिन है|url=|journal=[[SIAM Journal on Computing]]|language=en|volume=3|issue=2|pages=128–149|doi=10.1137/0203010|issn=}}</ref> कि बहुपद
[[वोल्कर स्ट्रास]] ने दिखाया है<ref>{{Cite journal|last=Strassen|first=Volker|author-link=Volker Strassen|date=1974|title=परिमेय गुणांक वाले बहुपद जिनकी गणना करना कठिन है|url=|journal=[[SIAM Journal on Computing]]|language=en|volume=3|issue=2|pages=128–149|doi=10.1137/0203010|issn=}}</ref> वह बहुपद
:<math>P(x)=\sum_{k=0}^n 2^{2^{kn^3}}x^k</math>
:<math>P(x)=\sum_{k=0}^n 2^{2^{kn^3}}x^k</math>
से कम के द्वारा मूल्यांकन नहीं किया जा सकता है <math>\tfrac12 n - 2</math> गुणन और <math>n - 4</math> जोड़।
से न्यूनतम के द्वारा <math>\tfrac12 n - 2</math> गुणन और <math>n - 4</math> जोड़ का मूल्यांकन नहीं किया जा सकता है ।न्यूनतम से न्यूनतम यह बाध्यता धारण करती है यदि केवल <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>
 
अन्य साधारण बहुपदों के लिए, जटिलता अज्ञात है।बहुपद <math>(x+1)(x+2)\cdots(x+n)</math> समय <math>(\log n)^{c}</math> किसी के लिए <math>c</math>. पर गणना करने योग्य नहीं होने का अनुमान है यह इस तथ्य से समर्थित है, कि यदि इसकी तीव्रता से गणना की जा सकती है, तो RSA (क्रिप्टोसिस्टम) को तोड़ते हुए बहुपद समय में पूर्णांक गुणनखंड की गणना की जा सकती है।<ref>Chen, Xi, Neeraj Kayal, and Avi Wigderson. Partial derivatives in arithmetic complexity and beyond. Now Publishers Inc, 2011.</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>.
यह इस तथ्य से समर्थित है, कि यदि इसकी तेजी से गणना की जा सकती है, तो RSA (क्रिप्टोसिस्टम) को तोड़ते हुए बहुपद समय में पूर्णांक गुणनखंड की गणना की जा सकती है।<ref>Chen, Xi, Neeraj Kayal, and Avi Wigderson. Partial derivatives in arithmetic complexity and beyond. Now Publishers Inc, 2011.</ref>




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


कभी-कभी अदिश गुणन की कम्प्यूटेशनल लागत (जैसे <math>ax</math>) गैर अदिश गुणन की कम्प्यूटेशनल लागत से कम है (जैसे <math>x^2</math>).
कभी-कभी अदिश गुणन की न्यूनतम कम्प्यूटेशनल लागत (जैसे <math>ax</math>)गैर अदिश गुणन की न्यूनतम कम्प्यूटेशनल लागत से न्यूनतम है (जैसे <math>x^2</math>).इसका विशिष्ट उदाहरण मैट्रिसेस है। <math>M</math> एक <math>m\times m</math> मैट्रिक्स में, एक अदिश गुणन लगभग <math>aM</math> और <math>m^2</math> गणना करते समय <math>M^2</math> अंकगणितीय संचालन लगभग <math>m^3</math>लगते हैं
इसका विशिष्ट उदाहरण मैट्रिसेस है।
अगर <math>M</math> एक <math>m\times m</math> मैट्रिक्स, एक अदिश गुणन <math>aM</math> लगभग लगते हैं <math>m^2</math> गणना करते समय अंकगणितीय संचालन <math>M^2</math> लगभग लगते हैं <math>m^3</math> (या <math>m^{2.3}</math> तेजी से मैट्रिक्स गुणन का उपयोग करके)।


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


पैटर्सन और स्टॉकमेयर <ref>{{Cite journal|last=Paterson|first=Michael S.|author-link=Mike Paterson|last2=Stockmeyer|first2=Larry J.|author-link2=Larry J. Stockmeyer|date=1973|title=बहुपदों का मूल्यांकन करने के लिए आवश्यक नॉनस्केलर गुणन की संख्या पर|url=|journal=[[SIAM Journal on Computing]]|language=en|volume=2|issue=1|pages=60–66|doi=10.1137/0202007|issn=}}</ref>
पैटर्सन और स्टॉन्यूनतमेयर <ref>{{Cite journal|last=Paterson|first=Michael S.|author-link=Mike Paterson|last2=Stockmeyer|first2=Larry J.|author-link2=Larry J. Stockmeyer|date=1973|title=बहुपदों का मूल्यांकन करने के लिए आवश्यक नॉनस्केलर गुणन की संख्या पर|url=|journal=[[SIAM Journal on Computing]]|language=en|volume=2|issue=1|pages=60–66|doi=10.1137/0202007|issn=}}</ref> ने  दर्शाया की डिग्री की गणना कैसे की जाती हैं  <math>O(\sqrt n)</math> गैर अदिश गुणन और <math>O(n)</math> अदिश गुणन केवल <math>n</math> बहुपद का उपयोग करती हैं।इस प्रकार डिग्री {{mvar|n}} के एक [[मैट्रिक्स बहुपद]] <math>O(m^{2.3}\sqrt{n} + m^2n)</math> का समय मूल्यांकन किया जा सकता है। अगर <math>m=n</math> से  <math>O(n^3)</math> न्यूनतम है ,तो मानक एल्गोरिथम के सापेक्ष एकल मैट्रिक्स गुणन से तीव्र हैं।
डिग्री की गणना करने का तरीका दिखाया <math>n</math> बहुपद केवल का उपयोग कर <math>O(\sqrt n)</math> गैर अदिश गुणन और <math>O(n)</math> अदिश गुणन।
इस प्रकार डिग्री का एक [[मैट्रिक्स बहुपद]] {{mvar|n}} में मूल्यांकन किया जा सकता है <math>O(m^{2.3}\sqrt{n} + m^2n)</math> समय। अगर <math>m=n</math> यह इससे कम है <math>O(n^3);</math> वह है, मानक एल्गोरिथम के साथ एकल मैट्रिक्स गुणन से तेज़।


यह विधि इस प्रकार काम करती है: एक बहुपद के लिए
यह विधि इस प्रकार काम करती है: एक बहुपद के लिए
:<math>P(M)=a_{n-1} M^{n-1} + \dots + a_{1}M + a_0 I,</math>
:<math>P(M)=a_{n-1} M^{n-1} + \dots + a_{1}M + a_0 I,</math>
होने देना {{mvar|k}} सबसे छोटा पूर्णांक हो जो इससे छोटा न हो <math>\sqrt{n}.</math>
मान लीजिए {{mvar|k}} सबसे छोटा पूर्णांक है जो इससे <math>\sqrt{n}.</math> छोटा नही है ,<math>M, M^2, \dots, M^k</math> घातांक के सापेक्ष गणना की जाती है <math>k</math> मैट्रिक्स गुणन, और   <math>M^k.</math> द्वारा <math>M^{2k}, M^{3k}, \dots, M^{k^2-k}</math> की बार-बार गुणा करके गणना की जाती है अब,
शक्तियाँ <math>M, M^2, \dots, M^k</math> के साथ गणना की जाती है <math>k</math> मैट्रिक्स गुणन, और <math>M^{2k}, M^{3k}, \dots, M^{k^2-k}</math> द्वारा बार-बार गुणा करके गणना की जाती है <math>M^k.</math>
अब,
:<math>\begin{align}P(M) =
:<math>\begin{align}P(M) =
&\,(a_0 I + a_1 M + \dots + a_{k-1}M^{k-1})
&\,(a_0 I + a_1 M + \dots + a_{k-1}M^{k-1})
Line 180: Line 147:
\\+&\,(a_{n-k} I + a_{n-k+1} M + \dots + a_{n-1}M^{k-1})M^{k^2-k},
\\+&\,(a_{n-k} I + a_{n-k+1} M + \dots + a_{n-1}M^{k-1})M^{k^2-k},
\end{align}</math>,
\end{align}</math>,
कहाँ <math>a_i=0</math> के लिए {{math|''i'' ≥ ''n''}}.
जहाँ <math>a_i=0</math> के लिए {{math|''i'' ≥ ''n''}} है.इसके लिए बस <math>k</math> अधिक गैर-अदिश गुणन की आवश्यकता है।
इसके लिए बस आवश्यकता है <math>k</math> अधिक गैर-अदिश गुणन।


[[क्रोनकर उत्पाद]] का उपयोग करके हम इसे संक्षेप में लिख सकते हैं:
[[क्रोनकर उत्पाद]] का उपयोग करके हम इसे संक्षेप में लिख सकते हैं:
Line 194: Line 160:
</math>.
</math>.


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


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


==संदर्भ==
==संदर्भ==
{{reflist}}
{{reflist}}
[[Category: बहुपदों]]


[[Category: Machine Translated Page]]
[[Category:Articles with hatnote templates targeting a nonexistent page]]
[[Category:CS1]]
[[Category:CS1 English-language sources (en)]]
[[Category:Created On 03/03/2023]]
[[Category:Created On 03/03/2023]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Short description with empty Wikidata description]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]
[[Category:बहुपदों]]

Latest revision as of 07:12, 19 March 2023

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

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

पृष्ठभूमि

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

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

सामान्य विधि

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

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

यह विधि गुणन और जोड़ की संख्या को घटाकर केवल कर देती है ,

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

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

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

उदाहरण.

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

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


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

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

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

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

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

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

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

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

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


उदाहरण

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

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

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

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

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

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

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


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


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

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

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

केदलया और उमंस के आगे यह दर्शाते हैं कि इस तीव्र प्रीप्रोसेसिंग को मल्टीपॉइंट मूल्यांकन के सापेक्ष कैसे जोड़ा जाए। यह बहुपद मॉड्यूलर रचना जैसे कई महत्वपूर्ण बीजगणितीय समस्याओं के लिए इष्टतम एल्गोरिदम की अनुमति देता है।

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

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


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

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

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

बहुपद परिवार

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

कठिन बहुपद

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

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

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

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


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

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

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

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

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

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

,

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

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

.

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

यह भी देखें

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

संदर्भ

  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.