我需要只使用NAND端口x xor(y xor z)
。
符号:NOT(y)= ~y。
我的第一步是识别那些东西的输出,所以:
x xor(y xor z) = x xor (y~z + ~yz) = ~x(y~z + ~yz) + x~(y~z + ~yz) = ~xy~z + ~x~yz + x~y~z + xyz
所以我的NAND构造的最终输出应该是:~xy~z + ~x~yz + x~y~z + xyz
我试图通过首先制作y XOR z来攻击这个:
y XOR z = y~z + ~yz = NAND[NAND(y,NAND(z,z)),NAND(z,NAND(y,y))]
自
NAND(y,NAND(z,z)) = NOT(y * NOT(z*z)) = NOT(y) + z
我打电话给 g1 和
NAND(z,NAND(y,y)) = NOT(z * NOT(y*y)) = NOT(z) + y
为 g2
然后外部NAND [g1,g2] = z~y + y~z。
所以现在我只有NAND的XOR并且x xor (y xor z)
应该只是将(y xor z)作为单个变量处理,这给了我:
x xor (y xor z) = NAND[NAND(x,NAND(NAND[NAND(y,NAND(z,z)),NAND(z,NAND(y,y))],NAND[NAND(y,NAND(z,z)),NAND(z,NAND(y,y))])),NAND(NAND[NAND(y,NAND(z,z)),NAND(z,NAND(y,y))],NAND(x,x))]
我说错了吗?我觉得xor可以比使用5个NAND端口更有效。
谢谢你们。