स्प्लिट-रेडिक्स एफएफटी एल्गोरिदम: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 1: Line 1:
{{Short description|Fast Fourier transform algorithm}}
{{Short description|Fast Fourier transform algorithm}}
'''स्प्लिट-रेडिक्स एफएफटी''', [[असतत फूरियर रूपांतरण|डिस्क्रीट फूरियर ट्रांसफॉर्म]] (डीएफटी) की गणना के लिए फास्ट फूरियर ट्रांसफॉर्म (एफएफटी) एल्गोरिदम है, और इसका वर्णन सर्वप्रथम आर. यावने (1968) द्वारा प्रारम्भ में कम प्रशंसित पेपर में किया गया था और पश्चात में 1984 में विभिन्न लेखकों द्वारा एक साथ पुनः इसका शोध किया गया। (स्प्लिट रेडिक्स नाम इनमें से दो पुनर्निवेशकों, पी. डुहामेल और एच. हॉलमैन द्वारा गढ़ा गया था।) विशेष रूप से, स्प्लिट रेडिक्स कूली-टुकी एफएफटी (Cooley–Tukey FFT) एल्गोरिदम का एक प्रकार है जो रेडिस के मूलांक 2 और 4 के मिश्रण का उपयोग करता है: यह N लंबाई के डीएफटी (DFT) को N/2 के एक छोटे डीएफटी और ''N''/4 लंबाई के छोटे डीएफटी के संदर्भ में पुनरावर्ती रूप से व्यक्त करता है।
'''स्प्लिट-रेडिक्स एफएफटी''', [[असतत फूरियर रूपांतरण|डिस्क्रीट फूरियर ट्रांसफॉर्म]] (डीएफटी) की गणना के लिए फास्ट फूरियर ट्रांसफॉर्म (एफएफटी) एल्गोरिदम है, और इसका वर्णन सर्वप्रथम आर. यावने (1968) द्वारा प्रारम्भ में कम प्रशंसित पेपर में किया गया था और पश्चात में पुनः 1984 में विभिन्न लेखकों द्वारा एक साथ इसका शोध किया गया। (स्प्लिट रेडिक्स नाम इनमें से दो पुनर्निवेशकों, पी. डुहामेल और एच. हॉलमैन द्वारा निर्मित किया गया था।) विशेष रूप से, स्प्लिट रेडिक्स कूली-टुकी एफएफटी (Cooley–Tukey FFT) एल्गोरिदम का एक प्रकार है जो रेडिस के मूलांक 2 और 4 के मिश्रण का उपयोग करता है: यह लंबाई N के डीएफटी (DFT) को लंबाई N/2 के एक छोटे डीएफटी और लंबाई N/4 के छोटे डीएफटी के संदर्भ में पुनरावर्ती रूप से व्यक्त करता है।


स्प्लिट-रेडिक्स एफएफटी, अपनी विविधताओं के साथ, लंबे समय से दो आकारों ''N'' की शक्ति के डीएफटी की गणना करने के लिए सबसे कम प्रकाशित अंकगणितीय ऑपरेशन गणना (आवश्यक [[वास्तविक संख्या]] जोड़ और गुणन की संपूर्ण त्रुटिहीन संख्या) प्राप्त करने का गौरव रखता था। मूल स्प्लिट-रेडिक्स एल्गोरिदम की अंकगणित गणना में 2004 में सुधार किया गया था (''N''=64 के लिए हाथ अनुकूलन के माध्यम से जे. वान बसकिर्क द्वारा अप्रकाशित कार्य में प्राप्त प्रारंभिक लाभ के साथ), परन्तु यह ज्ञात हुआ है कि कोई अभी भी विभाजित मूलांक (जॉनसन और फ्रिगो, 2007) के संशोधन द्वारा नई न्यूनतम गणना प्राप्त कर सकता है। यद्यपि [[कंप्यूटर]] पर डीएफटी की गणना करने के लिए आवश्यक समय निर्धारित करने में अंकगणितीय परिचालनों की संख्या एकमात्र कारक (या यहां तक ​​​​कि अनिवार्य रूप से प्रमुख कारक) नहीं है, न्यूनतम संभव गणना का प्रश्न लंबे समय से सैद्धांतिक रुचि का है। (वर्तमान में ऑपरेशन संख्या पर कोई सख्त निचली सीमा साबित नहीं हुई है।)
स्प्लिट-रेडिक्स एफएफटी, अपनी विविधताओं के साथ, लंबे समय से दो आकारों की पावर ''N'' के डीएफटी की गणना करने के लिए सबसे कम प्रकाशित अंकगणितीय ऑपरेशन गणना (आवश्यक [[वास्तविक संख्या]] जोड़ और गुणन की संपूर्ण त्रुटिहीन संख्या) प्राप्त करने का गौरव रखता था। मूल स्प्लिट-रेडिक्स एल्गोरिदम की अंकगणित गणना में 2004 में सुधार किया गया था (''N''=64 के लिए हाथ अनुकूलन के माध्यम से जे. वान बसकिर्क द्वारा अप्रकाशित कार्य में प्राप्त प्रारंभिक लाभ के साथ), परन्तु यह ज्ञात हुआ है कि कोई अभी भी विभाजित मूलांक (जॉनसन और फ्रिगो, 2007) के संशोधन द्वारा नई न्यूनतम गणना प्राप्त कर सकता है। यद्यपि [[कंप्यूटर]] पर डीएफटी की गणना करने के लिए आवश्यक समय निर्धारित करने में अंकगणितीय परिचालनों की संख्या एकमात्र कारक (या यहां तक ​​​​कि अनिवार्य रूप से प्रमुख कारक) नहीं है, न्यूनतम संभव गणना का प्रश्न लंबे समय से सैद्धांतिक रुचि का है। (वर्तमान में ऑपरेशन संख्या पर कोई कठिन निचली सीमा प्रमाणित नहीं हुई है।)


स्प्लिट-रेडिक्स एल्गोरिदम केवल तभी प्रस्तावित किया जा सकता है जब N, 4 का गुणक हो, परन्तु चूंकि यह डीएफटी को छोटे डीएफटी में खंडित करता है, इसलिए इसे इच्छानुसार किसी अन्य एफएफटी एल्गोरिदम के साथ जोड़ा जा सकता है।
स्प्लिट-रेडिक्स एल्गोरिदम केवल तभी प्रस्तावित किया जा सकता है जब N, 4 का गुणक हो, परन्तु चूंकि यह डीएफटी को छोटे डीएफटी में खंडित करता है, इसलिए इसे इच्छानुसार किसी अन्य एफएफटी एल्गोरिदम के साथ जोड़ा जा सकता है।
Line 9: Line 9:
याद रखें कि डीएफटी को सूत्र द्वारा परिभाषित किया गया है:
याद रखें कि डीएफटी को सूत्र द्वारा परिभाषित किया गया है:
:<math> X_k =  \sum_{n=0}^{N-1} x_n \omega_N^{nk} </math>
:<math> X_k =  \sum_{n=0}^{N-1} x_n \omega_N^{nk} </math>
जहाँ <math>k</math> <math>0</math> से लेकर <math>N-1</math> तक का पूर्णांक है और <math>\omega_N</math> एकता की आदिम जड़ को दर्शाता है:
जहाँ <math>k</math> पूर्णांक है, जो <math>0</math> से लेकर <math>N-1</math> तक है और <math>\omega_N</math> एकता की आदिम जड़ को दर्शाता है:
:<math>\omega_N = e^{-\frac{2\pi i}{N}},</math>
:<math>\omega_N = e^{-\frac{2\pi i}{N}},</math>
और इस प्रकार: <math>\omega_N^N = 1</math> होता है।
और इस प्रकार: <math>\omega_N^N = 1</math> होता है।
Line 15: Line 15:
स्प्लिट-रेडिक्स एल्गोरिदम इस योग को तीन छोटे योगों के रूप में व्यक्त करके कार्य करता है। (यहां, हम स्प्लिट-रेडिक्स एफएफटी के समय संस्करण में दशमलव देते हैं; आवृत्ति संस्करण में दोहरी दशमलव अनिवार्य रूप से इन चरणों के विपरीत है।)
स्प्लिट-रेडिक्स एल्गोरिदम इस योग को तीन छोटे योगों के रूप में व्यक्त करके कार्य करता है। (यहां, हम स्प्लिट-रेडिक्स एफएफटी के समय संस्करण में दशमलव देते हैं; आवृत्ति संस्करण में दोहरी दशमलव अनिवार्य रूप से इन चरणों के विपरीत है।)


सबसे पूर्व, सम संख्या सूचकांकों का सारांश <math>x_{2n_2}</math>, दूसरा, दो टुकड़ों में विभाजित विषम सूचकांकों का सारांश: <math>x_{4n_4+1}</math> और <math>x_{4n_4+3}</math>, इसके अनुसार सूचकांक 1 या 3 [[मॉड्यूलो ऑपरेशन]] 4 है। यहां, <math>n_m</math> एक सूचकांक को दर्शाता है जो 0 से <math>N/m-1</math> तक चलता है। परिणामी योग इस प्रकार दिखते हैं:
सबसे पूर्व, सम संख्या सूचकांकों का सारांश <math>x_{2n_2}</math>, दूसरा, दो टुकड़ों में विभाजित विषम सूचकांकों का सारांश: <math>x_{4n_4+1}</math> और <math>x_{4n_4+3}</math>, इसके अनुसार सूचकांक 1 या 3 [[मॉड्यूलो ऑपरेशन]] 4 है। यहां, <math>n_m</math> एक सूचकांक को दर्शाता है जो 0 से <math>N/m-1</math> तक जाता है। परिणामी योग इस प्रकार प्रदर्शित होते हैं:


:<math> X_k =  \sum_{n_2=0}^{N/2-1} x_{2n_2} \omega_{N/2}^{n_2 k}  
:<math> X_k =  \sum_{n_2=0}^{N/2-1} x_{2n_2} \omega_{N/2}^{n_2 k}  
Line 21: Line 21:
+ \omega_N^{3k} \sum_{n_4=0}^{N/4-1} x_{4n_4+3} \omega_{N/4}^{n_4 k}
+ \omega_N^{3k} \sum_{n_4=0}^{N/4-1} x_{4n_4+3} \omega_{N/4}^{n_4 k}
</math>
</math>
जहाँ हमने इस तथ्य का प्रयोग किया है कि <math>\omega_N^{m n k} = \omega_{N/m}^{n k}</math>है। ये तीन योग क्रमशःमूलांक-2 (आकार N/2) और मूलांक-4 (आकार N/4) कूली-टुकी चरणों के भागों के अनुरूप हैं। (अंतर्निहित विचार यह है कि मूलांक-2 के सम-सूचकांक उप-परिवर्तन के सामने कोई गुणक कारक नहीं है, इसलिए इसे वैसे ही छोड़ दिया जाना चाहिए, जबकि मूलांक-2 के विषम-सूचकांक उप-परिवर्तन को दूसरे पुनरावर्ती उपविभाजन के संयोजन से लाभ होता है।)
जहाँ हमने इस तथ्य का प्रयोग किया है कि <math>\omega_N^{m n k} = \omega_{N/m}^{n k}</math>है। ये तीन योग क्रमशः मूलांक-2 (आकार N/2) और मूलांक-4 (आकार N/4) कूली-टुकी चरणों के भागों के अनुरूप हैं। (अंतर्निहित विचार यह है कि मूलांक-2 के सम-सूचकांक उप-परिवर्तन के सामने कोई गुणक कारक नहीं है, इसलिए इसे वैसे ही छोड़ दिया जाना चाहिए, जबकि मूलांक-2 के विषम-सूचकांक उप-परिवर्तन को दूसरे पुनरावर्ती उपविभाजन के संयोजन से लाभ होता है।)


ये छोटे योग अब बिल्कुल N/2 और N/4 लंबाई के डीएफटी हैं, जिन्हें पुनरावर्ती रूप से निष्पादित किया जा सकता है और फिर पुन: संयोजित किया जा सकता है।
ये छोटे योग अब N/2 और N/4 लंबाई के डीएफटी हैं, जिन्हें पुनरावर्ती रूप से निष्पादित किया जा सकता है और फिर पुन: संयोजित किया जा सकता है।


अधिक विशेष रूप से, <math>U_k</math> लंबाई N/2 (<math>k = 0,\ldots,N/2-1</math> के लिए) के डीएफटी के परिणाम को निरूपित करें, और <math>Z_k</math> और <math>Z'_k</math> लंबाई N/4 (<math>k = 0,\ldots,N/4-1</math> लिए) के डीएफटी के परिणामों को निरूपित करें। फिर आउटपुट <math>X_k</math> है:
अधिक विशेष रूप से, <math>U_k</math> लंबाई N/2 (<math>k = 0,\ldots,N/2-1</math> के लिए) के डीएफटी के परिणाम को निरूपित करें, और <math>Z_k</math> और <math>Z'_k</math> लंबाई N/4 (<math>k = 0,\ldots,N/4-1</math> लिए) के डीएफटी के परिणामों को निरूपित करें। फिर आउटपुट <math>X_k</math> है:
:<math>X_k = U_k + \omega_N^k Z_k + \omega_N^{3k} Z'_k.</math>
:<math>X_k = U_k + \omega_N^k Z_k + \omega_N^{3k} Z'_k.</math>
चूँकि, यह अनावश्यक गणना करता है <math>k \geq N/4</math>, <math>k < N/4</math> के साथ कई गणनाएँ साझा करना संभव हो जाता है . विशेष रूप से, यदि हम k में N/4 जोड़ते हैं, तो आकार-N/4 डीएफटी नहीं परिवर्तित होती हैं (क्योंकि वे N/4 में आवधिक होते हैं), जबकि यदि हम k में N/2 जोड़ते हैं तो आकार-N/2 डीएफटी अपरिवर्तित रहता है। तो, केवल<math>\omega_N^k</math> और <math>\omega_N^{3k}</math> शब्द परिवर्तित होते हैं, जिन्हें [[घुमाव कारक|ट्विडल कारक]] के रूप में जाना जाता है। यहां, हम सर्वसमिकाओं का उपयोग करते हैं:
चूँकि, यह अनावश्यक गणना करता है <math>k \geq N/4</math>, <math>k < N/4</math> के साथ कई गणनाएँ भागित करना संभव हो जाता है। विशेष रूप से, यदि हम k में N/4 जोड़ते हैं, तो आकार-N/4 डीएफटी नहीं परिवर्तित होती हैं (क्योंकि वे N/4 में आवधिक होते हैं), जबकि यदि हम k में N/2 जोड़ते हैं तो आकार-N/2 डीएफटी अपरिवर्तित रहता है। तो, केवल <math>\omega_N^k</math> और <math>\omega_N^{3k}</math> शब्द परिवर्तित होते हैं, जिन्हें [[घुमाव कारक|ट्विडल कारक]] के रूप में जाना जाता है। यहां, हम सर्वसमिकाओं का उपयोग करते हैं:
:<math>\omega_N^{k+N/4} = -i \omega_N^k</math>
:<math>\omega_N^{k+N/4} = -i \omega_N^k</math>
:<math>\omega_N^{3(k+N/4)} = i \omega_N^{3k}</math>
:<math>\omega_N^{3(k+N/4)} = i \omega_N^{3k}</math>
Line 37: Line 37:
जो सभी आउटपुट <math>X_k</math> देता है, यदि <math>k</math> रेंज <math>0</math> से <math>N/4-1</math> को उपरोक्त चार भावों में होने देते है।
जो सभी आउटपुट <math>X_k</math> देता है, यदि <math>k</math> रेंज <math>0</math> से <math>N/4-1</math> को उपरोक्त चार भावों में होने देते है।


ध्यान दें कि इन अभिव्यक्तियों को इस प्रकार व्यवस्थित किया गया है कि हमें विभिन्न डीएफटी आउटपुट को जोड़ और घटाव के जोड़े द्वारा संयोजित करने की आवश्यकता है, जिन्हें [[तितली आरेख|बटरफ्लाईज आरेख]] के रूप में जाना जाता है। इस एल्गोरिदम के लिए न्यूनतम ऑपरेशन गणना प्राप्त करने के लिए, विशेष मामलों को ध्यान में रखना होगा <math>k = 0</math> (जहाँ ट्विडल कारक एकता हैं) और <math>k = N/8</math> (जहां ट्विडल कारक हैं <math>(1 \pm i)/\sqrt{2}</math> और अधिक तीव्रता से गुणा किया जा सकता है) के लिए; उदाहरण सोरेनसेन एट अल. (1986)। <math>\pm 1</math> और <math>\pm i</math> से गुणा सामान्यतः मुक्त के रूप में गिना जाता है (जोड़ को घटाव में परिवर्तित करके या इसके विपरीत सभी निषेधों को अवशोषित किया जा सकता है)।
ध्यान दें कि इन अभिव्यक्तियों को इस प्रकार व्यवस्थित किया गया है कि हमें विभिन्न डीएफटी आउटपुट को जोड़ और घटाव के जोड़े द्वारा संयोजित करने की आवश्यकता है, जिन्हें [[तितली आरेख|बटरफ्लाईज आरेख]] के रूप में जाना जाता है। इस एल्गोरिदम के लिए न्यूनतम ऑपरेशन गणना प्राप्त करने के लिए, किसी को <math>k = 0</math> (जहाँ ट्विडल कारक एकता हैं) और <math>k = N/8</math> (जहां ट्विडल कारक <math>(1 \pm i)/\sqrt{2}</math> हैं और अधिक तीव्रता से गुणा किया जा सकता है) के लिए विशेष मामलों को ध्यान में रखना होगा; उदाहरण सोरेनसेन एट अल. (1986)। <math>\pm 1</math> और <math>\pm i</math> से गुणा सामान्यतः मुक्त के रूप में गिना जाता है (जोड़ को घटाव में परिवर्तित करके या इसके विपरीत सभी निषेधों को अवशोषित किया जा सकता है)।


जब N दो की घात हो तो यह अपघटन पुनरावर्ती रूप से किया जाता है। रिकर्सन के आधार विषय N=1, जहां डीएफटी केवल <math>X_0 = x_0</math> की प्रति है, और N=2 हैं, जहां डीएफटी जोड़ <math>X_0 = x_0 + x_1</math>और घटाव <math>X_1 = x_0 - x_1</math>है।   
जब N दो की घात हो तो यह अपघटन पुनरावर्ती रूप से किया जाता है। रिकर्सन के आधार विषय N=1, जहां डीएफटी केवल <math>X_0 = x_0</math> की प्रति है, और N=2 हैं, जहां डीएफटी जोड़ <math>X_0 = x_0 + x_1</math>और घटाव <math>X_1 = x_0 - x_1</math>है।   


इन विचारों के परिणामस्वरूप गिनती होती है: <math>4 N \log_2 N - 6N + 8</math> वास्तविक जोड़ और गुणन, N>1 के लिए दो की घात है। यह गणना मानती है कि, 2 की विषम शक्तियों के लिए, 2 का शेष कारक (सभी विभाजन-मूलांक चरणों के पश्चात, जो N को 4 से विभाजित करता है) को सीधे डीएफटी परिभाषा (4 वास्तविक जोड़ और गुणा), या समकक्ष मूलांक-2 कूली-टुकी एफएफटी चरण द्वारा नियंत्रित किया जाता है।
इन विचारों के परिणामस्वरूप गिनती होती है: <math>4 N \log_2 N - 6N + 8</math> वास्तविक जोड़ और गुणन, N>1 के लिए दो की घात है। यह गणना मानती है कि, 2 की विषम घात के लिए, 2 का शेष कारक (सभी विभाजन-मूलांक चरणों के पश्चात, जो N को 4 से विभाजित करता है) को सीधे डीएफटी परिभाषा (4 वास्तविक जोड़ और गुणा), या समकक्ष मूलांक-2 कूली-टुकी एफएफटी चरण द्वारा नियंत्रित किया जाता है।


==संदर्भ==
==संदर्भ==

Revision as of 11:25, 24 November 2023

स्प्लिट-रेडिक्स एफएफटी, डिस्क्रीट फूरियर ट्रांसफॉर्म (डीएफटी) की गणना के लिए फास्ट फूरियर ट्रांसफॉर्म (एफएफटी) एल्गोरिदम है, और इसका वर्णन सर्वप्रथम आर. यावने (1968) द्वारा प्रारम्भ में कम प्रशंसित पेपर में किया गया था और पश्चात में पुनः 1984 में विभिन्न लेखकों द्वारा एक साथ इसका शोध किया गया। (स्प्लिट रेडिक्स नाम इनमें से दो पुनर्निवेशकों, पी. डुहामेल और एच. हॉलमैन द्वारा निर्मित किया गया था।) विशेष रूप से, स्प्लिट रेडिक्स कूली-टुकी एफएफटी (Cooley–Tukey FFT) एल्गोरिदम का एक प्रकार है जो रेडिस के मूलांक 2 और 4 के मिश्रण का उपयोग करता है: यह लंबाई N के डीएफटी (DFT) को लंबाई N/2 के एक छोटे डीएफटी और लंबाई N/4 के छोटे डीएफटी के संदर्भ में पुनरावर्ती रूप से व्यक्त करता है।

स्प्लिट-रेडिक्स एफएफटी, अपनी विविधताओं के साथ, लंबे समय से दो आकारों की पावर N के डीएफटी की गणना करने के लिए सबसे कम प्रकाशित अंकगणितीय ऑपरेशन गणना (आवश्यक वास्तविक संख्या जोड़ और गुणन की संपूर्ण त्रुटिहीन संख्या) प्राप्त करने का गौरव रखता था। मूल स्प्लिट-रेडिक्स एल्गोरिदम की अंकगणित गणना में 2004 में सुधार किया गया था (N=64 के लिए हाथ अनुकूलन के माध्यम से जे. वान बसकिर्क द्वारा अप्रकाशित कार्य में प्राप्त प्रारंभिक लाभ के साथ), परन्तु यह ज्ञात हुआ है कि कोई अभी भी विभाजित मूलांक (जॉनसन और फ्रिगो, 2007) के संशोधन द्वारा नई न्यूनतम गणना प्राप्त कर सकता है। यद्यपि कंप्यूटर पर डीएफटी की गणना करने के लिए आवश्यक समय निर्धारित करने में अंकगणितीय परिचालनों की संख्या एकमात्र कारक (या यहां तक ​​​​कि अनिवार्य रूप से प्रमुख कारक) नहीं है, न्यूनतम संभव गणना का प्रश्न लंबे समय से सैद्धांतिक रुचि का है। (वर्तमान में ऑपरेशन संख्या पर कोई कठिन निचली सीमा प्रमाणित नहीं हुई है।)

स्प्लिट-रेडिक्स एल्गोरिदम केवल तभी प्रस्तावित किया जा सकता है जब N, 4 का गुणक हो, परन्तु चूंकि यह डीएफटी को छोटे डीएफटी में खंडित करता है, इसलिए इसे इच्छानुसार किसी अन्य एफएफटी एल्गोरिदम के साथ जोड़ा जा सकता है।

विभाजन-मूलांक अपघटन

याद रखें कि डीएफटी को सूत्र द्वारा परिभाषित किया गया है:

जहाँ पूर्णांक है, जो से लेकर तक है और एकता की आदिम जड़ को दर्शाता है:

और इस प्रकार: होता है।

स्प्लिट-रेडिक्स एल्गोरिदम इस योग को तीन छोटे योगों के रूप में व्यक्त करके कार्य करता है। (यहां, हम स्प्लिट-रेडिक्स एफएफटी के समय संस्करण में दशमलव देते हैं; आवृत्ति संस्करण में दोहरी दशमलव अनिवार्य रूप से इन चरणों के विपरीत है।)

सबसे पूर्व, सम संख्या सूचकांकों का सारांश , दूसरा, दो टुकड़ों में विभाजित विषम सूचकांकों का सारांश: और , इसके अनुसार सूचकांक 1 या 3 मॉड्यूलो ऑपरेशन 4 है। यहां, एक सूचकांक को दर्शाता है जो 0 से तक जाता है। परिणामी योग इस प्रकार प्रदर्शित होते हैं:

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

ये छोटे योग अब N/2 और N/4 लंबाई के डीएफटी हैं, जिन्हें पुनरावर्ती रूप से निष्पादित किया जा सकता है और फिर पुन: संयोजित किया जा सकता है।

अधिक विशेष रूप से, लंबाई N/2 ( के लिए) के डीएफटी के परिणाम को निरूपित करें, और और लंबाई N/4 ( लिए) के डीएफटी के परिणामों को निरूपित करें। फिर आउटपुट है:

चूँकि, यह अनावश्यक गणना करता है , के साथ कई गणनाएँ भागित करना संभव हो जाता है। विशेष रूप से, यदि हम k में N/4 जोड़ते हैं, तो आकार-N/4 डीएफटी नहीं परिवर्तित होती हैं (क्योंकि वे N/4 में आवधिक होते हैं), जबकि यदि हम k में N/2 जोड़ते हैं तो आकार-N/2 डीएफटी अपरिवर्तित रहता है। तो, केवल और शब्द परिवर्तित होते हैं, जिन्हें ट्विडल कारक के रूप में जाना जाता है। यहां, हम सर्वसमिकाओं का उपयोग करते हैं:

अंत में पहुंचने के लिए:

जो सभी आउटपुट देता है, यदि रेंज से को उपरोक्त चार भावों में होने देते है।

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

जब N दो की घात हो तो यह अपघटन पुनरावर्ती रूप से किया जाता है। रिकर्सन के आधार विषय N=1, जहां डीएफटी केवल की प्रति है, और N=2 हैं, जहां डीएफटी जोड़ और घटाव है।

इन विचारों के परिणामस्वरूप गिनती होती है: वास्तविक जोड़ और गुणन, N>1 के लिए दो की घात है। यह गणना मानती है कि, 2 की विषम घात के लिए, 2 का शेष कारक (सभी विभाजन-मूलांक चरणों के पश्चात, जो N को 4 से विभाजित करता है) को सीधे डीएफटी परिभाषा (4 वास्तविक जोड़ और गुणा), या समकक्ष मूलांक-2 कूली-टुकी एफएफटी चरण द्वारा नियंत्रित किया जाता है।

संदर्भ

  • R. Yavne, "An economical method for calculating the discrete Fourier transform," in Proc. AFIPS Fall Joint Computer Conf. 33, 115–125 (1968).
  • P. Duhamel and H. Hollmann, "Split-radix FFT algorithm," Electron. Lett. 20 (1), 14–16 (1984).
  • M. Vetterli and H. J. Nussbaumer, "Simple FFT and DCT algorithms with reduced number of operations," Signal Processing 6 (4), 267–278 (1984).
  • J. B. Martens, "Recursive cyclotomic factorization—a new algorithm for calculating the discrete Fourier transform," IEEE Trans. Acoust., Speech, Signal Processing 32 (4), 750–761 (1984).
  • P. Duhamel and M. Vetterli, "Fast Fourier transforms: a tutorial review and a state of the art," Signal Processing 19, 259–299 (1990).
  • S. G. Johnson and M. Frigo, "A modified split-radix FFT with fewer arithmetic operations," IEEE Trans. Signal Process. 55 (1), 111–119 (2007).
  • Douglas L. Jones, "Split-radix FFT algorithms," Connexions web site (Nov. 2, 2006).
  • H. V. Sorensen, M. T. Heideman, and C. S. Burrus, "On computing the split-radix FFT", IEEE Trans. Acoust., Speech, Signal Processing 34 (1), 152–156 (1986).