|
1 / 1 / 0
Регистрация: 20.11.2015
Сообщений: 7
|
|
Реализация алгоритма08.09.2016, 13:33. Показов 1329. Ответов 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 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 11.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|