इस दस्तावेज़ में, हमने अनुवादक के लिए किसी विकल्प को लागू करने और उसकी समीक्षा करने के दिशा-निर्देशों के बारे में खास जानकारी दी है. हमने जान-बूझकर, पुष्टि करने वाले टूल और टाइप इंफ़रेंस से जुड़े कुछ सहायक ऐक्शन आइटम शामिल किए हैं. ऐसा इसलिए किया गया है, ताकि इंटरप्रिटर को लागू करने के साथ-साथ इन फ़्रंट पर भी आगे बढ़ सकें.
सेशन लागू करते समय
- पुष्टि करने और टाइप का अनुमान लगाने के तरीकों और उनसे जुड़े टेस्ट की समीक्षा करते समय, रेफ़रंस के तौर पर इस्तेमाल करने के लिए, पीआर के ब्यौरे में इस जैसी साफ़ तौर पर लिखी गई टेस्टिंग की रणनीति दें. समीक्षक इस बात की दोबारा जांच करेगा कि जानकारी में पूरी जानकारी दी गई है या नहीं.
- लागू करने से जुड़ी मुश्किल जानकारी और फ़ंक्शन के संभावित अंतर की पहचान करने के लिए, hlo_evaluator का इस्तेमाल करें.
- अगर आपको कोई गड़बड़ी मिलती है या कोई फ़ंक्शन नहीं मिलता है, तो उससे जुड़े सॉफ़्टवेयर कॉम्पोनेंट के लिए टिकट फ़ाइल करें.
ऑपरेशन लागू करने के बाद
StablehloOps.td में:
- पक्का करें कि ऑपरेटर के ओडीएस में मौजूद
summary
, स्टैंडर्ड फ़ॉर्मैट में हो. (मिलता-जुलता टिकट) ओडीएस और स्पेसिफ़िकेशन के बीच तालमेल की पहचान करने के लिए, सेशन
XyzOp
के लिएxyz_cn
याxyz_in
फ़ॉर्मैट में स्पेसिफ़िकेशन से, कंस्ट्रेंट लेबल (जैसे किCn
याIn
) के बारे में बताने वाली टिप्पणियां जोड़ें. यहां दिए गए उदाहरण में, mlirTraits
औरTypeConstraints
के साथ-साथ, टिप्पणियों के तौर पर शर्त के लेबल जोड़ने का तरीका बताया गया है. नोटxyz_c4
का मतलबStableHLO_FooOp
क्लास में तय की गई सीमाओं (जैसे किStableHLO_ShapedInterfaceOp
,StableHLO_UnaryElementwiseOp
,StableHLO_Op
वगैरह) से है.def StableHLO_XyzOp: StableHLO_FooOp<"xyz", [Trait1, Trait2 /*xyz_c1, xyz_c2*/, InferTensorType /*xyz_c3*/]> { /*xyz_c4*/ ... let summary = "Xyz operation"; let arguments = (ins 1DTensorOf<[HLO_Float]>:$a, /*xyz_c5, xyz_i1*/ HLO_Tensor:$b, /*xyz_i2*/ .... ); );
- पक्का करें कि ऑपरेटर के ओडीएस में मौजूद
TypeInference.cpp और StablehloOps.cpp में:
- "इन प्रॉपर्टी की पुष्टि करें: ..." जैसी टिप्पणियां मिटाएं.
- ऑपरेशन
XyzOp
के लिए,xyz_cn
याxyz_in
फ़ॉर्मैट में, स्पेसिफ़िकेशन केCn
याIn
जैसे, शर्त के लेबल का रेफ़रंस देने वाली टिप्पणियां जोड़ें. इससे यह पता चलता है कि पुष्टि करने वाले टूल और शेप फ़ंक्शन के कौनसे हिस्से, स्पेसिफ़िकेशन में बताई गई शर्तों से मेल खाते हैं.- एक से ज़्यादा शर्त वाले लेबल वाली टिप्पणी या एक ही शर्त वाले लेबल वाली कई टिप्पणियां हो सकती हैं. यह सब इस बात पर निर्भर करता है
कि कंस्ट्रेंट को कैसे लागू किया जाता है. अगर लगातार कंस्ट्रेंट हैं, तो उन्हें
xyz_cn...xyz_cm, xyz_in...xyz_jn
के तौर पर छोटा करें. - अगर लागू करने की प्रक्रिया और स्पेसिफ़िकेशन में दी गई पाबंदियों में कोई अंतर है, तो पक्का करें कि इस अंतर को दिखाने वाली कोई समस्या मौजूद हो.
- एक से ज़्यादा शर्त वाले लेबल वाली टिप्पणी या एक ही शर्त वाले लेबल वाली कई टिप्पणियां हो सकती हैं. यह सब इस बात पर निर्भर करता है
कि कंस्ट्रेंट को कैसे लागू किया जाता है. अगर लगातार कंस्ट्रेंट हैं, तो उन्हें
इंटरप्रेटर टेस्ट में:
<op_mnemonic>.mlir
नाम की फ़ाइल जोड़ें.- जांच के दिशा-निर्देशों का पालन करके टेस्ट लिखें.
-
- बंद किए गए ऐसे सभी टेस्ट चलाएं जो नए ऑपरेशन में शामिल हैं.
- अगर टेस्ट पास हो जाते हैं, तो
RUN-DISABLED
कोRUN
में बदलकर उन्हें चालू करें. - अगर कोई टेस्ट, सटीक मैच न होने के अलावा किसी और वजह से पूरा नहीं होता है, तो लागू करने/टेस्ट करने की प्रोसेस को ठीक करें.
- सटीक मैच न होने पर, टेस्ट को
RUN-DISABLED(#1278)
से टैग करें (अगर ऐसा पहले से नहीं किया गया है).
ops_stablehlo.mlir में:
- पक्का करें कि पुष्टि करने वाले और टाइप अनुमान लगाने वाले तरीकों में, हर पाबंदी के लिए कम से कम एक टेस्ट (पॉज़िटिव या नेगेटिव) हो. ओडीएस में शामिल पाबंदियों की जांच नहीं की जाएगी. ये जांच ज़्यादातर नेगेटिव होंगी, यानी यह जांच की जाएगी कि शर्तें पूरी नहीं हुई हैं या फिर पॉज़िटिव होंगी, यानी यह जांच की जाएगी कि अनुमानित आकार सही है.
- पक्का करें कि टेस्ट किए जा रहे ऑपरेशन से जुड़े सभी टेस्ट एक साथ रखे गए हों.
- पक्का करें कि टेस्ट किए जा रहे ऑपरेशन से जुड़े सभी टेस्ट के शुरू में,
CHECK-LABEL
lit मैक्रो हो. - ऑपरेशन
XyzOp
के लिए, फ़ंक्शन की जांच से जुड़ी पाबंदियोंCn
,Im
वगैरह के लिए,xyz_cn_im_...
फ़ॉर्मैट का इस्तेमाल करके, जांच के फ़ंक्शन का नाम चुनें. अगर सुझाया गया फ़ॉर्मैट लागू नहीं होता है, तो मौजूदा नाम रखें. - ऊपर दिया गया चरण पूरा करने के बाद, जांच के दायरे में आने वाले ऑपरेशन से जुड़े सभी टेस्ट को, फ़ंक्शन के नाम के हिसाब से, वर्णमाला के क्रम में क्रम से लगाएं.
- जब तक ccov, ऑपरेशन के लिए 90% से ज़्यादा कवरेज न दिखाए, तब तक टेस्ट जोड़ते रहें.
infer_stablehlo.mlir में:
- पक्का करें कि आकार के अनुमान की जांच से जुड़े सभी कंस्ट्रेंट इस फ़ाइल में मौजूद हैं. इसके लिए, नाम रखने से जुड़े उन दिशा-निर्देशों का पालन करें जो ऊपर बताए गए हैं.
- ops_stablehlo.mlir फ़ाइल से, आकार के अनुमान के किसी भी टेस्ट को इस फ़ाइल में ले जाएं.
spec.md में:
stablehlo/tests/interpret/<op_mnemonic>.mlir
का लिंक, "उदाहरण" सेक्शन में जोड़ें. उदाहरण के लिए, ज़्यादा उदाहरण.- पक्का करें कि स्पेसिफ़िकेशन में सिर्फ़ एक उदाहरण हो.
- पक्का करें कि शर्त का उदाहरण, जांच के दिशा-निर्देशों का पालन करता हो.
- पक्का करें कि 'खास निर्देश' के उदाहरण की जांच के नतीजे समझ में आने लायक हों.
- पक्का करें कि स्पेसिफ़िकेशन का उदाहरण, ओडीएस में मौजूद उदाहरण जैसा ही हो.
status.md में:
- "इंटरप्रेटर" कॉलम को
yes
पर अपडेट करें.
- "इंटरप्रेटर" कॉलम को