इस दस्तावेज़ में, हमने किसी खास जानकारी में किए गए बदलावों की समीक्षा करने के दिशा-निर्देशों के बारे में बताया है. फ़िलहाल, इन बदलावों में आम तौर पर कई स्रोतों में कई चीज़ों की जांच करना शामिल है. इसलिए, इस दस्तावेज़ में उन सभी चीज़ों की खास जानकारी दी गई है, ताकि समीक्षा को आसान बनाया जा सके:
- देखें कि 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*एट्रिब्यूट में से किसी एक के तहत आते हैं. अगर ऑप इनमें से किसी भी काम के नहीं है, तो उसेConditionallySpeculatabletrait दें और इंटरफ़ेस के तरीके लागू करें. अनुमान लगाने की क्षमता के लॉजिक को कवर करने के लिए,stablehlo/tests/ops_speculatability.mlirमें टेस्ट जोड़ें.
- अगर ऑप से कोई खराब असर नहीं पड़ता और हमेशा अनुमान लगाया जा सकता है, तो उसे