برای پیاده سازی این سوال، ابتدا باید W و W را به صورت پارامتر تعریف کرد. سپس ورودیها read, write, clk, reset, dataout, full, empty و خروجیها که نطقه ورودی میباشد و buffer که نشان دهنده بافر و دادههای آن میباشد تعریف تعریف میشوند. سپس سیگنال buffer که نشان دهنده بافر و دادههای آدیم تا در هر لبه میشود. همچنین نیاز به سیگنالهای index, next\_index, next\_dataout داریم تا در هر لبه بالارونده کلاک دادهها آیدیت شوند.

ابتدا یک بلاک always تعریف می شود که حساس به لبه پایین رونده کلاک می باشد و ایندکس و داده خروجی را 0 می کند و بافر را خالی می کند.

سپس یک بلاک always که حساس به لبه بالارونده کلاک میباشد تعریف میشود که در آن یوینتر نوشتن بافر (ایندکس) و داده خروجی آپدیت میشوند.

برای قسمت مدار ترکیبی، یک بلاک always تعریف می شود که با توجه به شرطهای داده شده در سوال، دادهها write یا read می شوند (الگوریتم خواندن و نوشتن به صورت FIFO می باشد). برای این سوال، فایل تست نیز نوشته شده است که در آن ظرفیت بافر 11 داده 8 بیتی می باشد و در آن 12 داده ریخته می شود ولی داده آخر داخل بافر نمی رود (چون full flag برابر 1 می باشد). باشد).