हैश ऐरे मैप्ड ट्रिए

हैश ऐरे मैप्ड ट्रिए (एचएएमटी) एक अस्सोसिएटिवे ऐरे का इम्प्लीमेंटेशन है जो हैश टेबल और हैश ऐरे मैप्ड ट्रिए की विशेषताओं को जोड़ता है। यह हैश ट्रिए (लगातार डेटा संरचना) की अधिक जनरल नोशन का एक रिफाइंड वरजन है।

संचालन
एचएएमटी एक ऐरे मैप्ड ट्रिए है जहां कीज़ का समान वितरण और निरंतर कुंजी लंबाई सुनिश्चित करने के लिए कीज़ को पहले हैश किया जाता है।

एचएएमटी के एरे मैप्ड ट्रिए के एक विशिष्ट कार्यान्वयन में, प्रत्येक बिंदु में कुछ निश्चित संख्या N स्लॉट के साथ एक टेबल होती है, जिसमें प्रत्येक स्लॉट में एक शून्य पॉइंटर या दूसरे बिंदु के लिए एक पॉइंटर होता है। N सामान्यतः 32 है। चूंकि प्रत्येक बिंदु के लिए N पॉइंटर के लिए स्थान आवंटित करना महंगा होगा, इसके स्थान पर प्रत्येक बिंदु में एक बिटमैप होता है जो N बिट लंबा होता है जहां प्रत्येक बिट एक गैर-शून्य पॉइंटर की उपस्थिति को इंडीकेट करता है। इसके बाद बिटमैप (इसका हैमिंग भार) में पॉइंटर की संख्या के बराबर लंबाई वाले पॉइंटर की एक ऐरे होती है।

एचएएमटी के लाभ
हैश ऐरे मैप्ड ट्राई मेमोरी का अधिक एकनॉमिकली उपयोग करते हुए लगभग हैश टेबल जैसी गति प्राप्त करता है। साथ ही, हैश टेबल का समय-समय पर आकार बदलना पड़ सकता है, जो एक महंगा संचालन है, जबकि एचएएमटी गतिशील रूप से बढ़ते हैं। सामान्यतः, एचएएमटी प्रदर्शन में कुछ एन स्लॉट के साथ एक बड़ी क्रम टेबल द्वारा सुधार किया जाता है; कुछ एचएएमटी प्रकार जड़ को प्रदर्शन पर नगण्य प्रभाव के साथ धीरे-धीरे बढ़ने देते हैं।

कार्यान्वयन विवरण
एचएएमटी के कार्यान्वयन में हैमिंग भार फलन का उपयोग सम्मिलित है, जो किसी संख्या के बाइनरी रिप्रजेंटेशन में नंबर ऑफ़ वंस की गणना करता है। यह संचालन हैमिंग वेट समर्थन में उपलब्ध है, लेकिन यह हैमिंग वेट केवल कुछ उच्च-स्तरीय लैंग्वेजओं में उपलब्ध है। हालाँकि जनसंख्या गणना को हैमिंग वेट इम्प्लीमेंटेशन का उपयोग करके O(1) समय में सॉफ़्टवेयर में लागू किया जा सकता है, ऐसा करने से संचालन आर्डर ऑफ़ मैग्नीट्यूड में धीमा हो सकता है।

कार्यान्वयन
प्रोग्रामिंग लैंग्वेजएँ क्लोजर, स्काला (प्रोग्रामिंग लैंग्वेज), और फ़्रीज (प्रोग्रामिंग लैंग्वेज) अपने मूल हैश मैप्ड प्रकार के लिए हैश ऐरे मैप्ड किए गए प्रयासों के लगातार डेटा संरचना संस्करण का उपयोग करें। हास्केल (प्रोग्रामिंग लैंग्वेज) लाइब्रेरी अनआर्डरड-कंटेनर्स लगातार मैप को लागू करने और डेटा स्ट्रक्चर को सम्मुच्चय करने के लिए इसका उपयोग करती है। एक अन्य हास्केल लाइब्रेरी एसटीएम-धारक सॉफ़्टवेयर ट्रांसेक्शनल मेमोरी के संदर्भ में उपयोग के लिए कलन विधि को अनुकूलित करता है। एक जावास्क्रिप्ट एचएएमटी लाइब्रेरी क्लोजर कार्यान्वयन पर आधारित भी उपलब्ध है। रुबिनियस रूबी (प्रोग्रामिंग लैंग्वेज) के कार्यान्वयन में एक एचएएमटी सम्मिलित है, जो अधिकतर रूबी में लिखा गया है लेकिन 3 के साथ एर्लैंग (प्रोग्रामिंग लैंग्वेज) में बड़े मैप्ड विमोचन 18.0 के बाद से आंतरिक रूप से एक पर्सिस्टेंट डेटा संरचना एचएएमटी प्रतिनिधित्व का उपयोग करते हैं। पोनी प्रोग्रामिंग लैंग्वेज अपने सतत संग्रह पैकेज में हैश मैप्ड के लिए एचएएमटी का उपयोग करती है।

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

यह भी देखें

 * जूडी ऐरे
 * मूलांक ट्री