Перейти к содержанию
    

Нахождение старшего значащего бита

Решаю задачу нахождение старшего значащего бита след. образом

 

 

reg [4:0] MSB;

    always @(posedge clk)
            if (data_temp[31])
                MSB    <= 31;
            else if (data_temp[30])
                MSB    <= 30;
            else if (data_temp[29])
                MSB    <= 29;
......
            else if (data_temp[0])
                MSB    <= 0;

 

 

Как записать такую конструкцию более кратно через for ?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Благодарю, решил задачку, помнил, что пробегала похожая тема , но не нашел.

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Можете здесь посмотреть алгоритм

Может после прочтения алгоритма сможете оптимизировать реализацию. ;)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...