شیفت رجیستر (Shift Register)، نوع دیگری از مدار منطقی ترتیبی ‌‌می‌باشد که از آن ‌‌می‌توان برای ذخیره یا انتقال داده‌های باینری استفاده شود.

این المان، داده را روی ورودی‌هایش بارگزاری میکند و سپس آن‌ها را با اعمال هر پالس کلاک به خروجی‌هایش شیفت ‌‌می‌دهد. بنابراین از آن به عنوان شیفت رجیستر یا ثبات شیفت یاد ‌‌می‌شود.

یک شیفت رجیستر شامل تعداد زیادی قفل داده نوع D تک بیتی است که به یکدیگر به صورت سری daisy chain متصل شده‌‌اند تا خروجی یک لچ داده، ورودی لچ بعدی شود.

بیت‌های داده ‌‌می‌توانند به صورت سریال از ثبات خارج یا به آن وارد شوند. بیت‌ها به ترتیب از چپ یا از راست از ثبات عبور ‌‌می‌کنند. اما در پیکربندی موازی ‌‌می‌توان همه داده‌ها را به صورت یکجا از ثبات عبور داد.

تعداد لچ‌های داده ای که برای ساخت یک شیفت رجیستر نیاز است، توسط تعداد بیت‌هایی که باید ذخیره شوند تعیین ‌‌می‌شود که در اکثر مواقع ۸ بیت (یک بایت) ‌‌می‌باشد. که از ۸ لچ داده ساخته ‌‌می‌شوند.

از ثبات‌های شیفت برای ذخیره داده یا حرکت داده استفاده ‌‌می‌شود. بنابراین از آن‌ها به وفور در ساخت ماشین حساب‌ها یا کامپیوترها استفاده ‌‌می‌شود تا داده‌هایی مانند اعداد باینری پیش از جمع شدن با یکدیگر در ثبات ذخیره شوند یا برای تبدیل داده از سریال به موازی یا برعکس از ثبات‌های شیفت استفاده ‌‌می‌شود. همچنین برخی از لچ‌های داده وجود دارند که ‌‌می‌توانند یک شیفت رجیستر را به وجود بیاورند و از آن جایی که این قفل‌های داده با پالس کلاک (Clk) یکسانی راه‌‌اندازی ‌‌می‌شوند، المان‌هایی سنکرون ‌‌می‌باشند.

IC شیفت رجیسترها معمولا دارای پایه ی Clear یا Reset هستند تا بتوانند در زمان‌های مقتضی Set یا Reset شوند. به طور کلی، شیفت رجیسترها در یکی از 4 حالتی که در زیر ذکر شده قرار دارند:

  • ورودی سریال – خروجی موازی (SIPO) (Serial-in to Parallel-out):

در این حالت داده‌های سریال روی ثبات بارگزاری ‌‌می‌شوند و داده‌های ذخیره شده در خروجی به صورت موازی ظاهر ‌‌می‌گردند.

  • ورودی سریال- خروجی سریال (SISO) (Serial-in to Serial-out):

دیتا به صورت سریال وارد یا خارج ‌‌می‌شود (یک بیت در هر لحظه) از جهت راست یا چپ به ازای هر کلاک یک بیت داده از ثبات عبور می‌کند.

  • ورودی موازی – خروجی سریال (PISO) (Parallel-in to Serial-out):

داده‌های موازی در ثبات به صورت همزمان بارگزاری ‌‌می‌شوند. اما به صورت تک به تک (سریال) و به ازای هر پالس کلاک روی خروجی نمایان ‌‌می‌شوند.

  • ورودی موازی – خروجی موازی (PIPO) (Parallel-in to Parallel-out)

داده‌های موازی به صورت همزمان در ثبات بارگزاری ‌‌می‌شوند و همگی با اعمال پالس کلاک به خروجی‌های متناظرشان هدایت ‌‌می‌شوند.

انتقال داده از چپ به راست در یک شیفت رجیستر ‌‌می‌تواند به صورت زیر نشان داده شود:

انتقال داده در شیفت رجیسترانتقال داده در شیفت رجیستر

همچنین جهت حرکت داده در یک شیفت رجیستر ‌‌می‌تواند به سمت چپ (شیفت چپ) یا به سمت راست (شیفت راست) باشد. با این وجود، ثبات‌های شیفتی نیز وجود دارند که در دو جهت انتقال داده را انجام ‌‌می‌دهند. در این مقاله این طور فرض خواهد شد که تمام انتقال داده‌ها به سمت راست (شیفت راست) ‌‌می‌باشد.

شیفت رجیستر ورودی سریال - خروجی موازی (SIPO)

شیفت رجیستر 4 بیتی ورودی سریال – خروجی موازیشیفت رجیستر 4 بیتی SIPO

حال فرض کنید که تمام فلیپ فلاپ‌ها (FFA تا FFD ) به تازگی از طریق ورودی Clear ریست شده‌‌اند و تمام خروجی‌ها (QA تا QD) در سطح منطقی صفر ‌‌می‌باشد و هیچ خروجی موازی داده ای وجود ندارد.

اگر پین وضعیت ورودی FFA یک شود، با اعمال اولین پالس کلاک خروجی FFA (QA) به سطح منطقی یک ‌‌می‌رود. در حالیکه دیگر خروجی‌ها هنوز در سطح منطقی صفر ‌‌می‌باشند. حال فرض کنید که پین ورودی FFA دوباره به سطح پایین و به منطق صفر برگشته و یک پالس داده به صورت 0-1-0 داریم.

دومین پالس کلاک خروجی FFA را به منطق صفر ‌‌می‌برد و خروجی FFB و QB به منطق یک ‌‌می‌روند چرا که ورودی D دارای سطح منطقی یک ‌‌می‌باشد. حال منطق یک، یک مرحله در ثبات به سمت راست شیفت داشته‌است.

هنگا‌‌می‌که سومین پالس کلاک فرا‌‌می‌رسد، مقدار منطق یک به خروجی FFC (QC) شیفت پیدا میکند و در پالس کلاک پنجم تمام خروجی‌ها (از QA به QD) دوباره به سطح منطقی صفر باز‌‌می‌گردند.

هر کلاک، داده را یک مرحله به سمت راست شیفت ‌‌می‌دهد تا زمانی که کل بیت‌های داده در ثبات بارگزاری شوند. حال این مقادیر داده ‌‌می‌تواند به صورت مستقیم از خروجی QA تاQD خوانده شوند. سپس داده‌ها از یک سیگنال ورودی سریال به یک خروجی داده موازی تبدیل ‌‌می‌شوند. جدول ارزشی و موج‌های به وجود آمده، شیفت منطق یک را در رجیستر از چپ به راست نشان ‌‌می‌دهد.

انتقال دیتا با شیفت رجیستر

شماره پالس کلاک

QA

QB

QC

QD

۰
۰
۰
۰
۰
۱
۱
۰
۰
۰
۲
۰
۱
۰
۰
۳
۰
۰
۱
۰
۴
۰
۰
۰
۱
۵
۰
۰
۰
۰

به یاد داشته باشید که پس از اعمال چهارمین پالس کلاک، 4 بیت داده (1-0-0-0) در ثبات ذخیره شده و این اطلاعات تا زمانی که کلاک ثبات متوقف شده باشد، در آن باقی ‌‌می‌ماند. در عمل داده‌های ورودی ممکن است شامل ترکیبی از منطق یک و صفر باشند. IC‌های SIPO رایج شامل 74LS168 8 بیتی یا 74LS594 ‌‌می‌باشند.

شیفت رجیستر ورودی سریال – خروجی سریال (SISO)

این شیفت رجیستر شباهت زیادی به ثبات SIPO دارد و تنها تفاوت آن این است که به جای خواندن همزمان داده از QA تا QD ، اطلاعات را به صورت تکی ‌‌می‌خواند. چرا که تنها یک خروجی در ثبات موجود است. بنابراین داده بیت به بیت (سریال) از ثبات خارج ‌‌می‌شود و به همین دلیل این ثبات را شیفت رجیستر ورودی سریال – خروجی سریال نام گذاری کرده‌‌اند.

شیفت رجیستر SISO ساده ترین پیکربندی را در بین ثبات‌های شیفت دارد. چرا که تنها دارای 3 پایه است: یک ورودی سریال (SI) که مشخص ‌‌می‌کند چه اطلاعاتی به سمت چپ فلیپ فلاپ وارد شود، یک خروجی سریال (SO) که از خروجی فلیپ فلاپ سمت راست گرفته ‌‌می‌شود و یک سیگنال کلاک (Clk). دیاگرا‌‌می‌که در شکل نشان داده شده، طرحی کلی از شیفت رجیستر ورودی سریال- خروجی سریال را نشان ‌‌می‌دهد.

شیفت رجیستر SISO چهار بیتیشیفت رجیستر SISO چهار بیتی

شاید بگویید فایده شیفت رجیستر SISO چیست؟ اگر قرار باشد خروجی داده دقیقا شبیه به ورودی آن باشد. در جواب باید گفت که این شیفت رجیستر شبیه به یک المان ذخیره داده عمل می‌کند یا ‌‌می‌تواند به عنوان یک المان تاخیری برای ارسال داده مورد استفاده قرار بگیرد و میزان تاخیر در ارسال داده توسط مراحل ثبات (4،8،16 و…) یا زمانبندی اعمال پالس کلاک تعیین ‌‌می‌شود. یکی از IC‌های SISO رایج، 74HC595 8 بیتی ‌‌می‌باشد که دارای 3 مرحله خروجی است.

شیفت رجیستر ورودی موازی – خروجی سریال PISO

این ثبات بر عکس ثبات ورودی سریال – خروجی موازی عمل ‌‌می‌کند. داده‌ها در ثبات به صورت موازی بارگزاری ‌‌می‌شوند. ( تمام داده‌ها به صورت همزمان توسط ثبات دریافت ‌‌می‌شوند) و روی پایه‌های ورودی PA تا PD ‌‌می‌افتند. سپس از سمت راست تک به تک و با اعامل هر کلاک، به خروجی Q ارسال ‌‌می‌شوند.

فراموش نکنید که این نوع شیفت رجیستر به هیچ پالس کلاکی برای ورودی نیاز ندارد. چرا که تمام داده‌ها به صورت همزمان بارگزاری ‌‌می‌شوند. اما به ۴ کلاک برای ارسال خروجی نیاز ‌‌می‌باشد.

شیفت رجیستر 4 بیتی PISOشیفت رجیستر 4 بیتی PISO

این نوع شیفت رجیستر، داده‌های موازی را به صورت سریال در‌‌می‌آورد و از آن ‌‌می‌توان برای ادغام خطوط ورودی مختلف و تبدیل آن‌ها به یک جریان تکی داده‌های سریال استفاده کرد تا از طریق خطوط انتقال داده به کامپیوتر و دیگر دستگاه‌ها ارسال شوند.

IC  هشت بیتی 74HC166 رایج ترین شیفت رجیستر ورودی موازی – خروجی سریال است.

شیفت رجیستر ورودی موازی – خروجی موازی PIPO

آخرین پیکربندی ثبات‌های شیفت، ثبات ورودی موازی – خروجی موازی ‌‌می‌باشد. این نوع شیفت رجیستر، همانند یک دستگاه حافظه موقف عمل می‌کند یا ‌‌می‌توان از آن به عنوان یک المان برای ایجاد تاخیر زمانی استفاده کرد. در این ثبات، داده در فرمت موازی روی پایه‌های ورودی PA تا PD بارگزاری ‌‌می‌شود و سپس با اعمال پالس کلاک همزمان به خروجی‌های منتاظر QA تا QD  ارسال ‌‌می‌شود. در واقع، ثبات برای بارگزاری اطلاعات یا ارسال آن تنها به یک پالس کلاک نیاز دارد. این پیکربندی در شکل زیر نشان داده شده‌است:

شیفت رجیستر 4 بیتی PIPOشیفت رجیستر 4 بیتی PIPO

شیفت رجیستر PIPO همانند SISO ساختار بسیار ساده‌ای دارد چرا که تنها دارای 3 اتصال ‌‌می‌باشد: (PI) که مشخص ‌‌می‌کند چه اطلاعاتی وارد فلیپ فلاپ شود، (PO) برای خروجی فلیپ فلاپ و پایه پالس کلاک (CLK).

همانند شیفت رجیستر، ورودی سریال – خروجی سریال از این ثبات برای ذخیره موقت داده یا ایجاد تاخیر در ارسال داده استفاده ‌‌می‌شود که میزان تاخیر توسط فرکانس پالس‌های کلاک مشخص ‌‌می‌شود. همچنین در این صورت، از ثبات هیچ اتصال داخلی بین فلیپ فلاپ‌های مختلف وجود ندارد چرا که به شیفت سریال داده نیازی نیست.

شیفت رجیستر یونیورسال

امروزه، مدارهای مجتمع شیفت رجیستر گوناگونی در دسترس ‌‌می‌باشد. مانند TTL74LS194، 74LS195 یا CMOS 4055 که به صورت المان‌های چند کاره‌ی 4 بیتی در دسترس ‌‌می‌باشند که ‌‌می‌توان از آن‌ها برای انتقال داده سریال به سریال، شیفت از سمت چپ و راست، سریال به موازی، موازی به سریال یا موازی به موازی بهره برد و به همین دلیل است که به این نوع المان‌ها، المان‌های همگانی یا یورنیورسال ‌‌می‌گویند.

ثبات‌های شیفت همگانی ‌‌می‌توانند ترکیب‌ها و پیکربندی‌های متفاوتی داشته باشند. اما به ورودی‌های بیشتری برای تعیین علمکرد دلخواه و ریست شدن نیاز دارند. یکی از ثبات‌های شیفت همگانی پرکاربرد، قطعه ی TTL 74LS194 ‌‌می‌باشد که در شکل زیر نشان داده شده:

شیفت رجیستر 4 بیتی همگانی 74LS194شیفت رجیستر 4 بیتی همگانی 74LS194

شیفت رجیسترهای یونیورسال یا همگانی، المان‌های دیجیتال پرکاربردی هستند. آن‌ها ‌‌می‌توانند به صورتی پیکربندی شوند که به عنوان حافظه موقت یا المان تاخیر مورد استفاده قرار بگیرند یا ‌‌می‌توان از آن‌ها برای انتقال اطلاعات از یک نقطه به نقطه دیگر در فرمت موازی یا سریال استفاده نمود. ثبات‌های شیفت همگانی به صورت مداوم در عملگر‌های ریاضی مورد استفاده قرار ‌‌می‌گیرند تا برای ضرب یا تقسیم داده را به سمت راست یا چپ شیفت بدهند.

خلاصه شیفت رجیسترها

  • یک شیفت رجیستر ساده ‌‌می‌تواند با استفاده از فلیپ فلاپ‌های نوع D ساخته شود. گفتنی است یک فلیپ فلاپ تنها ‌‌می‌تواند یک بیت از داده را نگه دارد.
  • خروجی از هر فلیپ فلاپ به ورودی D فلیپ فلاپ سمت راستش متصل ‌‌می‌شود.
  • شیفت رجیسترها داده را در حافظه شان نگه ‌‌می‌دارند تا با اعمال هر پالس کلاک به موقعیت دلخواه شیفت پیدا کند. هر پالس کلاک، محتویات ثبات را یک بیت به سمت چپ یا راست شیفت ‌‌می‌دهد.
  • بیت‌های داده ‌‌می‌توانند به صورت سری (یک بیت در هر لحظه) (SI) (Serial Input) یا به صورت موازی (همزمان) (PI) (Parallel Input) در ثبات بارگزاری شوند.
  • داده ‌‌می‌تواند به صورت بیت به بیت (سریال) به خروجی ارسال شود. (SO) (Serial Output) یا به صورت همزمان (موازی) (PO) (Parallel Output).
  • یکی از کاربردهای شیفت رجیستر، تبدیل داده از فرمت سری به فرمت موازی و بر عکس ‌‌می‌باشد.
  • ثبات‌های شیفت به 4 گروه SIPO، SISO، PISO وPIPO تقسیم ‌‌می‌شوند.
  • همچنین ثبات‌های شیفت همگانی وجود دارند که هر ۴ نوع ثبات را درون خود مجتمع کرده‌‌اند.

در مقاله‌ی بعدی بخش مدارات منطقی ترتیبی خواهیم دید اگر خروجی آخرین فلیپ فلاپ به صورت مستقیم به ورودی اولین فلیپ فلاپ متصل شود چه اتفاقی خواهد افتاد. به طور خلاصه، در این شرایط، یک مدار حلقه بسته به وجود ‌‌می‌آید که داده به صورت مداوم در آن گردش ‌‌می‌کند و در این حالت نوع دیگری از مدارات منطقی ترتیبی به نام شمارنده حلقه به وجود خواهد آمد که از آن در شمارنده‌های ده دهی و درایورها استفاده ‌‌می‌شود.