वृत्ताकार परिवर्तन: Difference between revisions
(Created page with "{{Refimprove|date=December 2009}} {{multiple image | align = right | total_width = 400 | image1 = Example permutation matrix; circular shift, left.svg | width1 = 169 | hei...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{multiple image | {{multiple image | ||
| align = right | | align = right | ||
Line 9: | Line 8: | ||
| footer = [[Permutation matrix|Matrices]] of 8-element circular shifts to the left and right | | footer = [[Permutation matrix|Matrices]] of 8-element circular shifts to the left and right | ||
}} | }} | ||
[[साहचर्य]] गणित में, | [[साहचर्य]] गणित में, सर्कुलर शिफ्ट टुपल में प्रविष्टियों को पुनर्व्यवस्थित करने का ऑपरेशन है, या तो अंतिम प्रविष्टि को पहले स्थान पर ले जाकर, जबकि अन्य सभी प्रविष्टियों को अगले स्थान पर स्थानांतरित करके, या उलटा ऑपरेशन करके। वृत्ताकार बदलाव विशेष प्रकार का [[चक्रीय क्रम[[परिवर्तन]]]] है, जो बदले में विशेष प्रकार का क्रमपरिवर्तन है। औपचारिक रूप से, गोलाकार बदलाव टुपल में ''एन'' प्रविष्टियों का क्रमपरिवर्तन है जैसे कि या तो | ||
:<math>\sigma(i)\equiv (i+1)</math> [[मॉड्यूलर अंकगणित]] n, सभी प्रविष्टियों के लिए i = 1, ..., n | :<math>\sigma(i)\equiv (i+1)</math> [[मॉड्यूलर अंकगणित]] n, सभी प्रविष्टियों के लिए i = 1, ..., n | ||
या | या | ||
Line 21: | Line 20: | ||
* (बी, सी, डी, ए), | * (बी, सी, डी, ए), | ||
* (ए, बी, सी, डी) (मूल चार-ट्यूपल), | * (ए, बी, सी, डी) (मूल चार-ट्यूपल), | ||
और फिर क्रम दोहराता है; इसलिए इस चार-टुपल में चार अलग-अलग गोलाकार बदलाव हैं। हालाँकि, सभी n-टुपल्स में n विशिष्ट वृत्ताकार बदलाव नहीं होते हैं। उदाहरण के लिए, 4-ट्यूपल (ए, बी, ए, बी) में केवल 2 अलग-अलग गोलाकार बदलाव हैं। | और फिर क्रम दोहराता है; इसलिए इस चार-टुपल में चार अलग-अलग गोलाकार बदलाव हैं। हालाँकि, सभी n-टुपल्स में n विशिष्ट वृत्ताकार बदलाव नहीं होते हैं। उदाहरण के लिए, 4-ट्यूपल (ए, बी, ए, बी) में केवल 2 अलग-अलग गोलाकार बदलाव हैं। n-ट्यूपल की अलग-अलग गोलाकार पारियों की संख्या है <math>\frac{n}{k}</math>, कहाँ {{mvar|k}} का [[भाजक]] है {{mvar|n}}, सभी उप-पैटर्न पर दोहराव की अधिकतम संख्या को दर्शाता है। | ||
[[कंप्यूटर प्रोग्रामिंग]] में, [[बिटवाइज़ रोटेशन]], जिसे सर्कुलर शिफ्ट के रूप में भी जाना जाता है, | [[कंप्यूटर प्रोग्रामिंग]] में, [[बिटवाइज़ रोटेशन]], जिसे सर्कुलर शिफ्ट के रूप में भी जाना जाता है, बिटवाइज़ ऑपरेशन है जो इसके ऑपरेंड के सभी बिट्स को शिफ्ट करता है। [[अंकगणितीय बदलाव]] के विपरीत, गोलाकार बदलाव किसी संख्या के साइन बिट को संरक्षित नहीं करता है या [[चल बिन्दु संख्या]] के घातांक को उसके [[महत्व]] से अलग नहीं करता है। [[तार्किक बदलाव]] के विपरीत, रिक्त बिट स्थिति शून्य से नहीं भरी जाती है, बल्कि अनुक्रम से बाहर स्थानांतरित बिट्स से भरी जाती है। | ||
== सर्कुलर शिफ्ट लागू करना == | == सर्कुलर शिफ्ट लागू करना == | ||
बिट अनुक्रमों को व्यवस्थित करने के लिए [[क्रिप्टोग्राफी]] में अक्सर सर्कुलर शिफ्ट का उपयोग किया जाता है। दुर्भाग्य से, [[सी (प्रोग्रामिंग भाषा)]] सहित कई प्रोग्रामिंग भाषाओं में सर्कुलर शिफ्टिंग के लिए ऑपरेटर या मानक फ़ंक्शन नहीं हैं, भले ही लगभग सभी [[प्रोसेसर]] के पास इसके लिए [[बिटवाइज़ ऑपरेशन]] निर्देश हैं (उदाहरण के लिए [[इंटेल x86]] में आरओएल और आरओआर हैं)। | बिट अनुक्रमों को व्यवस्थित करने के लिए [[क्रिप्टोग्राफी]] में अक्सर सर्कुलर शिफ्ट का उपयोग किया जाता है। दुर्भाग्य से, [[सी (प्रोग्रामिंग भाषा)]] सहित कई प्रोग्रामिंग भाषाओं में सर्कुलर शिफ्टिंग के लिए ऑपरेटर या मानक फ़ंक्शन नहीं हैं, भले ही लगभग सभी [[प्रोसेसर]] के पास इसके लिए [[बिटवाइज़ ऑपरेशन]] निर्देश हैं (उदाहरण के लिए [[इंटेल x86]] में आरओएल और आरओआर हैं)। | ||
हालाँकि, कुछ कंपाइलर [[आंतरिक कार्य]]ों के माध्यम से प्रोसेसर निर्देशों तक पहुंच प्रदान कर सकते हैं। इसके अलावा, मानक [[एएनएसआई सी]] कोड में कुछ निर्माणों को | हालाँकि, कुछ कंपाइलर [[आंतरिक कार्य]]ों के माध्यम से प्रोसेसर निर्देशों तक पहुंच प्रदान कर सकते हैं। इसके अलावा, मानक [[एएनएसआई सी]] कोड में कुछ निर्माणों को कंपाइलर द्वारा सीपीयू पर रोटेट असेंबली भाषा निर्देश के लिए अनुकूलित किया जा सकता है जिसमें ऐसा निर्देश होता है। अधिकांश सी कंपाइलर निम्नलिखित मुहावरे को पहचानते हैं, और इसे एकल 32-बिट रोटेट निर्देश में संकलित करते हैं।<ref> | ||
[https://gcc.gnu.org/ml/gcc-patches/2007-11/msg01112.html GCC: "Optimize common rotate constructs"] | [https://gcc.gnu.org/ml/gcc-patches/2007-11/msg01112.html GCC: "Optimize common rotate constructs"] | ||
</ref><ref> | </ref><ref> | ||
Line 67: | Line 66: | ||
==उदाहरण== | ==उदाहरण== | ||
यदि बिट अनुक्रम 0001 0111 को | यदि बिट अनुक्रम 0001 0111 को बिट स्थिति के गोलाकार बदलाव के अधीन किया गया था... (नीचे चित्र देखें) | ||
{| | {| | ||
| | | | ||
Line 130: | Line 129: | ||
| 1001 0110 | | 1001 0110 | ||
|} | |} | ||
== अनुप्रयोग == | == अनुप्रयोग == | ||
[[चक्रीय कोड]] | [[चक्रीय कोड]] प्रकार का [[ब्लॉक कोड]] होता है, जिसमें यह गुण होता है कि कोडवर्ड का गोलाकार बदलाव हमेशा और कोडवर्ड उत्पन्न करेगा। यह निम्नलिखित सामान्य परिभाषा को प्रेरित करता है: वर्णमाला Σ पर [[स्ट्रिंग (कंप्यूटर विज्ञान)]] के लिए, शिफ्ट (ओं) को एस के परिपत्र शिफ्ट के [[सेट (गणित)]] को निरूपित करें, | ||
और स्ट्रिंग्स के सेट L के लिए, शिफ्ट (L) को L में स्ट्रिंग्स के सभी गोलाकार शिफ्टों के सेट को निरूपित करें। यदि L | और स्ट्रिंग्स के सेट L के लिए, शिफ्ट (L) को L में स्ट्रिंग्स के सभी गोलाकार शिफ्टों के सेट को निरूपित करें। यदि L चक्रीय कोड है, तो शिफ्ट (L) ⊆ L; L के [[चक्रीय भाषा]] होने के लिए यह आवश्यक शर्त है। [[औपचारिक भाषा सिद्धांत]] में ऑपरेशन शिफ्ट (एल) का अध्ययन किया गया है। उदाहरण के लिए, यदि L [[संदर्भ-मुक्त भाषा]] है, तो शिफ्ट(L) फिर से संदर्भ-मुक्त है।<ref>T. Oshiba, "Closure property of the family of context-free languages under the cyclic shift operation", Transactions of IECE, '''55D''':119–122, 1972. | ||
</ref><ref>A. N. Maslov, "Cyclic shift operation for languages", Problems of Information Transmission '''9''':333–338, 1973.</ref> इसके अलावा, यदि एल को लंबाई एन की [[नियमित अभिव्यक्ति]] द्वारा वर्णित किया गया है, तो लंबाई [[ बिग ओ अंकन ]] (एन) की नियमित अभिव्यक्ति है<sup>3</sup>) शिफ्ट (एल) का वर्णन।<ref>{{cite journal | zbl=1176.68105 | last1=Gruber | first1=Hermann | last2=Holzer | first2=Markus | title=बहुपद आकार की नियमित अभिव्यक्तियों के साथ भाषा संचालन| url=http://www.hermann-gruber.com/data/derivatives-journal.pdf | journal=Theoretical Computer Science | volume=410 | number=35 | pages=3281–3289 | year=2009 | doi=10.1016/j.tcs.2009.04.009 | access-date=2012-09-06 | archive-url=https://web.archive.org/web/20170829023123/http://hermann-gruber.com/data/derivatives-journal.pdf | archive-date=2017-08-29 | url-status=dead | doi-access=free }}.</ref> | </ref><ref>A. N. Maslov, "Cyclic shift operation for languages", Problems of Information Transmission '''9''':333–338, 1973.</ref> इसके अलावा, यदि एल को लंबाई एन की [[नियमित अभिव्यक्ति]] द्वारा वर्णित किया गया है, तो लंबाई [[ बिग ओ अंकन |बिग ओ अंकन]] (एन) की नियमित अभिव्यक्ति है<sup>3</sup>) शिफ्ट (एल) का वर्णन।<ref>{{cite journal | zbl=1176.68105 | last1=Gruber | first1=Hermann | last2=Holzer | first2=Markus | title=बहुपद आकार की नियमित अभिव्यक्तियों के साथ भाषा संचालन| url=http://www.hermann-gruber.com/data/derivatives-journal.pdf | journal=Theoretical Computer Science | volume=410 | number=35 | pages=3281–3289 | year=2009 | doi=10.1016/j.tcs.2009.04.009 | access-date=2012-09-06 | archive-url=https://web.archive.org/web/20170829023123/http://hermann-gruber.com/data/derivatives-journal.pdf | archive-date=2017-08-29 | url-status=dead | doi-access=free }}.</ref> | ||
Line 144: | Line 141: | ||
*[[परिसंचारी]] | *[[परिसंचारी]] | ||
*[[लिंडन शब्द]] | *[[लिंडन शब्द]] | ||
*नेकलेस (कॉम्बिनेटरिक्स) - टपल जैसी | *नेकलेस (कॉम्बिनेटरिक्स) - टपल जैसी वस्तु लेकिन जिसके लिए गोलाकार बदलाव को समकक्ष माना जाता है। | ||
==संदर्भ== | ==संदर्भ== |
Revision as of 10:25, 19 July 2023
साहचर्य गणित में, सर्कुलर शिफ्ट टुपल में प्रविष्टियों को पुनर्व्यवस्थित करने का ऑपरेशन है, या तो अंतिम प्रविष्टि को पहले स्थान पर ले जाकर, जबकि अन्य सभी प्रविष्टियों को अगले स्थान पर स्थानांतरित करके, या उलटा ऑपरेशन करके। वृत्ताकार बदलाव विशेष प्रकार का [[चक्रीय क्रमपरिवर्तन]] है, जो बदले में विशेष प्रकार का क्रमपरिवर्तन है। औपचारिक रूप से, गोलाकार बदलाव टुपल में एन प्रविष्टियों का क्रमपरिवर्तन है जैसे कि या तो
- मॉड्यूलर अंकगणित n, सभी प्रविष्टियों के लिए i = 1, ..., n
या
- मॉड्यूलर अंकगणित n, सभी प्रविष्टियों के लिए i = 1, ..., n।
किसी दिए गए टुपल में बार-बार वृत्ताकार बदलाव लागू करने के परिणाम को ट्यूपल का 'वृत्ताकार बदलाव' भी कहा जाता है।
उदाहरण के लिए, चार-टुपल (ए, बी, सी, डी) में बार-बार गोलाकार बदलाव लगाने से क्रमिक रूप से लाभ मिलता है
- (डी, ए, बी, सी),
- (सी, डी, ए, बी),
- (बी, सी, डी, ए),
- (ए, बी, सी, डी) (मूल चार-ट्यूपल),
और फिर क्रम दोहराता है; इसलिए इस चार-टुपल में चार अलग-अलग गोलाकार बदलाव हैं। हालाँकि, सभी n-टुपल्स में n विशिष्ट वृत्ताकार बदलाव नहीं होते हैं। उदाहरण के लिए, 4-ट्यूपल (ए, बी, ए, बी) में केवल 2 अलग-अलग गोलाकार बदलाव हैं। n-ट्यूपल की अलग-अलग गोलाकार पारियों की संख्या है , कहाँ k का भाजक है n, सभी उप-पैटर्न पर दोहराव की अधिकतम संख्या को दर्शाता है।
कंप्यूटर प्रोग्रामिंग में, बिटवाइज़ रोटेशन, जिसे सर्कुलर शिफ्ट के रूप में भी जाना जाता है, बिटवाइज़ ऑपरेशन है जो इसके ऑपरेंड के सभी बिट्स को शिफ्ट करता है। अंकगणितीय बदलाव के विपरीत, गोलाकार बदलाव किसी संख्या के साइन बिट को संरक्षित नहीं करता है या चल बिन्दु संख्या के घातांक को उसके महत्व से अलग नहीं करता है। तार्किक बदलाव के विपरीत, रिक्त बिट स्थिति शून्य से नहीं भरी जाती है, बल्कि अनुक्रम से बाहर स्थानांतरित बिट्स से भरी जाती है।
सर्कुलर शिफ्ट लागू करना
बिट अनुक्रमों को व्यवस्थित करने के लिए क्रिप्टोग्राफी में अक्सर सर्कुलर शिफ्ट का उपयोग किया जाता है। दुर्भाग्य से, सी (प्रोग्रामिंग भाषा) सहित कई प्रोग्रामिंग भाषाओं में सर्कुलर शिफ्टिंग के लिए ऑपरेटर या मानक फ़ंक्शन नहीं हैं, भले ही लगभग सभी प्रोसेसर के पास इसके लिए बिटवाइज़ ऑपरेशन निर्देश हैं (उदाहरण के लिए इंटेल x86 में आरओएल और आरओआर हैं)। हालाँकि, कुछ कंपाइलर आंतरिक कार्यों के माध्यम से प्रोसेसर निर्देशों तक पहुंच प्रदान कर सकते हैं। इसके अलावा, मानक एएनएसआई सी कोड में कुछ निर्माणों को कंपाइलर द्वारा सीपीयू पर रोटेट असेंबली भाषा निर्देश के लिए अनुकूलित किया जा सकता है जिसमें ऐसा निर्देश होता है। अधिकांश सी कंपाइलर निम्नलिखित मुहावरे को पहचानते हैं, और इसे एकल 32-बिट रोटेट निर्देश में संकलित करते हैं।[1][2]
/*
* Shift operations in C are only defined for shift values which are
* not negative and smaller than sizeof(value) * CHAR_BIT.
* The mask, used with bitwise-and (&), prevents undefined behaviour
* when the shift count is 0 or >= the width of unsigned int.
*/
#include <stdint.h> // for uint32_t, to get 32-bit-wide rotates, regardless of the size of int.
#include <limits.h> // for CHAR_BIT
uint32_t rotl32 (uint32_t value, unsigned int count) {
const unsigned int mask = CHAR_BIT * sizeof(value) - 1;
count &= mask;
return (value << count) | (value >> (-count & mask));
}
uint32_t rotr32 (uint32_t value, unsigned int count) {
const unsigned int mask = CHAR_BIT * sizeof(value) - 1;
count &= mask;
return (value >> count) | (value << (-count & mask));
}
यह सुरक्षित और संकलक-अनुकूल कार्यान्वयन जॉन रेगेहर द्वारा विकसित किया गया था,[3] और इसे पीटर कॉर्डेस द्वारा और अधिक परिष्कृत किया गया।[4][5]
एक सरल संस्करण अक्सर देखा जाता है जब count
1 से 31 बिट्स की सीमा तक सीमित है:
uint32_t rotl32 (uint32_t value, unsigned int count) {
return value << count | value >> (32 - count);
}
यह संस्करण खतरनाक है क्योंकि यदि count
0 या 32 है, तो यह 32-बिट शिफ्ट के लिए पूछता है, जो सी भाषा मानक में अपरिभाषित व्यवहार है। हालाँकि, यह वैसे भी काम करता है, क्योंकि अधिकांश माइक्रोप्रोसेसर इसे लागू करते हैं value >> 32
या तो 32-बिट शिफ्ट (0 का उत्पादन) या 0-बिट शिफ्ट (मूल का उत्पादन) के रूप में value
), और इनमें से कोई भी इस एप्लिकेशन में सही परिणाम देता है।
उदाहरण
यदि बिट अनुक्रम 0001 0111 को बिट स्थिति के गोलाकार बदलाव के अधीन किया गया था... (नीचे चित्र देखें)
|
|
यदि बिट अनुक्रम 1001 0110 को निम्नलिखित परिचालनों के अधीन किया गया था:
left circular shift by 1 position: | 0010 1101 |
left circular shift by 2 positions: | 0101 1010 |
left circular shift by 3 positions: | 1011 0100 |
left circular shift by 4 positions: | 0110 1001 |
left circular shift by 5 positions: | 1101 0010 |
left circular shift by 6 positions: | 1010 0101 |
left circular shift by 7 positions: | 0100 1011 |
left circular shift by 8 positions: | 1001 0110 |
right circular shift by 1 position: | 0100 1011 |
right circular shift by 2 positions: | 1010 0101 |
right circular shift by 3 positions: | 1101 0010 |
right circular shift by 4 positions: | 0110 1001 |
right circular shift by 5 positions: | 1011 0100 |
right circular shift by 6 positions: | 0101 1010 |
right circular shift by 7 positions: | 0010 1101 |
right circular shift by 8 positions: | 1001 0110 |
अनुप्रयोग
चक्रीय कोड प्रकार का ब्लॉक कोड होता है, जिसमें यह गुण होता है कि कोडवर्ड का गोलाकार बदलाव हमेशा और कोडवर्ड उत्पन्न करेगा। यह निम्नलिखित सामान्य परिभाषा को प्रेरित करता है: वर्णमाला Σ पर स्ट्रिंग (कंप्यूटर विज्ञान) के लिए, शिफ्ट (ओं) को एस के परिपत्र शिफ्ट के सेट (गणित) को निरूपित करें, और स्ट्रिंग्स के सेट L के लिए, शिफ्ट (L) को L में स्ट्रिंग्स के सभी गोलाकार शिफ्टों के सेट को निरूपित करें। यदि L चक्रीय कोड है, तो शिफ्ट (L) ⊆ L; L के चक्रीय भाषा होने के लिए यह आवश्यक शर्त है। औपचारिक भाषा सिद्धांत में ऑपरेशन शिफ्ट (एल) का अध्ययन किया गया है। उदाहरण के लिए, यदि L संदर्भ-मुक्त भाषा है, तो शिफ्ट(L) फिर से संदर्भ-मुक्त है।[6][7] इसके अलावा, यदि एल को लंबाई एन की नियमित अभिव्यक्ति द्वारा वर्णित किया गया है, तो लंबाई बिग ओ अंकन (एन) की नियमित अभिव्यक्ति है3) शिफ्ट (एल) का वर्णन।[8]
यह भी देखें
- बैरल शिफ्टर
- परिसंचारी
- लिंडन शब्द
- नेकलेस (कॉम्बिनेटरिक्स) - टपल जैसी वस्तु लेकिन जिसके लिए गोलाकार बदलाव को समकक्ष माना जाता है।
संदर्भ
- ↑ GCC: "Optimize common rotate constructs"
- ↑ "Cleanups in ROTL/ROTR DAG combiner code" mentions that this code supports the "rotate" instruction in the CellSPU
- ↑ Safe, Efficient, and Portable Rotate in C/C++
- ↑ Stackoverflow: Best practices for rotates in C/C++
- ↑ Near constant time rotate that does not violate the standards
- ↑ T. Oshiba, "Closure property of the family of context-free languages under the cyclic shift operation", Transactions of IECE, 55D:119–122, 1972.
- ↑ A. N. Maslov, "Cyclic shift operation for languages", Problems of Information Transmission 9:333–338, 1973.
- ↑ Gruber, Hermann; Holzer, Markus (2009). "बहुपद आकार की नियमित अभिव्यक्तियों के साथ भाषा संचालन" (PDF). Theoretical Computer Science. 410 (35): 3281–3289. doi:10.1016/j.tcs.2009.04.009. Zbl 1176.68105. Archived from the original (PDF) on 2017-08-29. Retrieved 2012-09-06..