Upgrade to Pro — share decks privately, control downloads, hide ads and more …

ビットについて|入門者向け資料

mina
May 24, 2021
150

 ビットについて|入門者向け資料

大学サークルのイントロ用資料です
そもそもビットってなんぞやを扱います

mina

May 24, 2021
Tweet

Transcript

  1. 2進数を考える 使える数字は0,1の2種類 1の次は繰り上がりで,10(2)になる 1 0 1 1 0 0 1

    0(2) = 128*1 + 64*0 + 32*1 + 16*1 + 8*0 + 4*0 + 2*1 + 1*0 = 128*1 + 32*1 + 16*1 + 2*1
  2. 1 0 1 1 0 0 1 0 (2) 2^n(重み)

    7 6 5 4 3 2 1 0 2進数 1 0 1 1 0 0 1 0 値 128 64 32 16 8 4 2 1 それぞれの桁には重みがあり,2^(重み)で計算される n桁目の重みは(n-1)
  3. 1 0 1 1 0 0 1 0 (2) 2^n(重み)

    7 6 5 4 3 2 1 0 2進数 1 0 1 1 0 0 1 0 値 128 64 32 16 8 4 2 1 = 128 + 32 + 16 + 2 = 178
  4. ビットで考える A B Y 0 0 0 0 1 1

    1 0 1 1 1 1 Y = A OR B A B Y 0 0 0 0 1 0 1 0 0 1 1 1 Y = A AND B A B Y 0 0 0 0 1 1 1 0 1 1 1 0 Y = A XOR B A Y 0 1 1 0 Y = NOT A 排他的論理和(Exclusive OR)は, XOR / EOR / ExOR などの表記がある
  5. 否定もある(出力にNOTかませる) A B Y 0 0 1 0 1 0

    1 0 0 1 1 0 Y = A NOR B A B Y 0 0 1 0 1 1 1 0 1 1 1 0 Y = A NAND B A B Y 0 0 1 0 1 0 1 0 0 1 1 1 Y = A XNOR B
  6. 論理素子(論理ゲート) A B Y 0 0 0 0 1 1

    1 0 1 1 1 1 Y = A OR B A B Y 0 0 0 0 1 0 1 0 0 1 1 1 Y = A AND B A B Y 0 0 0 0 1 1 1 0 1 1 1 0 Y = A XOR B A Y 0 1 1 0 Y = NOT A
  7. 論理素子(論理ゲート) A B Y 0 0 1 0 1 0

    1 0 0 1 1 0 Y = A NOR B A B Y 0 0 1 0 1 1 1 0 1 1 1 0 Y = A NAND B A B Y 0 0 1 0 1 0 1 0 0 1 1 1 Y = A XNOR B
  8. ビット演算 - OR A 1 0 0 1 1 0

    1 0 B 0 0 1 0 1 0 0 1 Y 1 0 1 1 1 0 1 1 10011010(2) OR 00101001(2) 同じ重み同士で演算 算数の筆算みたいな感じ 桁数が違ったら足りない部分を 0で埋める A B Y 0 0 0 0 1 1 1 0 1 1 1 1
  9. ビット演算 - OR A 1 0 0 1 1 0

    1 0 B 0 0 1 0 1 0 0 1 Y 1 0 1 1 1 0 1 1 10011010(2) OR 00101001(2) Y = 10111011(2) A B Y 0 0 0 0 1 1 1 0 1 1 1 1
  10. ビット演算 - AND A 1 0 0 1 1 0

    1 0 B 0 0 1 0 1 0 0 1 Y 0 0 0 0 1 0 0 0 10011010(2) AND 00101001(2) Y = 00001000(2) A B Y 0 0 0 0 1 0 1 0 0 1 1 1
  11. ビット演算 - XOR A 1 0 0 1 1 0

    1 0 B 0 0 1 0 1 0 0 1 Y 1 0 1 1 0 0 1 1 10011010(2) XOR 00101001(2) Y = 10110011(2) A B Y 0 0 0 0 1 1 1 0 1 1 1 0
  12. ビット演算 - NOT A 1 0 0 1 1 0

    1 0 Y 0 1 1 0 0 1 0 1 NOT 10011010(2) Y = 01100101(2) A Y 0 1 1 0
  13. ビット演算 - NOT - XORで実現 A 1 0 0 1

    1 0 1 0 B 1 1 1 1 1 1 1 1 Y 0 1 1 0 0 1 0 1 NOT 10011010(2) = 10011010(2) XOR 11111111(2) Y = 01100101(2) A B Y 0 0 0 0 1 1 1 0 1 1 1 0
  14. ビット演算 - シフト A 1 0 0 1 1 0

    1 0 Y 0 1 0 0 1 1 0 1 右シフト 10011010(2) Y = 01001101(2) 論理シフトや算術シフトの違い ローテートの概念は割愛 右シフトは ÷ 2
  15. ビット演算 - 任意のbitを取り出す A 1 0 0 1 1 0

    1 0 B 0 0 0 0 1 1 1 1 Y 0 0 0 0 1 0 1 0 10011010(2) AND 00001111(2) Y = 00001010(2) 下位4bitのみ取り出す A B Y 0 0 0 0 1 0 1 0 0 1 1 1
  16. 2進数での足し算(+) 10011010 (2) + 00101001 (2) A 1 0 0

    1 1 0 1 0 B 0 0 1 0 1 0 0 1 Y 1 1 0 0 0 0 1 1
  17. 2進数での足し算(+) 10011010 (2) + 00101001 (2) A 1 0 0

    1 1 0 1 0 B 0 0 1 0 1 0 0 1 Y 1 1 0 0 0 0 1 1 1 + 1 = 10 1
  18. 2進数での足し算(+) 10011010 (2) + 00101001 (2) A 1 0 0

    1 1 0 1 0 B 0 0 1 0 1 0 0 1 Y 1 1 0 0 0 0 1 1 1 + 1 = 10 1 1
  19. 2進数での足し算(+) 10011010 (2) + 00101001 (2) A 1 0 0

    1 1 0 1 0 B 0 0 1 0 1 0 0 1 Y 1 1 0 0 0 0 1 1 1 + 1 = 10 1 1 1
  20. 8進数と16進数(余談) 2進数や10進数以外にも,いくつかよく使われる進数表現がある • 8進数 ◦ 0~7が使える ◦ n桁目の重みは8^(n-1) ◦ 000

    000 000 … のように,2進数を3桁ごとに区切ると変換しやすい (2進3桁は0~7を表現可能) ◦ 011 のように表記する(これは 8進数で11の意味)(OctalのO→0) • 16進数 ◦ 0~9,A~Fが使える(A:11, B:12, C:13, D:14, F:15) ◦ n桁目の重みは16^(n-1) ◦ 0000 0000 0000 … のように,2進数を4桁ごとに区切ると変換しやすい (2進4桁は0~15を表現可能) ◦ 0x1Fのように表記する(これは 16進数で1Fの意味)(Hexadecimalのx) ◦ 人間が結構読めるのでバイナリ形式とかはこれで表現したのをよく見る
  21. 8進数と16進数(余談)-「コンピュータとは」より 00000000: cffa edfe 0700 0001 0300 0000 0200 0000

    ................ 00000010: 1100 0000 d805 0000 8580 2100 0000 0000 ..........!..... 00000020: 1900 0000 4800 0000 5f5f 5041 4745 5a45 ....H...__PAGEZE 00000030: 524f 0000 0000 0000 0000 0000 0000 0000 RO.............. 00000040: 0000 0000 0100 0000 0000 0000 0000 0000 ................ 00000050: 0000 0000 0000 0000 0000 0000 0000 0000 ................ 00000060: 0000 0000 0000 0000 1900 0000 2802 0000 ............(... 00000070: 5f5f 5445 5854 0000 0000 0000 0000 0000 __TEXT.......... 00000080: 0000 0000 0100 0000 0080 0000 0000 0000 ................ 00000090: 0000 0000 0000 0000 0080 0000 0000 0000 ................ .exeファイル(実行ファイル)の実体 この部分が16進数
  22. ビット(bit)とバイト(Byte)(余談) 1 B(Byte) = 8 bit 1 KB = 10^3

    B = 1000 B 1 MB = 10^6 KB = 1000000 B 1 GB = 1000 MB = 10^9 B = 10000000000 B 1 TB = 1000 GB = 10^12 B = 1000000000000 B 1 PB = 1000 TB = 10^15 B = 1000000000000000 B 1 EB = 1000 PB = 10^18 B = 1000000000000000000 B 1 ZB = 1000 EB = 10^21 B = 1000000000000000000000 B 1 YB = 1000 ZB = 10^24 B = 1000000000000000000000000 B キロ メガ ギガ テラ ペタ エクサ ゼタ ヨタ
  23. KB(キロバイト)とKiB(キビバイト)(余談) 10進ベースだと 1 KB = 10^3 B = 1000 B

    2進ベースだと 1 KiB = 2^10 B = 1024 B コンピュータは2進ベースで動いている 1 MiB = 1024 KB = 2^20 B 1 GiB = 1024 MB = 2^30 B 1 TiB = 1024 GB = 2^40 B メビバイト ギビバイト ティビバイト