यह एक खास डेटा स्ट्रक्चर है, जो बेहतर मर्ज ऑपरेशन की सुविधा देता है. साथ ही, इसके ट्रैवर्सल ऑर्डर को तय किया जाता है. आम तौर पर, इसका इस्तेमाल, नियमों और पहलुओं में ट्रांज़िटिव डिपेंडेंसी से डेटा इकट्ठा करने के लिए किया जाता है. ज़्यादा जानकारी के लिए यहां देखें.
डिप्सेट के एलिमेंट हैश किए जा सकने वाले होने चाहिए और उनका टाइप (जैसा कि बिल्ट-इन टाइप(x) फ़ंक्शन में बताया गया है) एक जैसा होना चाहिए. हालांकि, डेपसेट सिर्फ़ हैश सेट नहीं हैं और वे पैसे चुकाकर ली जाने वाली सदस्यता की तेज़ी से जांच करने की सुविधा भी नहीं देते. अगर आपको किसी सामान्य सेट डेटा टाइप की ज़रूरत है, तो डिक्शनरी का इस्तेमाल करके किसी डेटा टाइप को सिम्युलेट किया जा सकता है. यहां सभी बटन True
से मैप होते हैं.
डेपसेट में बदलाव नहीं किया जा सकता. इन्हें उनके कंस्ट्रक्टर फ़ंक्शन का इस्तेमाल करके बनाया जाना चाहिए. साथ ही, transitive
आर्ग्युमेंट के ज़रिए दूसरे डिवाइसों के साथ मर्ज या ऑगमेंटेड करना चाहिए.
order
पैरामीटर से यह तय होता है कि किस तरह का ट्रैवर्सल है, जो डिप्सेट को बार-बार दोहराए जाने वाले में बदलता है. इसके चार संभावित मान हो सकते हैं:
"default"
(पहले"stable"
था): ऑर्डर की जानकारी नहीं दी गई है, लेकिन यह तय किया गया है कि ऑर्डर के मुताबिक ही ऑर्डर किया जा सकता है."postorder"
(पहले"compile"
था): ऑर्डर करने के बाद, बाएं से दाएं के क्रम में. इस तरीके से, सबसे बाईं ओर पहले और फिर सीधे तौर पर बाईं ओर मौजूद बच्चों को सबसे पहले दिखाया जाता है."preorder"
(पहले"naive_link"
था): बाएं से दाएं पहले से ऑर्डर करने की सुविधा. यह बिलकुल बाईं ओर के पहले एलिमेंट से मिलता है. इसके बाद, सबसे बाईं तरफ़ वाले बच्चों को बार-बार देखता है."topological"
(पहले"link"
था): मूल जड़ से लेकर पत्तियों तक एक टोपोलॉजील ऑर्डर. बाईं-से-दाईं ओर कोई गारंटी नहीं है.
दो डेपसेट सिर्फ़ तब मर्ज किए जा सकते हैं, जब दोनों में से किसी एक का क्रम एक जैसा हो या किसी एक में "default"
का क्रम हो. बाद के मामले में, नतीजे वाले डिप्सेट का क्रम दूसरे ऑर्डर के जैसा ही होगा.
हटाए गए वैल्यू में डुप्लीकेट वैल्यू हो सकती हैं. हालांकि, to_list()
का इस्तेमाल करके, दोहराए जाने वाले वैल्यू को रोक दिया जाएगा. डुप्लीकेट लिंक, क्रम के सिमेंटिक्स में रुकावट डाल सकते हैं.
सदस्य
to_list
list depset.to_list()
"default"
के ऑर्डर किए गए डिप्सेट के लिए भी तय नहीं किया गया है. इसके अलावा, उन चाइल्ड डेपसेट के लिए भी नहीं बताया गया है जिनका ऑर्डर पैरंट डेसेट से अलग है. यह सूची एक कॉपी है; इसे बदलने से डिप्सेट पर कोई असर नहीं पड़ता और डिप्सेट पर इसका कोई असर नहीं पड़ता.