реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Контрольная сумма по модулю 2
data_stack
сообщение Mar 18 2016, 15:54
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 16-10-15
Пользователь №: 88 891



Как посчитать сабж для двух байт понятно, вопрос как посчитать его для одного байта. На выходе нужно получить бит

Сообщение отредактировал data_stack - Mar 18 2016, 15:54
Go to the top of the page
 
+Quote Post
blackfin
сообщение Mar 18 2016, 15:56
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 106
Регистрация: 18-04-05
Пользователь №: 4 261



Цитата(data_stack @ Mar 18 2016, 18:54) *
Как посчитать сабж для двух байт понятно, вопрос как посчитать его для одного байта. На выходе нужно получить бит

Бит_на_выходе = сумма_бит_в_байте % 2;
Go to the top of the page
 
+Quote Post
jcxz
сообщение Mar 19 2016, 07:05
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(blackfin @ Mar 18 2016, 21:56) *
Бит_на_выходе = сумма_бит_в_байте % 2;

Я конечно понимаю, что компилятор заменит операцию '% 2' на '& 1', но мне казалось что у людей, работающих с сигнальниками (особенно), рука не поднимется написать лишнюю операцию деления, ну или они дважды подумают laughing.gif
Go to the top of the page
 
+Quote Post
menzoda
сообщение Mar 19 2016, 19:24
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 55
Регистрация: 13-09-12
Пользователь №: 73 530



Сумма по модулю 2 - это XOR. Если нужна однобитовая сумма, то сначала XORтье все байты данных друг с другом, затем биты получившегося результата.
Go to the top of the page
 
+Quote Post
k155la3
сообщение Mar 21 2016, 13:32
Сообщение #5


Профессионал
*****

Группа: Свой
Сообщений: 1 123
Регистрация: 8-03-09
Из: Днепр
Пользователь №: 45 848



сумма по модулю 2
0+0=0
0+1=1
1+0=1
1+1=0

если все биты в байте прогнать через одноразрядный мод2 сумматор, то для четного
кол-ва единиц будет 0, для нечетного 1. четность или нечетность.

Если надо считать очень быстро - через таблицу.
Зачем считать то, что заранее известно ?


Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Mar 21 2016, 14:39
Сообщение #6


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Код
CSum = Data ^ (Data >> 4);
CSum = CSum ^ (Csum >> 2);
CSum = CSum ^ (Csum >> 1);
CSum &= 1;


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th June 2025 - 04:07
Рейтинг@Mail.ru


Страница сгенерированна за 0.01395 секунд с 7
ELECTRONIX ©2004-2016