इस दस्तावेज़ में, हमने अनुवादक के लिए किसी विकल्प को लागू करने और उसकी समीक्षा करने के दिशा-निर्देशों के बारे में खास जानकारी दी है. हमने जान-बूझकर, पुष्टि करने वाले टूल और टाइप इंफ़रेंस से जुड़े कुछ सहायक ऐक्शन आइटम शामिल किए हैं. ऐसा इसलिए किया गया है, ताकि इंटरप्रिटर को लागू करने के साथ-साथ इन फ़्रंट पर भी आगे बढ़ सकें.
सेशन लागू करते समय
- पुष्टि करने और टाइप का अनुमान लगाने के तरीकों और उनसे जुड़े टेस्ट की समीक्षा करते समय, रेफ़रंस के तौर पर इस्तेमाल करने के लिए, पीआर के ब्यौरे में इस जैसी साफ़ तौर पर लिखी गई टेस्टिंग की रणनीति दें. समीक्षक इस बात की दोबारा जांच करेगा कि जानकारी में पूरी जानकारी दी गई है या नहीं.
- लागू करने से जुड़ी मुश्किल जानकारी और फ़ंक्शन के संभावित अंतर की पहचान करने के लिए, 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-LABELlit मैक्रो हो. - ऑपरेशन
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पर अपडेट करें.
- "इंटरप्रेटर" कॉलम को