Двоичное число — это число, выраженное в системе счисления с основанием -2 или двоичной системе счисления , способ представления чисел , который использует только два символа для натуральных чисел : обычно «0» ( ноль ) и «1» ( один ). Двоичное число может также относиться к рациональному числу , имеющему конечное представление в двоичной системе счисления, то есть частное целого числа на степень двойки.
Система счисления с основанием 2 представляет собой позиционную запись с основанием 2. Каждая цифра называется битом или двоичной цифрой. Благодаря своей простой реализации в цифровых электронных схемах с использованием логических вентилей , двоичная система используется почти всеми современными компьютерами и компьютерными устройствами как предпочтительная система использования по сравнению с другими человеческими методами общения из-за простоты языка и помехоустойчивости в физической реализации. [1]
Современная двоичная система счисления изучалась в Европе в XVI и XVII веках Томасом Харриотом , Хуаном Карамуэлем и Лобковицем и Готфридом Лейбницем . Однако системы, связанные с двоичными числами, появились и раньше во многих культурах, включая Древний Египет, Китай и Индию.
Писцы Древнего Египта использовали две разные системы для своих дробей: египетские дроби (не связанные с двоичной системой счисления) и дроби Глаза Гора (названные так потому, что многие историки математики считают, что символы, используемые для этой системы, могли быть расположены так, чтобы сформировать глаз Гора , хотя это было оспорено). [2] Дроби Глаза Гора представляют собой двоичную систему счисления для дробных количеств зерна, жидкостей или других мер, в которой дробь геката выражается как сумма двоичных дробей 1/2, 1/4, 1/8, 1/16, 1/32 и 1/64. Ранние формы этой системы можно найти в документах Пятой династии Египта , приблизительно 2400 г. до н.э., а ее полностью развитая иероглифическая форма датируется Девятнадцатой династией Египта , приблизительно 1200 г. до н.э. [3]
Метод, используемый для древнеегипетского умножения, также тесно связан с двоичными числами. В этом методе умножение одного числа на второе выполняется последовательностью шагов, в которых значение (первоначально первое из двух чисел) либо удваивается, либо к нему снова добавляется первое число; порядок, в котором должны выполняться эти шаги, задается двоичным представлением второго числа. Этот метод можно увидеть в использовании, например, в математическом папирусе Райнда , который датируется примерно 1650 годом до нашей эры. [4]
« И Цзин» датируется 9 веком до н. э. в Китае. [5] Двоичная система счисления в « И Цзин» используется для интерпретации ее четверичной техники гадания . [6]
Он основан на даосской двойственности инь и ян . [7] Восемь триграмм (багуа) и набор из 64 гексаграмм («шестьдесят четыре» гуа) , аналогичные трех- и шестибитным двоичным числам, использовались по крайней мере еще во времена династии Чжоу в Древнем Китае. [5]
Ученый династии Сун Шао Юн (1011–1077) переставил гексаграммы в формате, напоминающем современные двоичные числа, хотя он не намеревался использовать свою компоновку в математических целях. [ 6] Рассматривая наименее значимый бит поверх отдельных гексаграмм в квадрате Шао Юна [8] и читая по строкам либо снизу справа наверх слева со сплошными линиями как 0 и прерывистыми линиями как 1, либо сверху слева направо вниз со сплошными линиями как 1 и прерывистыми линиями как 0, гексаграммы можно интерпретировать как последовательность от 0 до 63. [9]
Этруски разделили внешний край гадательных печеней на шестнадцать частей, на каждой из которых было написано имя божества и его область неба. Каждая область печени производила бинарное чтение, которое объединялось в окончательный бинарник для гадания. [10]
Гадание в древнегреческом оракуле Додона работало путем вытягивания из отдельных банок, табличек с вопросами и шариков «да» и «нет». Затем результат объединялся, чтобы составить окончательное пророчество. [11]
Индийский ученый Пингала (ок. II в. до н. э.) разработал бинарную систему для описания просодии . [12] [13] Он описал метры в виде коротких и длинных слогов (последний по длине равен двум коротким слогам). [14] Они были известны как слоги laghu (легкие) и guru (тяжелые).
Индуистская классика Пингалы под названием Чандахшастра (8.23) описывает формирование матрицы для того, чтобы дать уникальное значение каждому метру. «Чандахшастра» буквально переводится как наука о метрах на санскрите. Двоичные представления в системе Пингалы увеличиваются вправо, а не влево, как в двоичных числах современной позиционной нотации . [15] В системе Пингалы числа начинаются с цифры один, а не с нуля. Четыре коротких слога «0000» являются первым шаблоном и соответствуют значению один. Числовое значение получается путем добавления единицы к сумме значений мест . [16]
Ифа — африканская система гадания . Похожа на И Цзин , но имеет до 256 бинарных знаков, [ 17] в отличие от И Цзин , в котором их 64. Ифа возникла в 15 веке в Западной Африке среди народа йоруба . В 2008 году ЮНЕСКО добавила Ифа в свой список « Шедевров устного и нематериального наследия человечества ». [18] [19]
Жители острова Мангарева во Французской Полинезии использовали гибридную двоично- десятичную систему до 1450 года. [20] Щелевые барабаны с бинарными тонами используются для кодирования сообщений по всей Африке и Азии. [7] Наборы двоичных комбинаций, похожие на И-Цзин, также использовались в традиционных африканских системах гадания, таких как Ифа и другие, а также в средневековой западной геомантии . Большинство языков коренных народов Австралии используют систему с основанием 2. [21]
В конце 13-го века Рамон Луллий имел амбицию учесть всю мудрость в каждой отрасли человеческого знания того времени. Для этой цели он разработал общий метод или "Ars generalis", основанный на бинарных комбинациях ряда простых базовых принципов или категорий, за что его считают предшественником вычислительной науки и искусственного интеллекта. [22]
В 1605 году Фрэнсис Бэкон обсуждал систему, посредством которой буквы алфавита могли быть сведены к последовательностям двоичных цифр, которые затем могли быть закодированы как едва заметные вариации шрифта в любом случайном тексте. [23] Что важно для общей теории двоичного кодирования, он добавил, что этот метод может быть использован с любыми объектами вообще: «при условии, что эти объекты способны только к двукратному различию; как, например, колокола, трубы, огни и факелы, звуки мушкетов и любые инструменты подобной природы». [23] (См. шифр Бэкона .)
В 1617 году Джон Нейпир описал систему, которую он назвал арифметикой расположения , для выполнения двоичных вычислений с использованием непозиционного представления буквами. Томас Харриот исследовал несколько позиционных систем счисления, включая двоичную, но не опубликовал свои результаты; они были найдены позже среди его статей. [24] Возможно, первая публикация системы в Европе была сделана Хуаном Карамуэлем и Лобковицем в 1700 году. [25]
Лейбниц написал более сотни рукописей о двоичной системе, большинство из которых остались неопубликованными. [26] До его первой специальной работы в 1679 году многочисленные рукописи содержат ранние попытки исследовать двоичные концепции, включая таблицы чисел и основные вычисления, часто набросанные на полях работ, не связанных с математикой. [26]
Его первая известная работа о двоичной системе, «О двоичной прогрессии» , была написана в 1679 году. Лейбниц ввел преобразование между десятичной и двоичной системой счисления, а также алгоритмы для выполнения основных арифметических операций, таких как сложение, вычитание, умножение и деление с использованием двоичных чисел. Он также разработал форму двоичной алгебры для вычисления квадрата шестизначного числа и извлечения квадратных корней. [26]
Его самая известная работа представлена в статье Explication de l'Arithmétique Binaire (опубликованной в 1703 году). Полное название статьи Лейбница переводится на английский язык как «Объяснение двоичной арифметики, которая использует только символы 1 и 0, с некоторыми замечаниями о ее полезности и о свете, который она проливает на древние китайские фигуры Фу Си » . [27] Система Лейбница использует 0 и 1, как и современная двоичная система счисления. Пример двоичной системы счисления Лейбница выглядит следующим образом: [27]
Переписываясь с иезуитским священником Иоахимом Буве в 1700 году, который стал экспертом по И Цзин , будучи миссионером в Китае, Лейбниц объяснил свою двоичную нотацию, а Буве продемонстрировал в своих письмах 1701 года, что И Цзин была независимым, параллельным изобретением двоичной нотации. Лейбниц и Буве пришли к выводу, что это отображение было свидетельством крупных китайских достижений в том виде философской математики, которым он восхищался. [28] Об этом параллельном изобретении Лейбниц писал в своем «Объяснении двоичной арифметики», что «это восстановление их значения после такого большого промежутка времени будет казаться тем более любопытным». [29]
Отношение было центральной идеей его универсальной концепции языка или characteristicsa universalis , популярной идеей, которой будут следовать его последователи, такие как Готтлоб Фреге и Джордж Буль, при формировании современной символической логики . [30] Лейбниц впервые познакомился с И Цзин через свой контакт с французским иезуитом Иоахимом Буве , который посетил Китай в 1685 году в качестве миссионера. Лейбниц видел гексаграммы И Цзин как утверждение универсальности своих собственных религиозных убеждений как христианина. [31] Двоичные числа занимали центральное место в теологии Лейбница. Он считал, что двоичные числа символизируют христианскую идею creatio ex nihilo или творения из ничего. [32]
[Концепция, которую] нелегко передать язычникам, — это творение ex nihilo посредством всемогущей силы Бога. Теперь можно сказать, что ничто в мире не может лучше представить и продемонстрировать эту силу, чем происхождение чисел, как оно представлено здесь посредством простого и неприукрашенного представления Единицы и Нуля или Ничто.
— Письмо Лейбница герцогу Брауншвейгскому с приложением гексаграмм И Цзин [31]
В 1854 году британский математик Джордж Буль опубликовал знаменательную работу, в которой подробно описывалась алгебраическая система логики , которая стала известна как булева алгебра . Его логическое исчисление стало инструментом в разработке цифровых электронных схем. [33]
В 1937 году Клод Шеннон защитил магистерскую диссертацию в Массачусетском технологическом институте , в которой впервые в истории реализовал булеву алгебру и двоичную арифметику с использованием электронных реле и переключателей. Диссертация Шеннона под названием «Символический анализ релейных и коммутационных схем » по сути легла в основу практического проектирования цифровых схем . [34]
В ноябре 1937 года Джордж Стибиц , тогда работавший в Bell Labs , завершил релейный компьютер, который он окрестил «Модель К» (от « Кухня », где он его собрал), который вычислял с помощью двоичного сложения. [35] Bell Labs санкционировала полную исследовательскую программу в конце 1938 года со Стибицем у руля. Их Complex Number Computer, завершенный 8 января 1940 года, был способен вычислять комплексные числа . На демонстрации на конференции Американского математического общества в Дартмутском колледже 11 сентября 1940 года Стибиц смог отправлять удаленные команды Complex Number Calculator по телефонным линиям с помощью телетайпа . Это была первая вычислительная машина, когда-либо использовавшаяся удаленно по телефонной линии. Среди участников конференции, которые были свидетелями демонстрации, были Джон фон Нейман , Джон Мочли и Норберт Винер , который написал об этом в своих мемуарах. [36] [37] [38]
Компьютер Z1 , который был спроектирован и построен Конрадом Цузе между 1935 и 1938 годами, использовал булеву логику и двоичные числа с плавающей точкой . [39]
Любое число может быть представлено последовательностью битов (двоичных цифр), которые в свою очередь могут быть представлены любым механизмом, способным находиться в двух взаимоисключающих состояниях. Любой из следующих рядов символов может быть интерпретирован как двоичное числовое значение 667:
Числовое значение, представленное в каждом случае, зависит от значения, присвоенного каждому символу. На заре вычислительной техники для представления двоичных значений использовались переключатели, пробитые отверстия и пробитые бумажные ленты. [40] В современном компьютере числовые значения могут быть представлены двумя различными напряжениями ; на магнитном диске могут использоваться магнитные полярности . Состояние «положительное», « да » или «включено» не обязательно эквивалентно числовому значению единицы; это зависит от используемой архитектуры.
В соответствии с общепринятым представлением чисел с использованием арабских цифр , двоичные числа обычно записываются с использованием символов 0 и 1. При записи двоичные числа часто имеют нижний индекс, префикс или суффикс для указания их основания или корня . Следующие обозначения эквивалентны:
При произнесении двоичные числа обычно читаются цифра за цифрой, чтобы отличать их от десятичных чисел. Например, двоичное число 100 произносится как один ноль ноль , а не сто , чтобы сделать его двоичную природу явной и в целях корректности. Поскольку двоичное число 100 представляет собой значение четыре, было бы запутанным называть это число сотней (словом, которое представляет собой совершенно другое значение или количество). В качестве альтернативы, двоичное число 100 можно прочитать как «четыре» (правильное значение ), но это не делает его двоичную природу явной.
Счет в двоичной системе подобен счету в любой другой системе счисления. Начиная с одной цифры, счет продолжается через каждый символ в порядке возрастания. Перед тем как рассматривать двоичный счет, полезно кратко обсудить более знакомую десятичную систему счета как систему отсчета.
Десятичный счет использует десять символов от 0 до 9. Счет начинается с инкрементной замены наименее значимой цифры (самой правой цифры), которую часто называют первой цифрой . Когда доступные символы для этой позиции исчерпаны, наименее значимая цифра сбрасывается на 0 , а следующая цифра более высокого значения (на одну позицию левее) увеличивается ( переполнение ), и инкрементная замена младшей цифры возобновляется. Этот метод сброса и переполнения повторяется для каждой значимой цифры. Подсчет происходит следующим образом:
Двоичный подсчет следует точно такой же процедуре, и снова инкрементная замена начинается с наименее значимой двоичной цифры или бита (самой правой, также называемой первым битом ), за исключением того, что доступны только два символа 0 и 1. Таким образом, после того, как бит достигает 1 в двоичном коде, инкремент сбрасывает его в 0, но также вызывает инкремент следующего бита слева:
В двоичной системе каждый бит представляет собой возрастающую степень числа 2, причем самый правый бит представляет собой 2 0 , следующий представляет собой 2 1 , затем 2 2 и т. д. Значение двоичного числа — это сумма степеней числа 2, представленных каждым битом «1». Например, двоичное число 100101 преобразуется в десятичную форму следующим образом:
Дроби в двоичной арифметике заканчиваются только если знаменатель является степенью числа 2. В результате 1/10 не имеет конечного двоичного представления ( 10 имеет простые множители 2 и 5 ). Это приводит к тому, что 10 × 1/10 не будет точно равняться 1 в двоичной арифметике с плавающей точкой . Например, чтобы интерпретировать двоичное выражение для 1/3 = .010101..., это означает: 1/3 = 0 × 2 −1 + 1 × 2 −2 + 0 × 2 −3 + 1 × 2 −4 + ... = 0,3125 + ... Точное значение не может быть найдено с помощью суммы конечного числа обратных степеней двойки, нули и единицы в двоичном представлении 1/3 чередуются вечно.
Арифметика в двоичной системе счисления во многом похожа на арифметику в других позиционных системах счисления . Сложение, вычитание, умножение и деление могут выполняться над двоичными числами.
Простейшая арифметическая операция в двоичной системе — сложение. Сложение двух однозначных двоичных чисел выполняется относительно просто, используя форму переноса:
Сложение двух цифр "1" дает цифру "0", а 1 нужно будет добавить к следующему столбцу. Это похоже на то, что происходит в десятичной системе счисления, когда складываются определенные однозначные числа; если результат равен или превышает значение основания (10), цифра слева увеличивается:
Это известно как перенос . Когда результат сложения превышает значение цифры, процедура заключается в «переносе» избыточной суммы, деленной на основание (то есть 10/10), влево, добавляя ее к следующему позиционному значению. Это правильно, поскольку следующая позиция имеет вес, который выше на коэффициент, равный основанию. Перенос работает таким же образом в двоичной системе счисления:
1 1 1 1 1 (переносимые цифры) 0 1 1 0 1+ 1 0 1 1 1-------------= 1 0 0 1 0 0 = 36
В этом примере складываются две цифры: 01101 2 (13 10 ) и 10111 2 (23 10 ). Верхняя строка показывает используемые биты переноса. Начиная с самого правого столбца, 1 + 1 = 10 2 . 1 переносится влево, а 0 записывается внизу самого правого столбца. Добавляется второй столбец справа: 1 + 0 + 1 = 10 2 снова; 1 переносится, а 0 записывается внизу. Третий столбец: 1 + 1 + 1 = 11 2 . На этот раз переносится 1, и 1 записывается в нижней строке. Продолжая таким образом, получаем окончательный ответ 100100 2 (36 10 ).
Когда компьютерам необходимо сложить два числа, правило: x xor y = (x + y) mod 2 для любых двух бит x и y также позволяет выполнять очень быстрые вычисления.
Упрощением для многих задач на двоичное сложение является «метод длинного переноса» или «метод Брукхауза двоичного сложения». Этот метод особенно полезен, когда одно из чисел содержит длинную полосу единиц. Он основан на простой предпосылке, что в двоичной системе, когда задана полоса цифр, состоящая полностью из n единиц (где n — любая целая длина), добавление 1 приведет к числу 1, за которым следует строка из n нулей. Эта концепция логически следует, так же как в десятичной системе, где добавление 1 к строке из n девяток приведет к числу 1, за которым следует строка из n нулей:
Двоично-десятичный 1 1 1 1 1 аналогично 9 9 9 9 9 + 1 + 1 ——————————— ——————————— 1 0 0 0 0 0 1 0 0 0 0 0
Такие длинные строки довольно распространены в двоичной системе. Из этого следует, что большие двоичные числа можно складывать, используя два простых шага, без лишних операций переноса. В следующем примере складываются две цифры: 1 1 1 0 1 1 1 1 1 0 2 (958 10 ) и 1 0 1 0 1 1 0 0 1 1 2 (691 10 ), используя традиционный метод переноса слева и длинный метод переноса справа:
Традиционный метод переноски Метод длительного переноса против. 1 1 1 1 1 1 1 1 (переносимые цифры) 1 ← 1 ← переносим 1 до тех пор, пока она не окажется на одну цифру дальше «строки» ниже 1 1 1 0 1 1 1 1 1 01 1 101 1 1 1 10 вычеркните «строку»,+ 1 0 1 0 1 1 0 0 1 1 + 1 010 1 1 0 011 и вычеркните цифру, которая была к ней добавлена.——————————————————————— —————————————————————= 1 1 0 0 1 1 1 0 0 0 1 1 1 0 0 1 1 1 0 0 0 1
Верхняя строка показывает используемые биты переноса. Вместо стандартного переноса из одного столбца в другой можно добавить самую младшую «1» с «1» в соответствующем разряде под ней, и «1» можно перенести на одну цифру после конца ряда. «Использованные» числа должны быть вычеркнуты, так как они уже добавлены. Другие длинные строки также можно отменить, используя ту же технику. Затем просто сложите все оставшиеся цифры обычным образом. Продолжая таким образом, получаем окончательный ответ 1 1 0 0 1 1 1 0 0 0 1 2 (1649 10 ). В нашем простом примере с использованием небольших чисел традиционный метод переноса требовал восьми операций переноса, тогда как метод длинного переноса требовал только двух, что представляет собой существенное сокращение усилий.
Таблица двоичного сложения похожа, но не идентична таблице истинности логической операции дизъюнкции . Разница в том , что , в то время как .
Вычитание работает примерно так же:
Вычитание цифры «1» из цифры «0» дает цифру «1», тогда как 1 придется вычитать из следующего столбца. Это известно как заимствование . Принцип тот же, что и для переноса. Когда результат вычитания меньше 0, наименьшего возможного значения цифры, процедура заключается в «заимствовании» дефицита, деленного на основание (то есть 10/10) слева, вычитая его из следующего позиционного значения.
* * * * (столбцы, отмеченные звездочкой, заимствованы из) 1 1 0 1 1 1 0− 1 0 1 1 1----------------= 1 0 1 0 1 1 1
* (столбцы, отмеченные звездочкой, заимствованы из) 1 0 1 1 1 1 1– 1 0 1 0 1 1----------------= 0 1 1 0 1 0 0
Вычитание положительного числа эквивалентно сложению отрицательного числа с равным абсолютным значением . Компьютеры используют знаковые представления чисел для обработки отрицательных чисел — чаще всего это дополнение до двух . Такие представления устраняют необходимость в отдельной операции «вычитания». Используя дополнение до двух, вычитание можно суммировать следующей формулой:
Умножение в двоичной системе похоже на свое десятичное подобие. Два числа A и B можно умножить на частичные произведения: для каждой цифры в B произведение этой цифры в A вычисляется и записывается на новой строке, сдвинутой влево так, чтобы ее самая правая цифра совпадала с использованной цифрой в B. Сумма всех этих частичных произведений дает конечный результат.
Поскольку в двоичной системе всего две цифры, то возможны только два результата каждого частичного умножения:
Например, двоичные числа 1011 и 1010 умножаются следующим образом:
1 0 1 1 ( А ) × 1 0 1 0 ( Б ) --------- 0 0 0 0 ← Соответствует самому правому «нулю» в B + 1 0 1 1 ← Соответствует следующей «единице» в B + 0 0 0 0 + 1 0 1 1 --------------- = 1 1 0 1 1 1 0
Двоичные числа также можно умножать на биты после двоичной точки :
1 0 1 . 1 0 1 A (5,625 в десятичной системе) × 1 1 0 . 0 1 B (6,25 в десятичной системе) ------------------- 1 . 0 1 1 0 1 ← Соответствует «единице» в B + 0 0 . 0 0 0 0 ← Соответствует «нулю» в B + 0 0 0 . 0 0 0 + 1 0 1 1 . 0 1 + 1 0 1 1 0 . 1 --------------------------- = 1 0 0 0 1 1 . 0 0 1 0 1 (35,15625 в десятичной системе)
См. также алгоритм умножения Бута .
Двоичная таблица умножения совпадает с таблицей истинности операции логического соединения .
Длинное деление в двоичной системе счисления снова похоже на свое десятичное подобие.
В примере ниже делитель равен 101 2 , или 5 в десятичной системе счисления, а делимое равно 11011 2 , или 27 в десятичной системе счисления. Процедура та же, что и при десятичном длинном делении ; здесь делитель 101 2 входит в первые три цифры 110 2 делимого один раз, поэтому в верхней строке записывается «1». Этот результат умножается на делитель и вычитается из первых трех цифр делимого; следующая цифра («1») включается для получения новой трехзначной последовательности:
1 ___________1 0 1 ) 1 1 0 1 1 − 1 0 1 ----- 0 0 1
Затем процедура повторяется с новой последовательностью, продолжаясь до тех пор, пока не будут исчерпаны цифры делимого:
1 0 1 ___________1 0 1 ) 1 1 0 1 1 − 1 0 1 ----- 1 1 1 − 1 0 1 ----- 0 1 0
Таким образом, частное от деления 11011 2 на 101 2 равно 101 2 , как показано в верхней строке, а остаток, показанный в нижней строке, равен 10 2 . В десятичной системе это соответствует тому факту, что 27, деленное на 5, равно 5 с остатком 2.
Помимо деления в столбик, можно также разработать процедуру таким образом, чтобы обеспечить возможность избыточного вычитания из частичного остатка на каждой итерации, что приведет к альтернативным методам, которые являются менее систематическими, но в результате более гибкими.
Процесс извлечения двоичного квадратного корня цифра за цифрой такой же, как и для десятичного квадратного корня, и объясняется здесь . Пример:
1 0 0 1 --------- √ 1010001 1 --------- 101 01 0 -------- 1001 100 0 -------- 10001 10001 10001 ------- 0
Хотя это и не связано напрямую с числовой интерпретацией двоичных символов, последовательности битов могут быть обработаны с помощью булевых логических операторов . Когда строка двоичных символов обрабатывается таким образом, это называется побитовой операцией ; логические операторы AND , OR и XOR могут быть выполнены над соответствующими битами в двух двоичных числах, предоставленных в качестве входных данных. Логическая операция NOT может быть выполнена над отдельными битами в одном двоичном числе, предоставленном в качестве входных данных. Иногда такие операции могут использоваться в качестве арифметических сокращений и могут иметь и другие вычислительные преимущества. Например, арифметический сдвиг влево двоичного числа эквивалентен умножению на (положительную, целую) степень числа 2.
Чтобы преобразовать целое число с основанием 10 в его эквивалент с основанием 2 (двоичное), число делится на два . Остаток — это наименее значимый бит . Частное снова делится на два; его остаток становится следующим наименее значимым битом. Этот процесс повторяется до тех пор, пока не будет достигнуто частное, равное единице. Последовательность остатков (включая конечное частное, равное единице) образует двоичное значение, поскольку каждый остаток должен быть либо нулем, либо единицей при делении на два. Например, (357) 10 выражается как (101100101) 2. [43]
Преобразование из базы 2 в базу 10 просто инвертирует предыдущий алгоритм. Биты двоичного числа используются один за другим, начиная с самого значимого (самого левого) бита. Начиная со значения 0, предыдущее значение удваивается, а затем добавляется следующий бит для получения следующего значения. Это можно организовать в виде таблицы из нескольких столбцов. Например, чтобы преобразовать 10010101101 2 в десятичное:
Результат 1197 10 . Первое априорное значение 0 — это просто начальное десятичное значение. Этот метод — применение схемы Хорнера .
Дробные части числа преобразуются аналогичными методами. Они снова основаны на эквивалентности сдвига с удвоением или делением пополам.
В дробном двоичном числе, таком как 0,11010110101 2 , первая цифра — , вторая — и т. д. Таким образом, если на первом месте после десятичной дроби стоит 1, то число не меньше , и наоборот. Удвоение этого числа не меньше 1. Это предполагает алгоритм: многократно удваиваем преобразуемое число, записываем, если результат не меньше 1, а затем отбрасываем целую часть.
Например, в двоичном виде это:
Таким образом, повторяющаяся десятичная дробь 0, 3 ... эквивалентна повторяющейся двоичной дроби 0, 01 ... .
Или, например, 0,1 10 в двоичной системе счисления будет:
Это также повторяющаяся двоичная дробь 0,0 0011 ... . Может показаться удивительным, что конечные десятичные дроби могут иметь повторяющиеся расширения в двоичной системе. Именно по этой причине многие удивляются, обнаружив, что 1/10 + ... + 1/10 (сложение 10 чисел) отличается от 1 в двоичной арифметике с плавающей точкой . Фактически, единственные двоичные дроби с конечными расширениями имеют форму целого числа, деленного на степень 2, которой 1/10 не является.
Окончательное преобразование происходит из двоичных в десятичные дроби. Единственная сложность возникает с повторяющимися дробями, но в остальном метод заключается в том, чтобы сдвинуть дробь в целое число, преобразовать ее, как указано выше, а затем разделить на соответствующую степень двойки в десятичной системе счисления. Например:
Другой способ преобразования из двоичной системы в десятичную, часто более быстрый для человека, знакомого с шестнадцатеричной , — это сделать это косвенным образом: сначала преобразовать ( в двоичной системе) в ( в шестнадцатеричной системе), а затем преобразовать ( в шестнадцатеричной системе) в ( в десятичной системе).
Для очень больших чисел эти простые методы неэффективны, поскольку они выполняют большое количество умножений или делений, где один операнд очень большой. Простой алгоритм «разделяй и властвуй» более эффективен асимптотически: дано двоичное число, оно делится на 10 k , где k выбирается так, чтобы частное примерно равнялось остатку; затем каждая из этих частей преобразуется в десятичное, и эти две части объединяются . Десятичное число можно разделить на две части примерно одинакового размера, каждая из которых преобразуется в двоичное, после чего первая преобразованная часть умножается на 10 k и добавляется ко второй преобразованной части, где k — количество десятичных цифр во второй, наименее значимой части до преобразования.
Двоичную систему можно преобразовать в шестнадцатеричную и обратно более легко. Это связано с тем, что основание шестнадцатеричной системы (16) является степенью основания двоичной системы (2). А именно, 16 = 2 4 , поэтому для представления одной цифры шестнадцатеричной системы требуется четыре цифры двоичной системы, как показано в соседней таблице.
Чтобы преобразовать шестнадцатеричное число в его двоичный эквивалент, просто подставьте соответствующие двоичные цифры:
Чтобы преобразовать двоичное число в его шестнадцатеричный эквивалент, разделите его на группы по четыре бита. Если количество битов не кратно четырем, просто вставьте дополнительные нулевые биты слева (называется padding ). Например:
Чтобы преобразовать шестнадцатеричное число в его десятичный эквивалент, умножьте десятичный эквивалент каждой шестнадцатеричной цифры на соответствующую степень числа 16 и сложите полученные значения:
Двоичная система счисления также легко преобразуется в восьмеричную , поскольку восьмеричная использует основание 8, которое является степенью двойки (а именно, 2 3 , поэтому для представления восьмеричной цифры требуется ровно три двоичные цифры). Соответствие между восьмеричными и двоичными числами такое же, как для первых восьми цифр шестнадцатеричной системы в таблице выше. Двоичное 000 эквивалентно восьмеричной цифре 0, двоичное 111 эквивалентно восьмеричной 7 и т. д.
Преобразование из восьмеричной системы счисления в двоичную выполняется так же, как и для шестнадцатеричной :
И из двоичной системы в восьмеричную:
И из восьмеричной системы в десятичную:
Нецелые числа могут быть представлены с помощью отрицательных степеней, которые отделяются от других цифр с помощью разделительной точки (называемой десятичной точкой в десятичной системе). Например, двоичное число 11,01 2 означает:
В сумме получается 3,25 десятичных знака.
Все двоичные рациональные числа имеют конечную двоичную цифру — двоичное представление имеет конечное число членов после запятой. Другие рациональные числа имеют двоичное представление, но вместо того, чтобы заканчиваться, они повторяются , с конечной последовательностью цифр, повторяющихся бесконечно. Например
Феномен, при котором двоичное представление любого рационального числа является либо конечным, либо повторяющимся, встречается и в других системах счисления на основе оснований. См., например, объяснение в десятичной системе счисления . Другое сходство заключается в существовании альтернативных представлений для любого конечного представления, основанного на том факте, что 0,111111... является суммой геометрической прогрессии 2 −1 + 2 −2 + 2 −3 + ..., которая равна 1.
Двоичные числа, которые не заканчиваются и не повторяются, представляют иррациональные числа . Например,
сказать, что [двоичная последовательность Фуси] — это более разумный способ представления гексаграммы в виде двоичных чисел... Рассуждения, если таковые имеются, которые информируют о последовательности [царя Вэня], неизвестны.