|
поменять местами биты в байте, простой вопрос |
|
|
|
 |
Ответов
|
Apr 25 2010, 22:31
|
Частый гость
 
Группа: Участник
Сообщений: 92
Регистрация: 23-12-08
Из: Кишинёв
Пользователь №: 42 680

|
Цитата(zltigo @ Apr 26 2010, 01:04)  Сильно поленились - у Автора всего лишь AVR а не Atlon . А во вторых и для AVR8 это фатально, переврали мои примеры и вписали int вместо insigned char. В третьих, а почему свой вариант не протестировали  ? А в четвертых попробуйте этот сравнительный тест, например, на 0x01 и узнаете немного о везении. Во первых под рукой нет avr и именно по этому uint8_t превратился в int. Для avr конечно нужно просто uint8_t. Далее свой(первый) вариант протестировал... и он оказался быстрее всех  - смотрел несколько раз, менял местами тесты. Быстрее он. Видимо архитектура процессора+ компилятор(VS2008Express, оптимизация на скорость). Насчёт 0x01: не корректно. Потому что компилятор умудряется считать результат до исполнения  . Зато есть более корректный способ: подать в функцию случайную последовательность. Тогда влияние кэша и предсказателя(и возможно других фишек процессора) будет меньше. Вот новый вариант(с первой функцией) и случайным входом: CODE #include <cstdlib> #include <iostream> #include <windows.h> #include <stdint.h>
static uint32_t x, y, z, w; static void reset_xor128() { x = 123456789; y = 362436069; z = 521288629; w = 88675123; }
static uint32_t xor128() { uint32_t t; t=(x^(x<<11));x=y;y=z;z=w; return(w=(w^(w>>19))^(t^(t>>8))); }
static uint8_t InverseByte_zltigo(int b ) { int ret = 0; for( int i = 0x80; i; i >>= 1 ) { if( b & 1 ) ret |= i; b >>= 1; } return ret; }
static uint8_t InverseByte_zltigo2(int b ) { int ret = 0; for( int i = 0x80; b; b >>= 1 ) { if( b & 1 ) ret |= i; i >>= 1; } return ret; }
static uint8_t InverseByte_unroll(int b ) { return ( (b & 0x01) << 7 | (b & 0x02) << 5 | (b & 0x04) << 3 | (b & 0x08) << 1 | (b & 0x10) >> 1 | (b & 0x20) >> 3 | (b & 0x40) >> 5 | (b & 0x80) >> 7 ); }
static uint8_t InverseByte_first(int b ) { int ret = 0; for( int i = 0; i < 8; i++ ) { ret |= ( ( b & ( 1 << i ) ) ? 1 : 0 ) << ( 7 - i ); } return ret; }
static void Benchmark( uint8_t (*test_func)(int)) { LARGE_INTEGER start, end; reset_xor128(); QueryPerformanceCounter(&start); for(int i = 0; i < 100000000; i++ ) test_func( xor128() & 0xFF ); QueryPerformanceCounter(&end); std::cout << "time=" << end.QuadPart - start.QuadPart << std::endl; }
int _tmain(int argc, _TCHAR* argv[]) { Benchmark( &InverseByte_unroll ); Benchmark( &InverseByte_first ); Benchmark( &InverseByte_zltigo ); Benchmark( &InverseByte_zltigo2 );
return 0; } И результат: time=4589919 time=4583382 time=18303765 time=16308624 ps: После нескольких испытаний пришёл всёже выводу что InverseByte_unroll и InverseByte_first примерно равны по скорости. Но в любом случае это всё архитектурнозависимо и тестировать нужно на том железе, где будет работать(оказывается что даже инструкции специальные для этого бывают  ).
|
|
|
|
Сообщений в этой теме
Vny4ek поменять местами биты в байте Apr 25 2010, 19:34 zltigo Цитата(Vny4ek @ Apr 25 2010, 21:34) 0х72=... Apr 25 2010, 19:45 aaarrr Цитата(zltigo @ Apr 25 2010, 23:45) Не хи... Apr 25 2010, 19:47 ASN Vny4ek
тут есть Apr 25 2010, 19:53 Vny4ek я это вижу как цикл на 8 шагов
где проверяется зна... Apr 25 2010, 20:04 baralgin Сумбурное описание, но если правильно понял то тип... Apr 25 2010, 20:04 demiurg_spb Если вопрос звучал так: "Как зеркалить биты в... Apr 25 2010, 20:53 KRS IMHO цикл тут неоптимален.
Можно же стандартный сп... Apr 25 2010, 20:46 baralgin Цитата(KRS @ Apr 25 2010, 23:46) Можно же... Apr 25 2010, 20:57 zltigo Цитата(baralgin @ Apr 25 2010, 22:57) Цик... Apr 25 2010, 21:12 baralgin Не поленился, проверил (плохая привычка меряться..... Apr 25 2010, 21:55 zltigo Цитата(baralgin @ Apr 25 2010, 23:55) Не ... Apr 25 2010, 22:04 KRS Цитата(baralgin @ Apr 26 2010, 01:55) ps:... Apr 25 2010, 22:07 Vny4ek я проще себе это представлял, не знаю только как н... Apr 26 2010, 05:33 zltigo Цитата(Vny4ek @ Apr 26 2010, 07:33) я про... Apr 26 2010, 06:58 KRS Для AVR все равно быстрее так
Кодuint8_t rsb(u... Apr 26 2010, 07:56 zltigo Цитата(KRS @ Apr 26 2010, 09:56) Для AVR ... Apr 26 2010, 08:14 demiurg_spb Цитата(KRS @ Apr 26 2010, 11:56) Даже есл... Apr 26 2010, 20:59  MrYuran Цитата(demiurg_spb @ Apr 27 2010, 00:59) ... Apr 27 2010, 09:06 x736C Цитата(KRS @ Apr 26 2010, 11:56) Для AVR ... Apr 27 2010, 01:53  singlskv Цитата(x736C @ Apr 27 2010, 05:53) С перв... Apr 27 2010, 20:58   x736C Цитата(singlskv @ Apr 28 2010, 00:58) у В... Apr 28 2010, 00:36    singlskv Цитата(x736C @ Apr 28 2010, 04:36) Перепр... Apr 28 2010, 08:03 Vny4ek ЦитатаВсе плохо, Вы, как оказалось, не только напи... Apr 26 2010, 17:12 smac Цитата(Vny4ek @ Apr 26 2010, 21:12) Инфы ... Apr 26 2010, 19:45 sigmaN Vny4ek вот как-то так:
установить бит в байтеКодb ... Apr 26 2010, 19:55 Vny4ek sigmaN, спасибо большое. То что написали после вас... Apr 27 2010, 05:02 zltigo Цитата(Vny4ek @ Apr 27 2010, 07:02) sigma... Apr 27 2010, 07:35 sergeeff Jr. Я по простому сделал (как и сказали, при помощи та... Apr 27 2010, 06:15 akl Может.
Apr 27 2010, 09:16 sergeeff Jr. Блин крутые специалисты, вы проблему решаете или п... Apr 27 2010, 22:55 aaarrr Цитата(sergeeff Jr. @ Apr 28 2010, 02:55)... Apr 27 2010, 23:29 sergeeff Jr. Я решаю задачи (взяв AVR с большим количеством пам... Apr 28 2010, 00:09 aaarrr Цитата(sergeeff Jr. @ Apr 28 2010, 04:09)... Apr 28 2010, 00:22 sigmaN ЦитатаА во вторых человек настолько хреново разбир... Apr 28 2010, 02:55 ASN sergeeff Jr
Тут речь не оптимизации ради оптимизац... Apr 28 2010, 15:21 x736C Да, облажался. Мне показалось, АВР делает цикличес... Apr 28 2010, 09:04 sergeeff Jr. Такое впечатление, что все ваши начальники понимаю... Apr 28 2010, 13:56 zltigo Цитата(sergeeff Jr. @ Apr 28 2010, 15:56)... Apr 28 2010, 14:11 aaarrr Цитата(sergeeff Jr. @ Apr 28 2010, 17:56)... Apr 28 2010, 14:13 sergeeff Jr. Байт конечно, очепятался я.
Я не говорил, что я н... Apr 28 2010, 16:49 KRS Цитата(sergeeff Jr. @ Apr 28 2010, 20:49)... Apr 28 2010, 22:11 sergeeff Если обратите внимание, в последних книгах по прог... Apr 28 2010, 17:35 aaarrr Цитата(sergeeff Jr. @ Apr 28 2010, 20:49)... Apr 28 2010, 18:05 sergeeff Это все на тему - сделать работоспособное устройст... Apr 28 2010, 20:41 Vny4ek Всем большое спасибо за помощь. Сам понимаю что ту... Apr 30 2010, 06:27
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|