बहुपद मूल्यांकन
गणित और कंप्यूटर विज्ञान में, बहुपद मूल्यांकन एक बहुपद के मूल्य की गणना को संदर्भित करता है तथा इसके अनिश्चित चर को कुछ मूल्यों के लिए प्रतिस्थापित किया जाता है। दूसरे शब्दों में, बहुपद के मूल्यांकन पर , में कंप्यूटिंग समिम्लित है,तथा बहुपद वलय § बहुपद मूल्यांकन भी देखें
अविभाज्य बहुपद के मूल्यांकन के लिए सबसे सरल विधि का उपयोग करेंगे गुणन की गणना करने के लिए , का,तथा गुणन की गणना करने के लिए उपयोग करेंगे और इसी तरह कुल मिलाकर से गुणन करेंगेऔर को जोड़ देंगे।हॉर्नर के नियम जैसे बेहतर विधियों का उपयोग करके गुणन और जोड़ को न्यूनतम किया जा सकता है। यदि कुछ प्रीप्रोसेसिंग की अनुमति दी जाती है, तो और भी बचत संभव है।
पृष्ठभूमि
अभ्यास में यह समस्या सामान्यतया उत्पन्न होती है। कम्प्यूटेशनल ज्यामिति में, टेलर बहुपदों का उपयोग करके फ़ंक्शन सन्निकटन की गणना करने के लिए बहुपदों का उपयोग किया जाता है। क्रिप्टोग्राफी और हैश तालिका में, 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 सबसे छोटा पूर्णांक हो जो इससे छोटा न हो शक्तियाँ के साथ गणना की जाती है मैट्रिक्स गुणन, और द्वारा बार-बार गुणा करके गणना की जाती है अब,
- ,
कहाँ के लिए i ≥ n. इसके लिए बस आवश्यकता है अधिक गैर-अदिश गुणन।
क्रोनकर उत्पाद का उपयोग करके हम इसे संक्षेप में लिख सकते हैं:
- .
इस पद्धति का प्रत्यक्ष अनुप्रयोग उपयोग करता है गैर-अदिश गुणन, लेकिन इसे बहुपद_मूल्यांकन#Evaluation_with_preprocessing के साथ जोड़कर, पैटर्सन और स्टॉकमेयर दिखाते हैं कि आप इसे कम कर सकते हैं .
यह भी देखें
- एस्ट्रिन की योजना आधुनिक कंप्यूटर आर्किटेक्चर पर समानांतरकरण की सुविधा के लिए
- अंकगणित सर्किट जटिलता सिद्धांत विभिन्न बहुपदों के मूल्यांकन के कम्प्यूटेशनल जटिलता सिद्धांत का अध्ययन करता है।
संदर्भ
- ↑ Carnicer, J.; Gasca, M. (1990). "बहुभिन्नरूपी बहुपदों और उनके डेरिवेटिव का मूल्यांकन". Mathematics of Computation. 54 (189): 231–243. doi:10.2307/2008692.
- ↑ Motzkin, T. S. (1955). "बहुपदों का मूल्यांकन और तर्कसंगत कार्यों का मूल्यांकन". Bulletin of the American Mathematical Society. 61 (163): 10.
- ↑ Von Zur Gathen, Joachim; Jürgen, Gerhard (2013). आधुनिक कंप्यूटर बीजगणित. Cambridge University Press. Chapter 10. ISBN 9781139856065.
- ↑ Knuth, Donald (2005). Art of Computer Programming. Vol. 2: Seminumerical Algorithms. Addison-Wesley. ISBN 9780201853926.
- ↑ Kedlaya, Kiran S.; Umans, Christopher (2011). "तेजी से बहुपद गुणनखंडन और मॉड्यूलर रचना". SIAM Journal on Computing. 40 (6): 1767–1802. doi:10.1137/08073408x. hdl:1721.1/71792.
- ↑ Larsen, K. G. (2012). "उच्च सेल जांच बहुपदों के मूल्यांकन के लिए निचली सीमा". Symposium on Foundations of Computer Science. IEEE. 53: 293–301. doi:10.1109/FOCS.2012.21.
- ↑ Strassen, Volker (1974). "परिमेय गुणांक वाले बहुपद जिनकी गणना करना कठिन है". SIAM Journal on Computing (in English). 3 (2): 128–149. doi:10.1137/0203010.
- ↑ 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
- ↑ Chen, Xi, Neeraj Kayal, and Avi Wigderson. Partial derivatives in arithmetic complexity and beyond. Now Publishers Inc, 2011.
- ↑ Paterson, Michael S.; Stockmeyer, Larry J. (1973). "बहुपदों का मूल्यांकन करने के लिए आवश्यक नॉनस्केलर गुणन की संख्या पर". SIAM Journal on Computing (in English). 2 (1): 60–66. doi:10.1137/0202007.