реклама на сайте
подробности

 
 
> 12-и разрядный двоично-десятичный сумматор
Skaf
сообщение Dec 12 2010, 07:38
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 228
Регистрация: 4-06-09
Пользователь №: 49 940



Всем привет.

В институте дали дополнительное задание- разработать 12-и разрядный двоично-десятичный сумматор. Имеется в виду используя базовые логические элементы.

Ну обычный сумматор делается проще всего на искл. или + и. А в десятичным что, контролировать появление 1010 на четырех битах?

Про схему ускоренного переноса ничего в задании не сказано. Но наверное тоже можно ее применить, хуже не будет.

Кто ни будь знает где можно посмотреть на схему двоично-десятичного сумматора? Хотя бы схемотично.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
XVR
сообщение Dec 13 2010, 09:12
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 123
Регистрация: 7-04-07
Из: Химки
Пользователь №: 26 847



Решение 'в лоб': Делается ячейка 10тичного сумматора из 4х битного двоичного сумматора и схемы коррекции. Схему рисовать не чем, но на Verilog'е это будет так:
Код
module sum10(input [3:0] A, input [3:0] B, input carry_in, output [3:0] out, output carry_out);

wire intermidiate_carry;
wire [3:0] intermidiate_sum;

assign {intermidiate_carry,intermidiate_sum}  = A + B + carry_in; // Обычный сумматор с переносом

wire do_dec_fixup = !intermidiate_carry & (intermidiate_sum>=10); // Определяем, не надо ли скорректировать результат, т.к. он вылез за 10

assign carry_out = do_dec_fixup | intermidiate_carry; // Формируем выходной перенос
assign out = do_dec_fixup?intermidiate_sum+6:intermidiate_sum; // И выходное значение (если надо - корректируем, прибавляя константу)

endmofule
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th June 2025 - 03:11
Рейтинг@Mail.ru


Страница сгенерированна за 0.02361 секунд с 7
ELECTRONIX ©2004-2016