From 8ec4ff3cd52bb4e1c6db534e2d40126b193f5175 Mon Sep 17 00:00:00 2001 From: "Quek, Yao Jing" Date: Mon, 9 Oct 2023 11:25:29 +0800 Subject: [PATCH] Add documentation and refractor variable for graytobin --- doc/binary_gray.md | 2 -- doc/components/binary_gray.md | 35 +++++++++++++++++++++++++++++++++++ test/binary_gray_test.dart | 17 ++++++++--------- 3 files changed, 43 insertions(+), 11 deletions(-) delete mode 100644 doc/binary_gray.md create mode 100644 doc/components/binary_gray.md diff --git a/doc/binary_gray.md b/doc/binary_gray.md deleted file mode 100644 index 83984d40b..000000000 --- a/doc/binary_gray.md +++ /dev/null @@ -1,2 +0,0 @@ -# Binary Gray - diff --git a/doc/components/binary_gray.md b/doc/components/binary_gray.md new file mode 100644 index 000000000..13e8e02e6 --- /dev/null +++ b/doc/components/binary_gray.md @@ -0,0 +1,35 @@ +# Binary Gray + +ROHD HCL provides a module to perform conversion on binary to gray and gray to binary. + +## Binary-to-Gray + +A fundamental digital logic operation known as binary to gray code conversion is employed in many different applications, notably in digital communication and signal processing systems. Gray code is a binary numbering system that is useful for minimizing communication channel faults because adjacent values only differ in one bit. This conversion algorithm converts a binary value into its equivalent Gray code representation from the input binary value. Each bit in the binary input is XORed with the bit before it to produce the Gray code. In order to reduce errors during signal transmission or processing, the transition between consecutive values must be as smooth as feasible in applications like rotary encoders, error correction, and circuit design. + +The [`BinaryToGrayConverter`](https://intel.github.io/rohd-hcl/rohd_hcl/BinaryToGrayConverter-class.html) module in ROHD-HCL accept a single input `binary` to be converted to gray of type `Logic`. The output value can be access via the getter `grayCode`. + +An example is shown below to convert binary to gray code. + +```dart +final binaryInput = Logic(name: 'binaryInput', width: 3)..put(bin('111')); +final binToGray = BinaryToGrayConverter(binaryInput); +await binToGray.build(); + +print(binToGray.grayCode.value.toString(includeWidth: false)); // output: 100 +``` + +## Gray-to-Binary + +The conversion of gray to binary code is an essential process in digital logic and communication systems. A binary numbering system called gray code is appropriate for use in applications where error reduction is crucial because adjacent values only differ by one bit. This conversion algorithm converts a Gray code value into its corresponding binary representation from the input. This is accomplished by computing the equivalent binary bit by XOR operations with the preceding bit after examining each bit in the Gray code, starting with the least significant bit. In many different domains, such as rotary encoders, digital signal processing, and error correction systems, it is necessary to extract precise binary representations from Gray code inputs. These applications include Gray to Binary Code Conversion. + +The [`GrayToBinary`](https://intel.github.io/rohd-hcl/rohd_hcl/GrayToBinaryConverter-class.html) module in ROHD-HCL accept a single input `gray` to be converted to binary of type `Logic`. The output value can be access via the getter `binaryVal`. + +An example is shown below to convert gray code to binary value. + +```dart +final graycode = Logic(name: 'grayCode', width: 3)..put(bin('100')); +final grayToBin = GrayToBinaryConverter(graycode); +await grayToBin.build(); + +print(grayToBin.binaryVal.value.toString(includeWidth: false)); // output: 111 +``` diff --git a/test/binary_gray_test.dart b/test/binary_gray_test.dart index 81bef3314..d2f33a95e 100644 --- a/test/binary_gray_test.dart +++ b/test/binary_gray_test.dart @@ -50,24 +50,24 @@ Future main() async { group('gray code to binary', () { test('should return 101 if gray code is 111 and width is 3.', () async { - final binaryInput = Logic(name: 'binaryInput', width: 3)..put(bin('111')); - final grayToBin = GrayToBinaryConverter(binaryInput); + final graycode = Logic(name: 'grayCode', width: 3)..put(bin('111')); + final grayToBin = GrayToBinaryConverter(graycode); await grayToBin.build(); expect(grayToBin.binaryVal.value.toString(includeWidth: false), '101'); }); test('should return 0 if gray code is 0 and width is 1.', () async { - final binaryInput = Logic(name: 'binaryInput')..put(bin('0')); - final grayToBin = GrayToBinaryConverter(binaryInput); + final grayCode = Logic(name: 'grayCode')..put(bin('0')); + final grayToBin = GrayToBinaryConverter(grayCode); await grayToBin.build(); expect(grayToBin.binaryVal.value.toInt(), 0); }); test('should return 1 if gray code is 1 and width is 1.', () async { - final binaryInput = Logic(name: 'binaryInput')..put(bin('1')); - final grayToBin = GrayToBinaryConverter(binaryInput); + final grayCode = Logic(name: 'grayCode')..put(bin('1')); + final grayToBin = GrayToBinaryConverter(grayCode); await grayToBin.build(); expect(grayToBin.binaryVal.value.toInt(), 1); @@ -75,9 +75,8 @@ Future main() async { test('should return 101011 if gray code is 111110 and width is 6.', () async { - final binaryInput = Logic(name: 'binaryInput', width: 6) - ..put(bin('111110')); - final grayToBin = GrayToBinaryConverter(binaryInput); + final grayCode = Logic(name: 'grayCode', width: 6)..put(bin('111110')); + final grayToBin = GrayToBinaryConverter(grayCode); await grayToBin.build(); expect(grayToBin.binaryVal.value.toString(includeWidth: false), '101011');