|
1 / 1 / 0
Регистрация: 20.11.2015
Сообщений: 7
|
|
Реализация алгоритма08.09.2016, 13:33. Показов 1337. Ответов 8
Метки нет (Все метки)
Имеются числа n,l,t,p- целые натуральные.
Нужно в цикле выводить значения dec(H[h]*bin(i)) где i от 1 до n, h от 0 до l-1. bin(i) переводит в цикле числа в их бинарное представление длины t. например: i=3, t=8 => bin(i) = 00000011 . Я перевожу числа с помощью get_bin = lambda x: format(x, 'b'), но непонятно, как сделать определенной длины, была мысль создать нулевой массив, а потом с помощью операции or получить желаемое. затем, H[h]- это все комбинации 0 и 1 длины t*p. т.е. H[0]=000...0(длины t*p), H[l-1]=111...11(длины t*p) это я делаю с помощью lst = list(map(list, itertools.product([0, 1], repeat=l-1))) моя проблема в том, что я не могу подобрать такие типы данных, чтобы можно было перемножить бинарное представление числа и H, H - получается типа map, а bin(i) я пытаюсь переводить с помощью list(str(get_bin(i)), но она переводит только первые четыре числа и на этом останавливается. И функция dec должна переводить вектор, который получился при перемножении обратно в число. Кто-нибудь может помочь?
0
|
|
| 08.09.2016, 13:33 | |
|
Ответы с готовыми решениями:
8
Реализация алгоритма Левенберга-Маркварда
Реализация алгоритма |
|
1 / 1 / 0
Регистрация: 20.11.2015
Сообщений: 7
|
|
| 09.09.2016, 11:25 [ТС] | |
|
H - размера (p*t), грубо говоря, это должна быть матрица, которая умножается на вектор размера (t*1), чтобы получить результат в виде вектора (p*1) и перевести обратно в число
0
|
|
|
431 / 302 / 90
Регистрация: 03.12.2015
Сообщений: 741
|
||
| 10.09.2016, 08:46 | ||
|
Что подразумевается под "перемножением" этих двух (бинарных) чисел? Т.е. чему равен bin(3)*H[1] И чему равен dec(bin(3)*H[1])
0
|
||
|
1 / 1 / 0
Регистрация: 20.11.2015
Сообщений: 7
|
|
| 10.09.2016, 16:15 [ТС] | |
|
Неправильно.
Допустим, t=3, p= 2. Тогда bin(3) =011 H(1)= 000001. Теперь вектор столбец bin(3) нужно умножить на H(1), по правилу матрицы, т.е. 000 умножить на 0 001_______________1 ___________________1
0
|
|
|
431 / 302 / 90
Регистрация: 03.12.2015
Сообщений: 741
|
|
| 11.09.2016, 00:45 | |
|
ОК. Пусть дано bin(3)=011 H(51)=110011.
H(51) трактуется как матрица: bin(3) трактуется как вектор: Умножаем bin(3)*H(51). Т.е. умножаем матрицу на вектор. Получаем: Вопрос 1: правильно понято условие? Вопрос 2: чему равно значение dec для полученного вектора (1 2)? В голову приходит следующее: Элементы данного вектора могут принимать значения от 0 до 3 (т.к. у нас три столбца в матрице). Значит мы можем рассматривать вектор как число, записанное в некой системе счисления - в данном случае в 4-ричной. И мы можем перевести его в dec (в десятичную форму).
0
|
|
|
1 / 1 / 0
Регистрация: 20.11.2015
Сообщений: 7
|
|
| 11.09.2016, 13:35 [ТС] | |
|
Все верно. Только при умножении нужно применять &(and логическое), а так все верно. Тогда получится вектор (1 0) а это даёт Dec(1 0)= 2
0
|
|
|
431 / 302 / 90
Регистрация: 03.12.2015
Сообщений: 741
|
|
| 11.09.2016, 14:48 | |
|
Все равно непонятно как получился вектор (1 0). Вариантов применения логического И здесь куча, вероятно также нужно логическое ИЛИ и т.п. В общем, нужно детальное описание перемножения матрицы на вектор с применением логического И.
0
|
|
| 11.09.2016, 14:48 | |
|
Помогаю со студенческими работами здесь
9
Реализация алгоритма сжатия (LZW) Реализация алгоритма Дугласа-Пеккера Реализация алгоритма diamond-square Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-rectangles-sdl3-c. zip
finish-rectangles-sdl3-cpp. zip
|
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие.
Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|