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

 
 
> Деление за один такт
ArAhis
сообщение Dec 5 2005, 17:01
Сообщение #1


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 8-09-05
Пользователь №: 8 387



Нужно поделить целое число A на целое число B за один такт, причем A > B! При этом нужна целая часть от деления, остаток не нужен! Посоветуйте как это можно сделать, каким алгоритмом, где посмотреть, в какой книге или инете???


--------------------
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
evgeniy_s
сообщение Dec 5 2005, 21:32
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 75
Регистрация: 3-09-05
Из: Россия, Москва
Пользователь №: 8 195



Кнут Дональд Э. Искусство программирования. 3 тома: том 1 - Основные алгоритмы; том 2 - Получисленные методы; том 3 - Сортировка и поиск.
Отдельные главы в интернете есть (а может и весь Кнут).
Понятие "такт" весьма расплывчето - если не указана длительность такта, то всё в твоих руках! Берёшь и реализуешь асинхронную схему деления (на логике), а потом подстраиваешь такт под эту логику. biggrin.gif
P.S. К тому же уважаемый, кафедра ИУ4 - очень авторитетная кафедра, как у нас, так и за рубежом, поэтому надо было на лекции ходить. biggrin.gif biggrin.gif biggrin.gif


--------------------
"О наслажденье ходить по краю.
Замрите, ангелы, смотрите: я играю.
Разбор грехов моих оставьте до поры,
Вы оцените красоту игры!"
Go to the top of the page
 
+Quote Post
ArAhis
сообщение Dec 7 2005, 12:57
Сообщение #3


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 8-09-05
Пользователь №: 8 387



Цитата(evgeniy_s @ Dec 6 2005, 00:32) *
P.S. К тому же уважаемый, кафедра ИУ4 - очень авторитетная кафедра, как у нас, так и за рубежом, поэтому надо было на лекции ходить. biggrin.gif biggrin.gif biggrin.gif

К сожелению, у нас не было курса по алгоритмам реализации математических операций и функций, а также не было нормального курса по цифровой схемотехнике sad.gif приходиться все изучать самому

Цитата(SM @ Dec 6 2005, 10:01) *
Больше слушайте народ, тоже мне невозможная задача. Советую посмотреть реализацию LPM_DIVIDE из альтеровского софта. Генерит хорошие комбинаторные делители. Вот он же на верилоге (A и B восьмибитные), только построенный на менее экономной схеме, чем альтеровский вариант с восстановлением остатка (если рассматривать реализацию в заказной ИМС, то мультиплексор обычно более компактен, чем xor для сумматора-вычитателя):

Код
reg [7:0]p[8:0],r;
integer i;

always @(A,B)
for (i = 7; i >= 0; i = i - 1)
{r[i],p[i]}=(i==7)?(A>>7)-B:(r[i+1])?{p[i+1],A[i]}+B:{p[i+1],A[i]}-B;
assign Q = ~r;
assign M = (r[0])? p[0] + B : p[0] + 0;
endmodule

Спасибо за пример, попробую всетаки реализовать табличным методом с целью уменьшения задержки и увеличения точности

Сообщение отредактировал ArAhis - Dec 7 2005, 12:52


--------------------
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 20:29
Рейтинг@Mail.ru


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