170 похожих чатов

Использую boost::multiprecision Вот интересующий кусок кода: https://pastebin.com/3Em2AiJj Вот вывод: https://pastebin.com/Nq9sxzLC Почему powm() меняет тип выражения

на какой-то непонятный, который потом несовместим с cpp_int? В доке и в гугле об этом ничего нет, по крайней мере я не нашел. Бьюсь с этим уже кучу времени

Полный код:
https://pastebin.com/0KtZUi8t

17 ответов

10 просмотров

https://www.boost.org/doc/libs/1_69_0/boost/multiprecision/integer.hpp там тип это первый

Функция ничего не меняет, она возвращает какой-то типа данных, значение его

Pavel-Павлик Автор вопроса
Ilya Zviagin
Функция ничего не меняет, она возвращает какой-то ...

Я имел в виду, что логично, если у меня каждый из трех аргументов cpp_int, то значение степени по модулю тоже будет cpp_int

Pavel Павлик
Я имел в виду, что логично, если у меня каждый из ...

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

template <class I1, class I2, class I3> typename enable_if_c<is_integral<I1>::value && is_unsigned<I2>::value && is_integral<I3>::value, I1>::type powm(const I1& a, I2 b, I3 c) { typedef typename detail::double_integer<I1>::type double_type; I1 x(1), y(a); double_type result; while(b > 0) { if(b & 1) { multiply(result, x, y); x = integer_modulus(result, c); } multiply(result, y, y); y = integer_modulus(result, c); b >>= 1; } return x % c; } template <class I1, class I2, class I3> inline typename enable_if_c<is_integral<I1>::value && is_signed<I2>::value && is_integral<I3>::value, I1>::type powm(const I1& a, I2 b, I3 c) { if(b < 0) { BOOST_THROW_EXCEPTION(std::runtime_error("powm requires a positive exponent.")); } return powm(a, static_cast<typename make_unsigned<I2>::type>(b), c); }

Pavel-Павлик Автор вопроса
Ilya Zviagin
Степень растет быстро, поэтому логично возвращать ...

cpp_int не ограничено вообще и степень тут не растет быстро, потому что тут возведение по модулю

Pavel-Павлик Автор вопроса
std::slavik
template <class I1, class I2, class I3> typename e...

Насколько я понимаю, эта реализация для беззнаковых, но я не указывал, что у меня cpp_int может быть беззнаковым (хотя это так)

Pavel-Павлик Автор вопроса
Ilya Zviagin
А что за тип OpenKey ?

struct OpenKey { cpp_int p; cpp_int q; cpp_int g; cpp_int y; };

Pavel Павлик
struct OpenKey { cpp_int p; cpp_int q; ...

Да блин чё с тобой, парень? как так может быть?

Pavel Павлик
struct OpenKey { cpp_int p; cpp_int q; ...

Делай репро-пример, и присылай. Иначе не разобраться будет

Pavel-Павлик Автор вопроса
Ilya Zviagin
Делай репро-пример, и присылай. Иначе не разобрать...

В исходном сообщении ссылка на полный код https://t.me/supapro/757592

Pavel Павлик
Или я не так понял вопрос?

нет, так , я просто пропустил это...

https://godbolt.org/z/Gn6qbr

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта