در این سند، دستورالعملهای بررسی تغییرات در مشخصات را خلاصه میکنیم. در حال حاضر، این تغییرات معمولاً شامل بررسی چندین چیز در چندین منبع است، بنابراین این سند همه آنها را برای ساده کردن بررسی ها خلاصه می کند:
- بررسی کنید که ستون "Specification" در status.md "بله" باشد، در صورت اضافه کردن یک عملیات جدید، یک ردیف اضافه کنید.
- بررسی کنید که آیا عنوان بخش با یادداشت عملیات در ODS مطابقت دارد یا خیر.
- بررسی کنید که آیا بخش "Semantics" با عملیات Semantics XLA مطابقت دارد یا خیر.
- بررسی کنید که آیا بخشهای «ورودیها» و «خروجیها»:
- موارد مشابه ODS را فهرست کنید.
- موارد مشابه HloInstruction::CreateFromProto را فهرست کنید.
- دقیقاً مانند ODS سفارش داده می شوند.
- اگر ناهماهنگی وجود دارد، بررسی کنید که بلیط های مربوطه وجود دارد.
- بررسی کنید که آیا بخش "محدودیت ها" است:
- با XLA's shape_inference.cc مطابقت دارد.
- با hlo_verifier.cc XLA مطابقت دارد.
- با ODS مطابقت دارد.
- با StablehloOps.cpp مطابقت دارد.
- اگر ناهماهنگی وجود دارد، بررسی کنید که بلیط های مربوطه وجود دارد. همه آن بلیتهای موجود در مشخصات را در مکانهایی که تا حد امکان خاص هستند پیوند دهید (مثلاً اگر بلیط مربوط به محدودیتی است که اجرا نشده است، بلیط را درست در آن محدودیت پیوند دهید).
- اگر قسمتهای مربوط به ODS و StablehloOps.cpp با مشخصات مطابقت دارند، بررسی کنید که ستونهای «Verification» و «Type Inference» در status.md «بله» باشند.
- بررسی کنید که آیا بخش "مثال":
- فقط یک مثال دارد (در آینده، ما به نمونه های بیشتری از مجموعه تست مترجم StableHLO پیوند خواهیم داد).
- با اجرای
stablehlo-opt
روی نمونههای کد، از نحو معتبر MLIR استفاده میکند. - از نحو عمومی MLIR استفاده میکند که میتوان با اجرای
stablehlo-opt -mlir-print-op-generic
به دست آورد (ما به نحو عمومی در مشخصات پایبند هستیم تا از تغییر مشخصات در تغییرات زیبایی چاپگر جلوگیری کنیم).
- بررسی کنید که
description
در ODS عملیات:- شامل جمله اول مشخصات است.
- سپس به بخش مربوطه از مشخصات پیوند دهید.
- سپس از همان مثال به عنوان مشخصات استفاده می کند، اما از طریق نحو زیبا که می توان با اجرای
stablehlo-opt
به دست آورد.
- بررسی کنید که فایلهای مربوط به اجرای محدودیتهای تایید و استنتاج نوع از دستورالعملهای ذکر شده در زیر پیروی میکنند:
- دستورالعمل شماره 1 را برای StablehloOps.td دنبال کنید.
- دستورالعمل شماره 2 را برای TypeInference.cpp و StablehloOps.cpp دنبال کنید.
- دستورالعمل شماره 5 را برای ops_stablehlo.mlir دنبال کنید.
- دستورالعمل شماره 6 را برای infer_stablehlo.mlir دنبال کنید.
- این عملیات را از نظر عوارض جانبی و قابلیت حدس و گمان ارزیابی کنید.
- اگر عملیات هیچ عوارض جانبی ندارد و همیشه قابل حدس و گمان است، صفت
Pure
را به آن بدهید. این به ندرت اتفاق میافتد، زیرا اکثر عملیاتها اشکال پویا را مجاز میکنند، که ممکن است منجر به عدم تطابق شکل در زمان اجرا شود، که رفتاری تعریفنشده است. برخی از عملیات ها می توانند در موقعیت های دیگر نیز رفتار نامشخصی داشته باشند. اکثریت قریب به اتفاق عملیات ها عوارض جانبی ندارند (آنها باید ویژگیNoMemoryEffect
را داشته باشند). - اکثر عملیاتها در یکی از ویژگیهای
HLO_SpeculatableIf*
قرار میگیرند. اگر عملیات در هیچ یک از آنها قرار نمیگیرد، ویژگیConditionallySpeculatable
را به آن بدهید و متدهای واسط را اجرا کنید. برای پوشش منطق حدس و گمان، تست ها را بهstablehlo/tests/ops_speculatability.mlir
اضافه کنید.
- اگر عملیات هیچ عوارض جانبی ندارد و همیشه قابل حدس و گمان است، صفت