مکمل دو
این مقاله نیازمند ویکیسازی است. لطفاً با توجه به راهنمای ویرایش و شیوهنامه، محتوای آن را بهبود بخشید. |
مکملدو یا متمم دو، در رایانههای دیجیتال برای ساده کردن عمل تفریق و سایر عملیات منطقی به کار میروند. از این روش برای نمایش و کار با اعداد علامتدار (اعداد منفی و اعداد مثبت) استفاده میگردد. مکملدو روش موفقی برای اینکار است چرا که سادهترین روش برای مدارات الکتریکی است تا یک عدد علامتدار را محاسبه نمایند. هرچند در گذشته روشهای دیگری مانند مکملیک استفاده میگردید، اما رایانههای امروزی از روش مکملدو استفاده میکنند.
در هر مبنایی مثل r، دو نوع متمم وجود دارد. یکی متمم مبنا و دیگری متمم مبنای کاهش یافته. در مبنای دو یا همان دستگاه اعداد دودویی نیز، دو نوع متمم وجود دارد. یکی متمم دوم یا همان متمم مبنا و دیگری متمم اول یا همان متمم مبنای کاهش یافته.
مکمل دو یک عدد k بیتی مانند n برابر است با
مکمل دو و عملیات های ریاضی
[ویرایش]مدار هایی که عملیات های ریاضی جمع و ضرب اعداد k بیتی را انجام می دهند، عموما این کار را به پیمانه انجام می دهند. یعنی اگر مثلا مداری دارید که اعداد ۴ بیتی را جمع می زند، و به آن و را ورودی دهید، آن مدار به شما را تحویل می دهد.
اگر این خاصیت را کنار این خاصیت مکمل دو بگذاریم که "مکمل دو هر عدد با منفی آن عدد به پیمانه همنهشت است"، می توانیم در عملیات های ریاضی به جای منفی اعداد، از مکمل دو آن ها استفاده کنیم.
مثال
[ویرایش]فرض کنید با دستگاه های ۴ بیتی کار می کنیم.
مکمل دو عدد ۳، برابر است.
جمع ۵ با منفی ۳ یا همان ۵ منهای ۳، برابر است.
ضرب 2 در منفی ۳ با دستگاه های ۴ بیتی، برابر است که ۱۰ طبق تعریف، مکمل دو عدد 6 یا همان منفی 6 است.
شیوههای یافتن مکمل اول و مکمل دوم
[ویرایش]در دستگاه اعداد دودویی پیدا کردن مکمل یک اعداد بسیار سادهاست. کافیست به جای صفرها، یک، و به جای یکها صفر قرار دهید.
مثال یک
متمم اول عدد (۱۰۱۱۰۰۰)۲ برابر است با (۰۱۰۰۱۱۱)۲
مثال دو
متمم اول عدد (۰۱۰۱۱۰۱)۲ برابر است با (۱۰۱۰۰۱۰)۲
مثال سه
همانطور که میبینید در این مثال با رها کردن دو صفر کم ارزشتر و اولین ۱ و سپس جایگزینی همهٔ ۱ها با ۰ها و همهٔ ۰ها با ۱ها در چهار رقم باارزشتر باقیمانده ، یا با با معکوس کردن (تغییر یک به صفر، و بلعکس) و جمع کردن عدد یک با عدد معکوس شده، مکمل دوم آن بدست میآید.
متمم دوم عدد (۱۱۰۱۱۰۰)۲ برابر است ب ا (۰۰۱۰۱۰۰)۲
مثال چهار
متمم دوم عدد (۰۱۱۰۱۱۱)۲ برابر است با (۱۰۰۱۰۰۱)۲
منابع
[ویرایش]- کتاب طراحی دیجیتال (مدار منطقی)، تألیف موریس مانو، سال ۱۹۲۷ - فصل اول بخش ۱-۵