सफिक्स ट्री

From Vigyanwiki
Revision as of 19:18, 10 July 2023 by alpha>Indicwiki (Created page with "{{short description|Tree containing all suffixes of a given text}} Image:Suffix tree BANANA.svg|thumb|250px|right|पाठ के लिए प्रत्यय वृक...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
पाठ के लिए प्रत्यय वृक्ष BANANA. प्रत्येक सबस्ट्रिंग को विशेष वर्ण के साथ समाप्त किया जाता है $. जड़ से पत्तियों तक के छह रास्ते (बक्से के रूप में दिखाए गए) छह प्रत्ययों के अनुरूप हैं A$, NA$, ANA$, NANA$, ANANA$ और BANANA$. पत्तों की संख्याएँ संबंधित प्रत्यय की आरंभिक स्थिति बताती हैं। निर्माण के दौरान धराशायी खींचे गए प्रत्यय लिंक का उपयोग किया जाता है।

कंप्यूटर विज्ञान में, एक प्रत्यय वृक्ष (जिसे पीएटी वृक्ष या, पहले के रूप में, स्थिति वृक्ष भी कहा जाता है) एक संपीड़ित त्रि है जिसमें दिए गए पाठ के सभी प्रत्यय (कंप्यूटर विज्ञान) उनकी कुंजी के रूप में और पाठ में उनके मूल्यों के रूप में स्थित होते हैं। प्रत्यय वृक्ष कई महत्वपूर्ण स्ट्रिंग ऑपरेशनों के विशेष रूप से तेज़ कार्यान्वयन की अनुमति देते हैं।

डोरी के लिए ऐसे वृक्ष का निर्माण की लंबाई में समय और स्थान को रैखिक लेता है . एक बार निर्माण हो जाने के बाद, कई ऑपरेशन तुरंत किए जा सकते हैं, उदाहरण के लिए एक सबस्ट्रिंग का पता लगाना , यदि एक निश्चित संख्या में गलतियों की अनुमति है तो एक सबस्ट्रिंग का पता लगाना, नियमित अभिव्यक्ति पैटर्न के लिए मिलान का पता लगाना आदि। प्रत्यय पेड़ों ने सबसे लंबी सामान्य सबस्ट्रिंग समस्या के लिए पहले रैखिक-समय समाधानों में से एक भी प्रदान किया।[2] ये स्पीडअप लागत पर आते हैं: एक स्ट्रिंग के प्रत्यय वृक्ष को संग्रहीत करने के लिए आमतौर पर स्ट्रिंग को संग्रहीत करने की तुलना में काफी अधिक स्थान की आवश्यकता होती है।

इतिहास

इस अवधारणा को सबसे पहले पेश किया गया था Weiner (1973). प्रत्यय के बजाय , वेनर ने अपनी तिकड़ी में संग्रहित किया[3] प्रत्येक स्थिति के लिए उपसर्ग पहचानकर्ता, अर्थात, प्रारंभ होने वाली सबसे छोटी स्ट्रिंग और केवल एक बार घटित होता है . उसका एल्गोरिदम डी एक असम्पीडित लेता है[4] के लिए प्रयास करें और इसे एक प्रयास में विस्तारित करता है . इस तरह, के लिए तुच्छ प्रयास से शुरू करते हैं , के लिए एक प्रयास द्वारा बनाया जा सकता है एल्गोरिथम डी को लगातार कॉल; हालाँकि, कुल मिलाकर रन टाइम है . वेनर का एल्गोरिथम बी निर्मित ट्राइ के आकार में समग्र रन टाइम रैखिक प्राप्त करने के लिए कई सहायक डेटा संरचनाओं को बनाए रखता है। उत्तरार्द्ध अभी भी हो सकता है नोड्स, उदा. के लिए वेनर का एल्गोरिदम सी अंततः रैखिक समग्र भंडारण आकार और रन टाइम प्राप्त करने के लिए संपीड़ित प्रयासों का उपयोग करता है।[5] बाद में डोनाल्ड नुथ ने बाद की विशेषता बताई वर्ष 1973 के एल्गोरिदम के रूप में।[citation needed] पाठ्यपुस्तक Aho, Hopcroft & Ullman (1974, Sect.9.5) वेनर के परिणामों को एक सरलीकृत और अधिक सुंदर रूप में पुन: प्रस्तुत किया गया, जिसमें पोजीशन ट्री शब्द का परिचय दिया गया।

McCreight (1976) सभी प्रत्ययों का एक (संपीड़ित) त्रि बनाने वाला पहला व्यक्ति था . यद्यपि प्रत्यय प्रारंभ हो रहा है आमतौर पर उपसर्ग पहचानकर्ता से अधिक लंबा होता है, संपीड़ित ट्राई में उनका पथ प्रतिनिधित्व आकार में भिन्न नहीं होता है। दूसरी ओर, मैकक्रेइट वेनर की अधिकांश सहायक डेटा संरचनाओं को छोड़ सकता है; केवल प्रत्यय कड़ियाँ ही रह गईं।

Ukkonen (1995) निर्माण को और सरल बनाया।[6] उन्होंने प्रत्यय पेड़ों का पहला ऑनलाइन-निर्माण प्रदान किया, जिसे अब उक्कोनेन के एल्गोरिदम के रूप में जाना जाता है, जिसमें चलने का समय तत्कालीन सबसे तेज़ एल्गोरिदम से मेल खाता था। ये एल्गोरिदम सभी स्थिर-आकार वर्णमाला के लिए रैखिक-समय हैं, और सबसे खराब स्थिति में चलने का समय है सामान्य रूप में।

Farach (1997) ने पहला प्रत्यय वृक्ष निर्माण एल्गोरिदम दिया जो सभी वर्णमालाओं के लिए इष्टतम है। विशेष रूप से, यह पहला रैखिक-समय एल्गोरिदम है बहुपद श्रेणी में पूर्णांकों की वर्णमाला से खींची गई स्ट्रिंग के लिए। फ़राच का एल्गोरिदम प्रत्यय वृक्षों और प्रत्यय सरणियों दोनों के निर्माण के लिए नए एल्गोरिदम का आधार बन गया है, उदाहरण के लिए, बाहरी मेमोरी में, संपीड़ित, संक्षिप्त, आदि।

परिभाषा

स्ट्रिंग के लिए प्रत्यय वृक्ष लम्बाई का इसे एक पेड़ के रूप में परिभाषित किया गया है जैसे:[7]

  • पेड़ में बिल्कुल n पत्तियाँ क्रमांकित हैं को .
  • जड़ को छोड़कर, प्रत्येक पेड़ (डेटा संरचना)#शब्दावली में कम से कम दो बच्चे होते हैं।
  • प्रत्येक किनारे को एक गैर-रिक्त सबस्ट्रिंग के साथ लेबल किया गया है .
  • किसी नोड से शुरू होने वाले किसी भी दो किनारों में एक ही वर्ण से शुरू होने वाले स्ट्रिंग-लेबल नहीं हो सकते हैं।
  • जड़ से पत्ती तक पथ पर पाए जाने वाले सभी स्ट्रिंग-लेबलों को संयोजित करके प्राप्त स्ट्रिंग प्रत्यय का उच्चारण करता है , के लिए से को .

चूँकि ऐसा पेड़ सभी तारों के लिए मौजूद नहीं है, एक टर्मिनल प्रतीक के साथ गद्देदार है जो स्ट्रिंग में नहीं देखा जाता है (आमतौर पर दर्शाया जाता है)। $). यह सुनिश्चित करता है कि कोई भी प्रत्यय दूसरे का उपसर्ग नहीं है, और रहेगा लीफ नोड्स, प्रत्येक के लिए एक के प्रत्यय . चूंकि सभी आंतरिक गैर-रूट नोड्स शाखाएं हैं, इसलिए अधिकतम n − 1 ऐसे नोड हो सकते हैं, और n + (n − 1) + 1 = 2n नोड्स कुल मिलाकर (n पत्तियां, n − 1 आंतरिक गैर-रूट नोड्स, 1) जड़)।

'प्रत्यय लिंक' पुराने रैखिक-समय निर्माण एल्गोरिदम के लिए एक प्रमुख विशेषता है, हालांकि अधिकांश नए एल्गोरिदम, जो फ़राच के एल्गोरिदम पर आधारित हैं, प्रत्यय लिंक से दूर हैं। एक पूर्ण प्रत्यय वृक्ष में, सभी आंतरिक गैर-रूट नोड्स में किसी अन्य आंतरिक नोड के लिए एक प्रत्यय लिंक होता है। यदि रूट से नोड तक का पथ स्ट्रिंग को वर्तनी देता है , कहाँ एक एकल वर्ण है और एक स्ट्रिंग है (संभवतः खाली), इसमें आंतरिक नोड का प्रतिनिधित्व करने वाला एक प्रत्यय लिंक है . उदाहरण के लिए नोड से प्रत्यय लिंक देखें ANA के लिए नोड के लिए NA उपरोक्त चित्र में. ट्री पर चलने वाले कुछ एल्गोरिदम में प्रत्यय लिंक का भी उपयोग किया जाता है।

एक सामान्यीकृत प्रत्यय वृक्ष एक एकल स्ट्रिंग के बजाय तारों के एक सेट के लिए बनाया गया एक प्रत्यय वृक्ष है। यह स्ट्रिंग के इस सेट से सभी प्रत्ययों का प्रतिनिधित्व करता है। प्रत्येक स्ट्रिंग को एक अलग समाप्ति प्रतीक द्वारा समाप्त किया जाना चाहिए।

कार्यक्षमता

एक स्ट्रिंग के लिए एक प्रत्यय वृक्ष लम्बाई का में बनाया जा सकता है समय, यदि अक्षर बहुपद श्रेणी में पूर्णांकों की वर्णमाला से आते हैं (विशेष रूप से, यह स्थिर आकार के वर्णमाला के लिए सच है)।[8] बड़े अक्षरों के लिए, अक्षरों को आकार की एक सीमा में लाने के लिए चलने का समय पहले छँटाई एल्गोरिथ्म पर हावी होता है ; सामान्य तौर पर, यह लगता है समय। नीचे लागतें इस धारणा के तहत दी गई हैं कि वर्णमाला स्थिर है।

मान लें कि स्ट्रिंग के लिए एक प्रत्यय वृक्ष बनाया गया है लम्बाई का , या कि स्ट्रिंग्स के सेट के लिए एक सामान्यीकृत प्रत्यय वृक्ष बनाया गया है कुल लंबाई का . तुम कर सकते हो:

  • तार खोजें:
    • जांचें कि क्या कोई स्ट्रिंग है लम्बाई का में एक सबस्ट्रिंग है समय।[9]
    • पैटर्न की पहली घटना का पता लगाएं कुल लंबाई का में सबस्ट्रिंग के रूप में समय।
    • सब ढूँढ़ो पैटर्न की घटनाएँ कुल लंबाई का में सबस्ट्रिंग के रूप में समय।[10]
    • समय अपेक्षित सबलाइनियर टाइम एल्गोरिदम में नियमित अभिव्यक्ति पी की खोज करें .[11]
    • एक पैटर्न के प्रत्येक प्रत्यय के लिए खोजें , के उपसर्ग के बीच सबसे लंबे मिलान की लंबाई और एक सबस्ट्रिंग में समय।[12] इसे मिलान आँकड़े कहा जाता है .
  • स्ट्रिंग्स के गुण खोजें:
    • स्ट्रिंग की सबसे लंबी सामान्य सबस्ट्रिंग समस्या ढूंढें और में समय।[13]
    • सभी अधिकतम जोड़े, अधिकतम दोहराव या सुपरमैक्सिमल दोहराव खोजें समय।[14]
    • लेम्पेल-ज़िव अपघटन का पता लगाएं समय।[15]
    • सबसे लंबी बार-बार दोहराई जाने वाली सबस्ट्रिंग समस्या ढूंढें समय।
    • न्यूनतम लंबाई की सबसे अधिक बार आने वाली सबस्ट्रिंग खोजें समय।
    • से सबसे छोटी तार खोजें जो कि घटित नहीं होता है , में समय, अगर वहाँ हैं ऐसे तार.
    • केवल एक बार आने वाली सबसे छोटी सबस्ट्रिंग ढूंढें समय।
    • प्रत्येक के लिए खोजें , का सबसे छोटा उपस्ट्रिंग में अन्यत्र नहीं घटित हो रहा है में समय।

प्रत्यय वृक्ष को नोड्स के बीच निरंतर समय न्यूनतम सामान्य पूर्वज पुनर्प्राप्ति के लिए तैयार किया जा सकता है समय।[16] तब कोई यह भी कर सकता है:

  • प्रत्ययों के बीच सबसे लंबा सामान्य उपसर्ग खोजें और में .[17]
  • अधिकतम k बेमेल के साथ लंबाई m का एक पैटर्न P खोजें समय, जहां z हिट्स की संख्या है।[18]
  • सब ढूँढ़ो अधिकतम विलोमपद ,[19] या यदि लंबाई का अंतराल हो तो समय अनुमति है, या अगर बेमेल की अनुमति है.[20]
  • सब ढूँढ़ो अग्रानुक्रम दोहराता है , और k-बेमेल अग्रानुक्रम दोहराता है .[21]
  • कम से कम सबसे लंबी सामान्य सबस्ट्रिंग समस्या ढूंढें में तार के लिए में समय।[22]
  • रैखिक समय में किसी दिए गए स्ट्रिंग का सबसे लंबा पैलिंड्रोमिक सबस्ट्रिंग (स्ट्रिंग के सामान्यीकृत प्रत्यय ट्री और उसके रिवर्स का उपयोग करके) ढूंढें।[23]


अनुप्रयोग

प्रत्यय वृक्षों का उपयोग पाठ-संपादन, मुक्त-पाठ खोज, कम्प्यूटेशनल बायोलॉजी विज्ञान और अन्य अनुप्रयोग क्षेत्रों में होने वाली बड़ी संख्या में स्ट्रिंग समस्याओं को हल करने के लिए किया जा सकता है।[24]प्राथमिक अनुप्रयोगों में शामिल हैं:[24]

  • स्ट्रिंग खोज # इंडेक्स विधियां, ओ (एम) जटिलता में, जहां एम उप-स्ट्रिंग की लंबाई है (लेकिन प्रारंभिक ओ (एन) समय के साथ स्ट्रिंग के लिए प्रत्यय पेड़ बनाने के लिए आवश्यक है)
  • सबसे लंबी दोहराई जाने वाली सबस्ट्रिंग ढूँढना
  • सबसे लंबी सामान्य उपस्ट्रिंग ढूँढना
  • एक स्ट्रिंग में सबसे लंबा पैलिंड्रोम ढूँढना

प्रत्यय वृक्षों का उपयोग अक्सर जैव सूचना विज्ञान अनुप्रयोगों में किया जाता है, डीएनए या प्रोटीन अनुक्रमों में पैटर्न की खोज की जाती है (जिन्हें वर्णों की लंबी श्रृंखला के रूप में देखा जा सकता है)। बेमेल के साथ कुशलतापूर्वक खोज करने की क्षमता उनकी सबसे बड़ी ताकत मानी जा सकती है। प्रत्यय वृक्षों का उपयोग डेटा संपीड़न में भी किया जाता है; उनका उपयोग बार-बार डेटा खोजने के लिए किया जा सकता है, और बरोज़-व्हीलर ट्रांसफ़ॉर्म के सॉर्टिंग चरण के लिए भी किया जा सकता है। LZW संपीड़न योजनाओं के वेरिएंट प्रत्यय वृक्ष (LZSS) का उपयोग करते हैं। प्रत्यय ट्री का उपयोग प्रत्यय वृक्ष समूहन में भी किया जाता है, जो कुछ खोज इंजनों में उपयोग किया जाने वाला डेटा क्लस्टरिंग एल्गोरिदम है।[25]


कार्यान्वयन

यदि प्रत्येक नोड और किनारे को दर्शाया जा सकता है अंतरिक्ष में, पूरे पेड़ का प्रतिनिधित्व किया जा सकता है अंतरिक्ष। पेड़ के सभी किनारों पर सभी तारों की कुल लंबाई है , लेकिन प्रत्येक किनारे को एक सबस्ट्रिंग की स्थिति और लंबाई के रूप में संग्रहीत किया जा सकता है S, का कुल स्थान उपयोग दे रहा है कंप्यूटर शब्द. प्रत्यय वृक्ष का सबसे खराब स्थिति वाला स्थान उपयोग एक फाइबोनैचि शब्द के साथ देखा जाता है, जो पूर्ण देता है नोड्स.

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

  • किसी दिए गए चरित्र पर बच्चे को खोजने की लागत।
  • एक बच्चे को सम्मिलित करने की लागत.
  • एक नोड के सभी बच्चों को सूचीबद्ध करने की लागत (नीचे दी गई तालिका में बच्चों की संख्या से विभाजित)।

होने देना σ वर्णमाला का आकार हो. तब आपकी निम्नलिखित लागतें होंगी:

प्रविष्टि लागत का परिशोधन किया जाता है, और हैशिंग की लागत सही हैशिंग के लिए दी जाती है।

प्रत्येक किनारे और नोड में बड़ी मात्रा में जानकारी प्रत्यय वृक्ष को बहुत महंगा बनाती है, अच्छे कार्यान्वयन में स्रोत पाठ की मेमोरी आकार का लगभग 10 से 20 गुना उपभोग करती है। प्रत्यय सरणी इस आवश्यकता को 8 के कारक तक कम कर देती है (32-बिट एड्रेस स्पेस और 8-बिट वर्णों के भीतर निर्मित एलसीपी सरणी मानों सहित सरणी के लिए।) यह कारक गुणों पर निर्भर करता है और 4-बाइट चौड़े वर्णों के उपयोग के साथ 2 तक पहुंच सकता है। (कुछ UNIX-जैसी प्रणालियों में कोई प्रतीक शामिल करने की आवश्यकता है, wchar_t देखें) 32-बिट सिस्टम पर। शोधकर्ताओं ने छोटी अनुक्रमणिका संरचनाओं को ढूंढना जारी रखा है।

समानांतर निर्माण

प्रत्यय वृक्ष निर्माण को गति देने के लिए विभिन्न समानांतर एल्गोरिदम प्रस्तावित किए गए हैं।[26][27][28][29][30] हाल ही में, प्रत्यय वृक्ष निर्माण के लिए एक व्यावहारिक समानांतर एल्गोरिदम समानांतर एल्गोरिदम (अनुक्रमिक समय) का विश्लेषण और समानांतर एल्गोरिदम का विश्लेषण विकसित किया गया है। एल्गोरिदम साझा-मेमोरी मल्टीकोर मशीनों पर अच्छी समानांतर स्केलेबिलिटी प्राप्त करता है और 40-कोर मशीन का उपयोग करके 3 मिनट से कम समय में मानव जीनोम - लगभग 3 गीगाबाइट - को अनुक्रमित कर सकता है।[31]

बाहरी निर्माण

यद्यपि रैखिक, प्रत्यय वृक्ष का मेमोरी उपयोग काफी अधिक है अनुक्रम संग्रह के वास्तविक आकार की तुलना में। एक बड़े पाठ के लिए, निर्माण के लिए बाह्य मेमोरी दृष्टिकोण की आवश्यकता हो सकती है।

बाह्य में प्रत्यय वृक्षों के निर्माण के सैद्धांतिक परिणाम हैं याद। एल्गोरिथ्म द्वारा Farach-Colton, Ferragina & Muthukrishnan (2000) सैद्धांतिक रूप से इष्टतम है, सॉर्टिंग के बराबर I/O जटिलता के साथ। हालाँकि, इस एल्गोरिथम की समग्र जटिलता ने अब तक इसे रोका है व्यावहारिक कार्यान्वयन।[32]

दूसरी ओर, निर्माण के लिए व्यावहारिक कार्य भी हुए हैं डिस्क-आधारित प्रत्यय वृक्ष जो (कुछ) जीबी/घंटे का पैमाना है। अत्याधुनिक विधियां टीडीडी हैं,[33] ट्रेलिस,[34] डिजेएसटी,[35] और बी2ST.[36] टीडीडी और ट्रेलिस पूरे मानव जीनोम तक स्केल करते हैं जिसके परिणामस्वरूप दसियों गीगाबाइट आकार का एक डिस्क-आधारित प्रत्यय वृक्ष बनता है।[33][34]हालाँकि, ये विधियाँ 3GB से अधिक अनुक्रमों के संग्रह को कुशलतापूर्वक संभाल नहीं सकती हैं।[35] DiGeST काफी बेहतर प्रदर्शन करता है और लगभग 6 घंटों में 6GB के क्रम में अनुक्रमों के संग्रह को संभालने में सक्षम है।[35]

ये सभी विधियाँ उस मामले के लिए कुशलतापूर्वक प्रत्यय वृक्षों का निर्माण कर सकती हैं जब पेड़ मुख्य मेमोरी में फ़िट नहीं होता, लेकिन इनपुट करता है. सबसे नवीनतम विधि, बी2ST,[36]संभालने के लिए तराजू ऐसे इनपुट जो मुख्य मेमोरी में फिट नहीं होते। ईआरए एक हालिया समानांतर प्रत्यय वृक्ष निर्माण विधि है जो काफी तेज़ है। ईआरए 16 जीबी रैम वाले 8-कोर डेस्कटॉप कंप्यूटर पर 19 मिनट में संपूर्ण मानव जीनोम को अनुक्रमित कर सकता है। 16 नोड्स (प्रति नोड 4 जीबी रैम) वाले एक साधारण लिनक्स क्लस्टर पर, ईआरए 9 मिनट से भी कम समय में पूरे मानव जीनोम को अनुक्रमित कर सकता है।[37]

यह भी देखें

टिप्पणियाँ

  1. Donald E. Knuth; James H. Morris; Vaughan R. Pratt (Jun 1977). "Fast Pattern Matching in Strings" (PDF). SIAM Journal on Computing. 6 (2): 323–350. doi:10.1137/0206024. Here: p.339 bottom.
  2. Knuth conjectured in 1970 that the problem could not be solved in linear time.[1] In 1973, this was refuted by Weiner's suffix-tree algorithm Weiner (1973).
  3. This term is used here to distinguish Weiner's precursor data structures from proper suffix trees as defined above and unconsidered before McCreight (1976).
  4. i.e., with each branch labelled by a single character
  5. See File:WeinerB aaaabbbbaaaabbbb.gif and File:WeinerC aaaabbbbaaaabbbb.gif for an uncompressed example tree and its compressed correspondant.
  6. Giegerich & Kurtz (1997).
  7. http://www.cs.uoi.gr/~kblekas/courses/bioinformatics/Suffix_Trees1.pdf[permanent dead link]
  8. Farach (1997).
  9. Gusfield (1999), p.92.
  10. Gusfield (1999), p.123.
  11. Baeza-Yates & Gonnet (1996).
  12. Gusfield (1999), p.132.
  13. Gusfield (1999), p.125.
  14. Gusfield (1999), p.144.
  15. Gusfield (1999), p.166.
  16. Gusfield (1999), Chapter 8.
  17. Gusfield (1999), p.196.
  18. Gusfield (1999), p.200.
  19. Gusfield (1999), p.198.
  20. Gusfield (1999), p.201.
  21. Gusfield (1999), p.204.
  22. Gusfield (1999), p.205.
  23. Gusfield (1999), pp.197–199.
  24. 24.0 24.1 Allison, L. "प्रत्यय वृक्ष". Archived from the original on 2008-10-13. Retrieved 2008-10-14.
  25. First introduced by Zamir & Etzioni (1998).
  26. Apostolico et al. (1988).
  27. Hariharan (1994).
  28. Sahinalp & Vishkin (1994).
  29. Farach & Muthukrishnan (1996).
  30. Iliopoulos & Rytter (2004).
  31. Shun & Blelloch (2014).
  32. Smyth (2003).
  33. 33.0 33.1 Tata, Hankins & Patel (2003).
  34. 34.0 34.1 Phoophakdee & Zaki (2007).
  35. 35.0 35.1 35.2 Barsky et al. (2008).
  36. 36.0 36.1 Barsky et al. (2009).
  37. Mansour et al. (2011).


संदर्भ


बाहरी संबंध