|
Одним делением вычислить два, можно ли? |
|
|
|
May 19 2011, 16:30
|
Профессионал
    
Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968

|
Добрый день. Возникла задача, под которую у меня мозг не заточен, если не ошибаюсь, из математики конечных полей. Господа математики, подскажите, можно ли вычислить одним делением X и Y:
X=(a mod k1) mod k2 Y = (a mod k1)/k2
k1, k2 - константы, 16 бит. а- переменная, 32 бит.
Нужна аппаратная реализация этого, если в лоб - два делителя подряд - задержка большая, скорость снижается, да и ресурсов делитель немало ест. Нужна реализация с одним делителем + умножители и сумматоры/вычитатели если нужно.
Спасибо!
|
|
|
|
|
 |
Ответов
|
May 25 2011, 11:19
|
Вечный студент
   
Группа: Участник
Сообщений: 500
Регистрация: 11-09-06
Из: Питер
Пользователь №: 20 262

|
1. Вот крутится такая мысля… От деления a на k1 нужен только остаток. Значит прибавив к а любое целое число, умноженное на k1, мы ничего не изменим. Допустим, при делении a на k1 мы получаем частное t и остаток r
a=k1*t+r
Во втором делении r делим на k2 и получаем Y и X.
a=k1*t+k2*Y+X
Возьмем в качестве «любого целого числа» Y–t
b = a+k1*(Y–t) = (k1+k2)*Y+X
Такое b можно подставить в Ваши формулы вместо а, и результат будет тот же. Но самое интересное, что деление b на (k1+k2) даст сразу вожделенные X и Y… казалось бы. Но беда в том, что t мы не знаем. Мысля до конца не доведена, но я дал посыл, может быть кто-нибудь доведет.
2. Если k1 и k2 – константы, то вообще возможно обойтись без единого деления. Для простоты рассмотрю на примере деления 2-разрядных десятичных чисел. Пусть надо разделить 37 на 13. 37/13 = 37*100/13/100. Берем число 100 div 13 =7 (константа). Вместо деления 37 (переменная) умножаем на 7 (константа). Получаем 259. Два младших разряда (добавленных выше) выкидываем и получаем частное =2. Остаток находим как 37–13*2
Сообщение отредактировал Diusha - May 25 2011, 11:27
|
|
|
|
Сообщений в этой теме
alexPec Одним делением вычислить два May 19 2011, 16:30 Сергей Борщ Или я чего-то не понимаю, или X и Y - это остаток ... May 19 2011, 22:04 Xenia Цитата(alexPec @ May 19 2011, 20:30) Добр... May 19 2011, 23:18 Волощенко Цитата(alexPec @ May 19 2011, 19:30) Нужн... May 20 2011, 05:16 Visk Цитата(Волощенко @ May 20 2011, 09:16) Де... May 20 2011, 09:02  alexPec Напишу то же самое от себя...
Поясню подробней x ... May 20 2011, 15:38 i-mir Не совсем понятно что у вас за проблема. Не уклады... May 23 2011, 19:44 ViKo Цитата(i-mir @ May 23 2011, 22:44) Н... May 24 2011, 06:42 i-mir Вопрос как обычно звучит так - чего хочет топикста... May 24 2011, 13:54 scifi Цитата(i-mir @ May 24 2011, 17:54) Я... May 24 2011, 14:20  alexPec Цитата(scifi @ May 24 2011, 18:20) Удивит... May 24 2011, 18:12 des00 никак, делайте два деления на одном блоке %) May 25 2011, 04:25 i-mir ЦитатаУдивительно толкование. И совсем неверное.
С... May 25 2011, 07:21 ViKo Если k1 не очень большое число (а k2 должно быть е... May 26 2011, 06:46 alexPec Цитата(ViKo @ May 26 2011, 10:46) Если k1... May 26 2011, 19:20  Diusha Цитата(alexPec @ May 26 2011, 22:20) Не, ... May 27 2011, 15:57   ViKo Цитата(Diusha @ May 27 2011, 18:57) Так а... May 27 2011, 19:45    Diusha Цитата(ViKo @ May 27 2011, 22:45) Видимо,... May 28 2011, 04:11     ViKo Цитата(Diusha @ May 28 2011, 07:11) ... н... May 28 2011, 07:16      alexPec Цитата(ViKo @ May 28 2011, 11:16) Мы не т... May 28 2011, 09:16    singlskv Цитата(ViKo @ May 27 2011, 23:45) Видимо,... Jun 2 2011, 08:16     alexPec Цитата(singlskv @ Jun 2 2011, 12:16) А ес... Jun 2 2011, 20:47      singlskv Цитата(alexPec @ Jun 3 2011, 00:47) k2 = ... Jun 2 2011, 21:55 i-mir Вот интересен например сам факт задачи, где топикс... May 30 2011, 19:00
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|