इस दस्तावेज़ में, हमने किसी खास जानकारी में किए गए बदलावों की समीक्षा करने के दिशा-निर्देशों के बारे में बताया है. फ़िलहाल, इन बदलावों में आम तौर पर कई स्रोतों में कई चीज़ों की जांच करना शामिल है. इसलिए, इस दस्तावेज़ में उन सभी चीज़ों की खास जानकारी दी गई है, ताकि समीक्षा को आसान बनाया जा सके:
- देखें कि status.md में "खास जानकारी" कॉलम में "हां" लिखा है या नहीं. अगर नया विकल्प जोड़ा जा रहा है, तो एक लाइन जोड़ें.
- देखें कि सेक्शन का टाइटल, ODS में ऑपरेटर के याददाश्त से मिलता-जुलता है या नहीं.
- देखें कि "सीमेंटिक्स" सेक्शन, XLA के ऑपरेशन सेमैंटिक्स से मेल खाता है या नहीं.
- देखें कि क्या "इनपुट" और "आउटपुट" सेक्शन दिख रहे हैं:
- ओडीएस वाले आइटम की सूची बनाएं.
- उन आइटम की सूची बनाएं जो HloInstruction::CreateFromProto जैसे हैं.
- ओडीएस की तरह ही व्यवस्थित किए जाते हैं.
- अगर कुछ मेल नहीं खाता है, तो देखें कि उससे जुड़े टिकट मौजूद हैं.
- देखें कि "सीमाएं" सेक्शन:
- XLA की shape_inference.cc से मेल खाता है.
- यह XLA की hlo_verifier.cc से मेल खाता है.
- ODS से मैच करता है.
- StablehloOps.cpp से मेल खाता हो.
- अगर कुछ मेल नहीं खाता है, तो देखें कि उससे जुड़े टिकट मौजूद हैं. उन सभी टिकटों को स्पेसिफ़िकेशन में उन जगहों से लिंक करें जहां ज़्यादा से ज़्यादा जानकारी दी गई हो. उदाहरण के लिए, अगर कोई टिकट किसी ऐसी सीमा के बारे में है जिसे लागू नहीं किया गया है, तो टिकट को कंस्ट्रेंट में सीधे लिंक करें.
- अगर ODS और StablehloOps.cpp के संबंधित हिस्से, स्पेसिफ़िकेशन से मेल खाते हैं, तो देखें कि status.md में, "पुष्टि" और "टाइप अनुमान" कॉलम में "हां" लिखा हो.
- देखें कि क्या "उदाहरण" सेक्शन:
- सिर्फ़ एक उदाहरण है. (आने वाले समय में, हम StableHLO अनुवादक टेस्ट सुइट के और उदाहरणों के लिंक देंगे).
- कोड उदाहरणों पर
stablehlo-opt
चलाकर, मान्य MLIR सिंटैक्स का इस्तेमाल किया जाता है. - सामान्य MLIR सिंटैक्स का इस्तेमाल किया जाता है, जिसे
stablehlo-opt -mlir-print-op-generic
चलाकर हासिल किया जा सकता है. प्रिटीप्रिंटर बदलावों से जुड़ी खास जानकारी को बदलने से बचने के लिए, हम स्पेसिफ़िकेशन में सामान्य सिंटैक्स का इस्तेमाल करते हैं.
- देखें कि ऑपरेटर के ODS में
description
:- इसमें स्पेसिफ़िकेशन का पहला वाक्य शामिल है.
- इसके बाद, खास जानकारी से जुड़े सेक्शन से लिंक करता है.
- इसके बाद, उसी उदाहरण का इस्तेमाल करता है जैसा खास जानकारी के लिए किया जाता है. हालांकि, अच्छे सिंटैक्स के ज़रिए इसे
stablehlo-opt
चलाकर हासिल किया जा सकता है.
- पक्का करें कि पुष्टि करने और टाइप अनुमान से जुड़ी पाबंदियों से जुड़ी फ़ाइलें, इन दिशा-निर्देशों का पालन करती हों:
- StablehloOps.td के लिए, #1 दिशा-निर्देश का पालन करें.
- TypeInference.cpp और StablehloOps.cpp के लिए, दिशा-निर्देश #2 का पालन करें.
- ops_stablehlo.mlir के लिए दिए गए दिशा-निर्देश #5 का पालन करें.
- infer_stablehlo.mlir के लिए दिए गए दिशा-निर्देश #6 का पालन करें.
- साइड इफ़ेक्ट और अनुमान लगाने की क्षमता के लिए, राय का आकलन करें.
- अगर ऑप से कोई खराब असर नहीं पड़ता और हमेशा अनुमान लगाया जा सकता है, तो उसे
Pure
एट्रिब्यूट दें. ऐसा बहुत कम होता है, क्योंकि ज़्यादातर ऑपरेशन डाइनैमिक आकार की अनुमति देते हैं. इस वजह से रनटाइम के दौरान, डेटा में अंतर दिख सकता है. इसके व्यवहार की कोई जानकारी नहीं होती. कुछ ऑपरेशन से दूसरी स्थितियों में भी ऐसा व्यवहार हो सकता है जिसकी जानकारी नहीं हो. ज़्यादातर ऑपरेशन का कोई खराब असर नहीं होता (उनमेंNoMemoryEffect
एट्रिब्यूट होना चाहिए). - ज़्यादातर ऑपरेशन
HLO_SpeculatableIf*
एट्रिब्यूट में से किसी एक के तहत आते हैं. अगर ऑप इनमें से किसी भी काम के नहीं है, तो उसेConditionallySpeculatable
trait दें और इंटरफ़ेस के तरीके लागू करें. अनुमान लगाने की क्षमता के लॉजिक को कवर करने के लिए,stablehlo/tests/ops_speculatability.mlir
में टेस्ट जोड़ें.
- अगर ऑप से कोई खराब असर नहीं पड़ता और हमेशा अनुमान लगाया जा सकता है, तो उसे