Efetuando Subtração Binária com Complemento de 1 – Eletrônica Digital
Subtração Binária com Complemento de 1
Na lição anterior aprendemos a calcular o resultado de uma subtração binária usando bits de borrow. Agora, vamos mostrar uma outra técnica para realização de subtração entre números binários, denominada Subtração com Complemento de 1, que é uma técnica utilizada pelos computadores para realizar esse tipo de cálculo.
Para humanos, a subtração usando o método do borrow é mais simples, mas certamente é de valia conhecer outros métodos também, especialmente para quem trabalha com projetos de lógica digital ou programação de computadores.
O complemento de 1 de um bit é o seu inverso (o de 1 é 0 e o de 0 é 1). Podemos usar esse complemento de 1 para efetuar uma subtração binária, de acordo com o procedimento a seguir:
- Iguale o número de casas binárias dos números envolvidos no cálculo, acrescentando zeros à esquerda se necessário. Obtenha o complemento de 1 do subtraendo (número que será subtraído do minuendo; “número de baixo”)
- Some o complemento de 1 obtido no passo a) ao minuendo (número “de cima” no cálculo)
- Se o número estourar (ultrapassar o número de casas binárias dos valores envolvidos na subtração), a resposta será um valor positivo. Somamos então o estouro ao LSB (bit menos significativo) do resultado do passo b). Chamamos essa operação de EAC (End-Around-Carry / vai-um final ao redor). Caso não haja estouro, simplesmente aplique o complemento de 1 neste resultado, e o valor obtido será um número negativo.
Vejamos um exemplo de subtração binária usando esta técnica:
Exemplo 01: Efetue o cálculo de 110012 – 100012, usando o complemento de um.
Resolução:
Resultado: 110012 – 100012 = 10002
Exemplo 02: Calcule 10112 – 1012:
Resolução:
Igualamos o número de casas binárias dos números acrescentando um zero ao 1012:
Resultado: 10112 – 1012 = 1102
Exemplo 03: Efetuar 1012 – 110002 usando o complemento de um.
Resolução: Note que neste exemplo o segundo número (subtraendo) é menor do que o primeiro (minuendo) na subtração, de forma que o resultado deve ser um valor negativo.
Neste caso obtivemos um número negativo. O valor real do número será dado pelo complemento de 1 do resultado anterior, incluindo o bit de estouro:
Resultado: 1012 – 110002 = -100112 (-1910)
É isso aí! Na próxima parte de nossa lição sobre subtração de números binários, vamos apresentar a subtração usando a técnica do complemento de 2.
Escreva um comentário