We are currently in the process of converting the website to the new design. Some pages, like this one, are still broken. We appreciate your patience.
BitwiseยปEpisode Guide
Logic Design, Part 6
?
?

Keyboard Navigation

Global Keys

[, < / ], > Jump to previous / next episode
W, K, P / S, J, N Jump to previous / next marker
t / T Toggle theatre / SUPERtheatre mode
V Revert filter to original state Y Select link (requires manual Ctrl-c)

Menu toggling

q Quotes r References f Filter y Link c Credits

In-Menu Movement

a
w
s
d
h j k l
โ†
โ†‘
โ†“
โ†’

Quotes and References Menus

Enter Jump to timecode

Quotes, References and Credits Menus

o Open URL (in new tab)

Filter Menu

x, Space Toggle category and focus next
X, ShiftSpace Toggle category and focus previous
v Invert topics / media as per focus

Filter and Link Menus

z Toggle filter / linking mode

Credits Menu

Enter Open URL (in new tab)
0:06Recap and set the stage for the day revisiting ALU before going on to shifters
๐Ÿ—ฉ
0:06Recap and set the stage for the day revisiting ALU before going on to shifters
๐Ÿ—ฉ
0:06Recap and set the stage for the day revisiting ALU before going on to shifters
๐Ÿ—ฉ
1:18Review our adders
๐Ÿ“–
1:18Review our adders
๐Ÿ“–
1:18Review our adders
๐Ÿ“–
2:37Review off-stream introduction of Kogge Stone scan
๐Ÿ“–
2:37Review off-stream introduction of Kogge Stone scan
๐Ÿ“–
2:37Review off-stream introduction of Kogge Stone scan
๐Ÿ“–
4:23Review off-stream introduction of analyze_delay()
๐Ÿ“–
4:23Review off-stream introduction of analyze_delay()
๐Ÿ“–
4:23Review off-stream introduction of analyze_delay()
๐Ÿ“–
8:04Instantiate 32-bit and 4-bit bit adders to compare their delay with the 64-bit ones
๐Ÿƒ
8:04Instantiate 32-bit and 4-bit bit adders to compare their delay with the 64-bit ones
๐Ÿƒ
8:04Instantiate 32-bit and 4-bit bit adders to compare their delay with the 64-bit ones
๐Ÿƒ
9:57Shifters
๐Ÿ—ฉ
9:57Shifters
๐Ÿ—ฉ
9:57Shifters
๐Ÿ—ฉ
12:23Set up to implement dynamic shift in terms of static shift
๐Ÿ—ฉ
12:23Set up to implement dynamic shift in terms of static shift
๐Ÿ—ฉ
12:23Set up to implement dynamic shift in terms of static shift
๐Ÿ—ฉ
13:42Introduce left_shifter()
13:42Introduce left_shifter()
13:42Introduce left_shifter()
16:50Define Example16 as a left shifter module
16:50Define Example16 as a left shifter module
16:50Define Example16 as a left shifter module
18:47Check out our left shifter graph
๐Ÿƒ
18:47Check out our left shifter graph
๐Ÿƒ
18:47Check out our left shifter graph
๐Ÿƒ
19:21Instantiate a 16-bit shifter and check out its graph
๐Ÿƒ
19:21Instantiate a 16-bit shifter and check out its graph
๐Ÿƒ
19:21Instantiate a 16-bit shifter and check out its graph
๐Ÿƒ
20:43Define Mux4 module
20:43Define Mux4 module
20:43Define Mux4 module
22:43Introduce left_shifter_radix2() and left_shifter_radix4() based on our original left_shifter()
22:43Introduce left_shifter_radix2() and left_shifter_radix4() based on our original left_shifter()
22:43Introduce left_shifter_radix2() and left_shifter_radix4() based on our original left_shifter()
25:25Define Example17 using left_shifter_radix4()
25:25Define Example17 using left_shifter_radix4()
25:25Define Example17 using left_shifter_radix4()
25:48Check out the graph to find that left_shifter_radix4() does not work
๐Ÿƒ
25:48Check out the graph to find that left_shifter_radix4() does not work
๐Ÿƒ
25:48Check out the graph to find that left_shifter_radix4() does not work
๐Ÿƒ
27:18Redefine Example17 using just mux4()
27:18Redefine Example17 using just mux4()
27:18Redefine Example17 using just mux4()
27:48Check out the mux4 graph to see that that works
๐Ÿƒ
27:48Check out the mux4 graph to see that that works
๐Ÿƒ
27:48Check out the mux4 graph to see that that works
๐Ÿƒ
28:00Fix left_shifter_radix4() to loop over the correct range
28:00Fix left_shifter_radix4() to loop over the correct range
28:00Fix left_shifter_radix4() to loop over the correct range
28:43Check out the left_shifter_radix4() graph
๐Ÿƒ
28:43Check out the left_shifter_radix4() graph
๐Ÿƒ
28:43Check out the left_shifter_radix4() graph
๐Ÿƒ
29:38Instantiate a 32-bit shifter, and enable left_shifter_radix4() to handle odd-numbered shift bits
29:38Instantiate a 32-bit shifter, and enable left_shifter_radix4() to handle odd-numbered shift bits
29:38Instantiate a 32-bit shifter, and enable left_shifter_radix4() to handle odd-numbered shift bits
31:01Check out the graph to see that it is not as expected
๐Ÿƒ
31:01Check out the graph to see that it is not as expected
๐Ÿƒ
31:01Check out the graph to see that it is not as expected
๐Ÿƒ
31:22Change left_shifter_radix4() to handle odd-numbered shift bits inside its loop
31:22Change left_shifter_radix4() to handle odd-numbered shift bits inside its loop
31:22Change left_shifter_radix4() to handle odd-numbered shift bits inside its loop
32:00Check out the graph of our 32-bit left shifter
๐Ÿƒ
32:00Check out the graph of our 32-bit left shifter
๐Ÿƒ
32:00Check out the graph of our 32-bit left shifter
๐Ÿƒ
32:32Reflect on our single logarithmic shifter, with a brief mention of linear shifters
๐Ÿ—ฉ
32:32Reflect on our single logarithmic shifter, with a brief mention of linear shifters
๐Ÿ—ฉ
32:32Reflect on our single logarithmic shifter, with a brief mention of linear shifters
๐Ÿ—ฉ
33:44Right-shifting, both logical and arithmetic
๐Ÿ—ฉ
33:44Right-shifting, both logical and arithmetic
๐Ÿ—ฉ
33:44Right-shifting, both logical and arithmetic
๐Ÿ—ฉ
35:27Q&A
๐Ÿ—ฉ
35:27Q&A
๐Ÿ—ฉ
35:27Q&A
๐Ÿ—ฉ
35:43rygorous The typical array / linear shifter layout does not have N layers. Instead you basically have N layers "deep" of tristate drivers on one long wire, and only one of them is active, the rest is Z. So that's not N layers deep of logic, basically one layer
๐Ÿ—ช
35:43rygorous The typical array / linear shifter layout does not have N layers. Instead you basically have N layers "deep" of tristate drivers on one long wire, and only one of them is active, the rest is Z. So that's not N layers deep of logic, basically one layer
๐Ÿ—ช
35:43rygorous The typical array / linear shifter layout does not have N layers. Instead you basically have N layers "deep" of tristate drivers on one long wire, and only one of them is active, the rest is Z. So that's not N layers deep of logic, basically one layer
๐Ÿ—ช
36:16Recommend Mean and Conway's 'Introduction to VLSI systems'1
๐Ÿ“–
36:16Recommend Mean and Conway's 'Introduction to VLSI systems'1
๐Ÿ“–
36:16Recommend Mean and Conway's 'Introduction to VLSI systems'1
๐Ÿ“–
37:37Introduce rotator_radix2
37:37Introduce rotator_radix2
37:37Introduce rotator_radix2
39:41Define Example18 as a left-rotator
39:41Define Example18 as a left-rotator
39:41Define Example18 as a left-rotator
40:09Instantiate a 16-bit left-rotator and check out its graph
๐Ÿƒ
40:09Instantiate a 16-bit left-rotator and check out its graph
๐Ÿƒ
40:09Instantiate a 16-bit left-rotator and check out its graph
๐Ÿƒ
41:10Rename rotator_radix2() to left_rotator_radix2() and introduce right_rotator_radix2() using it
41:10Rename rotator_radix2() to left_rotator_radix2() and introduce right_rotator_radix2() using it
41:10Rename rotator_radix2() to left_rotator_radix2() and introduce right_rotator_radix2() using it
44:15Introduce __neg__() โ€“ unary minus operator โ€“ in rattle
44:15Introduce __neg__() โ€“ unary minus operator โ€“ in rattle
44:15Introduce __neg__() โ€“ unary minus operator โ€“ in rattle
45:36Check out our right-rotator graph
๐Ÿƒ
45:36Check out our right-rotator graph
๐Ÿƒ
45:36Check out our right-rotator graph
๐Ÿƒ
46:42Introduce the notion of pre-rotation in right_rotator_radix2()
46:42Introduce the notion of pre-rotation in right_rotator_radix2()
46:42Introduce the notion of pre-rotation in right_rotator_radix2()
48:25Check out our pre-rotated right rotator graph
๐Ÿƒ
48:25Check out our pre-rotated right rotator graph
๐Ÿƒ
48:25Check out our pre-rotated right rotator graph
๐Ÿƒ
48:32Test our shifters in the simulator
๐Ÿƒ
48:32Test our shifters in the simulator
๐Ÿƒ
48:32Test our shifters in the simulator
๐Ÿƒ
50:38Test our rotators in the simulator, introducing rotl() and rotr()
๐Ÿƒ
50:38Test our rotators in the simulator, introducing rotl() and rotr()
๐Ÿƒ
50:38Test our rotators in the simulator, introducing rotl() and rotr()
๐Ÿƒ
53:37All the tests passed at the first try
๐Ÿ—ฉ
53:37All the tests passed at the first try
๐Ÿ—ฉ
53:37All the tests passed at the first try
๐Ÿ—ฉ
54:43rygorous pervognsen Probably want to mask both sides for rotl() / rotr() so it works with signed values
๐Ÿ—ช
54:43rygorous pervognsen Probably want to mask both sides for rotl() / rotr() so it works with signed values
๐Ÿ—ช
54:43rygorous pervognsen Probably want to mask both sides for rotl() / rotr() so it works with signed values
๐Ÿ—ช
54:47Enable rotl() and rotr() to work with signed values
54:47Enable rotl() and rotr() to work with signed values
54:47Enable rotl() and rotr() to work with signed values
55:02Set up to create our first combined design: Barrel shifter
๐Ÿ—ฉ
55:02Set up to create our first combined design: Barrel shifter
๐Ÿ—ฉ
55:02Set up to create our first combined design: Barrel shifter
๐Ÿ—ฉ
56:32Introduce barrel_left_shifter()
56:32Introduce barrel_left_shifter()
56:32Introduce barrel_left_shifter()
59:54Define Example20 as a left barrel shifter
59:54Define Example20 as a left barrel shifter
59:54Define Example20 as a left barrel shifter
1:00:37Simulate the left barrel shifter and fail the verification test
๐Ÿƒ
1:00:37Simulate the left barrel shifter and fail the verification test
๐Ÿƒ
1:00:37Simulate the left barrel shifter and fail the verification test
๐Ÿƒ
1:01:22Fix missing comma in binary_ops
1:01:22Fix missing comma in binary_ops
1:01:22Fix missing comma in binary_ops
1:01:48Test the correct module in Example20, and simulate it to find that it passes
๐Ÿƒ
1:01:48Test the correct module in Example20, and simulate it to find that it passes
๐Ÿƒ
1:01:48Test the correct module in Example20, and simulate it to find that it passes
๐Ÿƒ
1:02:25miotatsu Wow, that implicit string concatenation there is nasty
๐Ÿ—ช
1:02:25miotatsu Wow, that implicit string concatenation there is nasty
๐Ÿ—ช
1:02:25miotatsu Wow, that implicit string concatenation there is nasty
๐Ÿ—ช
1:02:33Introduce barrel_right_shifter()
1:02:33Introduce barrel_right_shifter()
1:02:33Introduce barrel_right_shifter()
1:05:15Explain inference of literal types
๐Ÿ—ฉ
1:05:15Explain inference of literal types
๐Ÿ—ฉ
1:05:15Explain inference of literal types
๐Ÿ—ฉ
1:06:04Define Example21 as a right barrel shifter
1:06:04Define Example21 as a right barrel shifter
1:06:04Define Example21 as a right barrel shifter
1:06:32Simulate the right barrel shifter, fail the test and investigate why
๐Ÿƒ
1:06:32Simulate the right barrel shifter, fail the test and investigate why
๐Ÿƒ
1:06:32Simulate the right barrel shifter, fail the test and investigate why
๐Ÿƒ
1:14:49nothings2 How is it that the outer assertion has access to 'mask'? Is this a weird pythonism?
๐Ÿ—ช
1:14:49nothings2 How is it that the outer assertion has access to 'mask'? Is this a weird pythonism?
๐Ÿ—ช
1:14:49nothings2 How is it that the outer assertion has access to 'mask'? Is this a weird pythonism?
๐Ÿ—ช
1:15:04Print the mask of barrel_right_shifter()
1:15:04Print the mask of barrel_right_shifter()
1:15:04Print the mask of barrel_right_shifter()
1:16:13Run it and check out the mask
๐Ÿƒ
1:16:13Run it and check out the mask
๐Ÿƒ
1:16:13Run it and check out the mask
๐Ÿƒ
1:16:56Fix the mask computation in barrel_right_shifter()
1:16:56Fix the mask computation in barrel_right_shifter()
1:16:56Fix the mask computation in barrel_right_shifter()
1:17:11Simulate the right barrel shifter and pass the test
๐Ÿƒ
1:17:11Simulate the right barrel shifter and pass the test
๐Ÿƒ
1:17:11Simulate the right barrel shifter and pass the test
๐Ÿƒ
1:17:19Remove the mask printout
1:17:19Remove the mask printout
1:17:19Remove the mask printout
1:18:11Simulate it, pass the test and reflect on the right barrel shifter
๐Ÿƒ
1:18:11Simulate it, pass the test and reflect on the right barrel shifter
๐Ÿƒ
1:18:11Simulate it, pass the test and reflect on the right barrel shifter
๐Ÿƒ
1:19:06Introduce barrel_arithmetic_right_shifter()
1:19:06Introduce barrel_arithmetic_right_shifter()
1:19:06Introduce barrel_arithmetic_right_shifter()
1:22:02rygorous pervognsen Don't you really need a mux? Since you need to either clear or set the upper bits, neither AND nor OR by itself can work
๐Ÿ—ช
1:22:02rygorous pervognsen Don't you really need a mux? Since you need to either clear or set the upper bits, neither AND nor OR by itself can work
๐Ÿ—ช
1:22:02rygorous pervognsen Don't you really need a mux? Since you need to either clear or set the upper bits, neither AND nor OR by itself can work
๐Ÿ—ช
1:22:32Enable barrel_arithmetic_right_shifter() to mux between clearing and setting the upper bits
1:22:32Enable barrel_arithmetic_right_shifter() to mux between clearing and setting the upper bits
1:22:32Enable barrel_arithmetic_right_shifter() to mux between clearing and setting the upper bits
1:24:54Simulate the barrel_arithmetic_right_shifter() on a signed input to find that it works
๐Ÿƒ
1:24:54Simulate the barrel_arithmetic_right_shifter() on a signed input to find that it works
๐Ÿƒ
1:24:54Simulate the barrel_arithmetic_right_shifter() on a signed input to find that it works
๐Ÿƒ
1:25:04Introduce barrel_shifter() as our first combined design
1:25:04Introduce barrel_shifter() as our first combined design
1:25:04Introduce barrel_shifter() as our first combined design
1:35:34Define Example23 as a unified barrel shifter
1:35:34Define Example23 as a unified barrel shifter
1:35:34Define Example23 as a unified barrel shifter
1:37:26Simulate our unified barrel shifter on left- and right-rotations and left-shift, to find that they all work
๐Ÿƒ
๐Ÿ–ฎ
1:37:26Simulate our unified barrel shifter on left- and right-rotations and left-shift, to find that they all work
๐Ÿƒ
๐Ÿ–ฎ
1:37:26Simulate our unified barrel shifter on left- and right-rotations and left-shift, to find that they all work
๐Ÿƒ
๐Ÿ–ฎ
1:40:06Simulate right-shift to find that it doesn't work, and investigate why
๐Ÿƒ
1:40:06Simulate right-shift to find that it doesn't work, and investigate why
๐Ÿƒ
1:40:06Simulate right-shift to find that it doesn't work, and investigate why
๐Ÿƒ
1:42:00Print the mask of barrel_shifter()
1:42:00Print the mask of barrel_shifter()
1:42:00Print the mask of barrel_shifter()
1:42:55rygorous pervognsen But now you're passing in ~n (from the first mux) when dir=1
๐Ÿ—ช
1:42:55rygorous pervognsen But now you're passing in ~n (from the first mux) when dir=1
๐Ÿ—ช
1:42:55rygorous pervognsen But now you're passing in ~n (from the first mux) when dir=1
๐Ÿ—ช
1:43:05Enable barrel_shifter() to correctly perform right-shift
1:43:05Enable barrel_shifter() to correctly perform right-shift
1:43:05Enable barrel_shifter() to correctly perform right-shift
1:43:44Simulate the barrel shifter on right-shift, and pass the test
๐Ÿƒ
1:43:44Simulate the barrel shifter on right-shift, and pass the test
๐Ÿƒ
1:43:44Simulate the barrel shifter on right-shift, and pass the test
๐Ÿƒ
1:44:05Simulate the barrel shifter on arithmetic shift, and pass
๐Ÿƒ
1:44:05Simulate the barrel shifter on arithmetic shift, and pass
๐Ÿƒ
1:44:05Simulate the barrel shifter on arithmetic shift, and pass
๐Ÿƒ
1:44:40rygorous pervognsen Basically, for the rotate case, just force mask to all-1s and delete the output mux
๐Ÿ—ช
1:44:40rygorous pervognsen Basically, for the rotate case, just force mask to all-1s and delete the output mux
๐Ÿ—ช
1:44:40rygorous pervognsen Basically, for the rotate case, just force mask to all-1s and delete the output mux
๐Ÿ—ช
1:44:48Change barrel_shifter() to force the mask to all 1s and delete the output mux in the rotate case
1:44:48Change barrel_shifter() to force the mask to all 1s and delete the output mux in the rotate case
1:44:48Change barrel_shifter() to force the mask to all 1s and delete the output mux in the rotate case
1:45:46Simulate it to find that it works
๐Ÿƒ
1:45:46Simulate it to find that it works
๐Ÿƒ
1:45:46Simulate it to find that it works
๐Ÿƒ
1:46:09Introduce left_rotator_radix4()
1:46:09Introduce left_rotator_radix4()
1:46:09Introduce left_rotator_radix4()
1:50:03Check out the left_rotator_radix4 graph to see that it looks reasonable
๐Ÿƒ
1:50:03Check out the left_rotator_radix4 graph to see that it looks reasonable
๐Ÿƒ
1:50:03Check out the left_rotator_radix4 graph to see that it looks reasonable
๐Ÿƒ
1:50:33Instantiate an 8-bit rotator and check out its graph
๐Ÿƒ
1:50:33Instantiate an 8-bit rotator and check out its graph
๐Ÿƒ
1:50:33Instantiate an 8-bit rotator and check out its graph
๐Ÿƒ
1:52:10Test barrel_shifter() using both left_rotator_radix2() and left_rotator_radix4() to see that it works
๐Ÿƒ
๐Ÿ–ฎ
1:52:10Test barrel_shifter() using both left_rotator_radix2() and left_rotator_radix4() to see that it works
๐Ÿƒ
๐Ÿ–ฎ
1:52:10Test barrel_shifter() using both left_rotator_radix2() and left_rotator_radix4() to see that it works
๐Ÿƒ
๐Ÿ–ฎ
1:53:03Check out the graph of our unified barrel shifter
๐Ÿƒ
1:53:03Check out the graph of our unified barrel shifter
๐Ÿƒ
1:53:03Check out the graph of our unified barrel shifter
๐Ÿƒ
1:53:20rygorous pervognsen Why m1, m2, m3 and not m,2*m,3*m?
๐Ÿ—ช
1:53:20rygorous pervognsen Why m1, m2, m3 and not m,2*m,3*m?
๐Ÿ—ช
1:53:20rygorous pervognsen Why m1, m2, m3 and not m,2*m,3*m?
๐Ÿ—ช
1:53:26Rewrite left_rotator_radix4() as per rygorous's suggestion
1:53:26Rewrite left_rotator_radix4() as per rygorous's suggestion
1:53:26Rewrite left_rotator_radix4() as per rygorous's suggestion
1:53:55Consult the graph of our unified barrel shifter
๐Ÿƒ
1:53:55Consult the graph of our unified barrel shifter
๐Ÿƒ
1:53:55Consult the graph of our unified barrel shifter
๐Ÿƒ
1:54:34Instantiate a 16-bit barrel shifter and check out its graph, noting the importance of the mask being off the critical path
๐Ÿƒ
1:54:34Instantiate a 16-bit barrel shifter and check out its graph, noting the importance of the mask being off the critical path
๐Ÿƒ
1:54:34Instantiate a 16-bit barrel shifter and check out its graph, noting the importance of the mask being off the critical path
๐Ÿƒ
1:57:54rygorous pervognsen Other things: 1. Bit-reversal shifters! 2. Funnel shifters!
๐Ÿ—ช
1:57:54rygorous pervognsen Other things: 1. Bit-reversal shifters! 2. Funnel shifters!
๐Ÿ—ช
1:57:54rygorous pervognsen Other things: 1. Bit-reversal shifters! 2. Funnel shifters!
๐Ÿ—ช
1:58:02Funnel shifters
๐Ÿ—ฉ
1:58:02Funnel shifters
๐Ÿ—ฉ
1:58:02Funnel shifters
๐Ÿ—ฉ
2:02:30Introduce double_width_shifter() as a funnel shifter
2:02:30Introduce double_width_shifter() as a funnel shifter
2:02:30Introduce double_width_shifter() as a funnel shifter
2:06:15Define Example24 as a funnel shifter
2:06:15Define Example24 as a funnel shifter
2:06:15Define Example24 as a funnel shifter
2:07:09Instantiate a 16-bit funnel shifter and check out its graph, to see that it is off-by-one
๐Ÿƒ
2:07:09Instantiate a 16-bit funnel shifter and check out its graph, to see that it is off-by-one
๐Ÿƒ
2:07:09Instantiate a 16-bit funnel shifter and check out its graph, to see that it is off-by-one
๐Ÿƒ
2:10:21Shrink the x input of our funnel shifter by one bit
2:10:21Shrink the x input of our funnel shifter by one bit
2:10:21Shrink the x input of our funnel shifter by one bit
2:10:38Check out our funnel shifter graph to see that it looks good
๐Ÿƒ
2:10:38Check out our funnel shifter graph to see that it looks good
๐Ÿƒ
2:10:38Check out our funnel shifter graph to see that it looks good
๐Ÿƒ
2:10:50Rename double_width_shifter() to funnel_shifter()
2:10:50Rename double_width_shifter() to funnel_shifter()
2:10:50Rename double_width_shifter() to funnel_shifter()
2:11:17Create a test of our funnel shifter
2:11:17Create a test of our funnel shifter
2:11:17Create a test of our funnel shifter
2:13:48Simulate a 16-bit and 4-bit funnel shifter to see that it passes
๐Ÿƒ
2:13:48Simulate a 16-bit and 4-bit funnel shifter to see that it passes
๐Ÿƒ
2:13:48Simulate a 16-bit and 4-bit funnel shifter to see that it passes
๐Ÿƒ
2:14:17Introduce funnel_right_shifter()
2:14:17Introduce funnel_right_shifter()
2:14:17Introduce funnel_right_shifter()
2:16:33Simulate a funnel right shifter to see that it passes
๐Ÿƒ
2:16:33Simulate a funnel right shifter to see that it passes
๐Ÿƒ
2:16:33Simulate a funnel right shifter to see that it passes
๐Ÿƒ
2:16:59Introduce funnel_left_shifter()
2:16:59Introduce funnel_left_shifter()
2:16:59Introduce funnel_left_shifter()
2:18:19rygorous pervognsen You need to be careful with the opposite-direction shifts later (so if you do a right shift funnel, look at the left shift)
๐Ÿ—ช
2:18:19rygorous pervognsen You need to be careful with the opposite-direction shifts later (so if you do a right shift funnel, look at the left shift)
๐Ÿ—ช
2:18:19rygorous pervognsen You need to be careful with the opposite-direction shifts later (so if you do a right shift funnel, look at the left shift)
๐Ÿ—ช
2:18:33Simulate a funnel left shifter to see that it fails
๐Ÿƒ
2:18:33Simulate a funnel left shifter to see that it fails
๐Ÿƒ
2:18:33Simulate a funnel left shifter to see that it fails
๐Ÿƒ
2:19:40Fix funnel_left_shifter()
2:19:40Fix funnel_left_shifter()
2:19:40Fix funnel_left_shifter()
2:20:06Introduce funnel_arithmetic_right_shifter()
2:20:06Introduce funnel_arithmetic_right_shifter()
2:20:06Introduce funnel_arithmetic_right_shifter()
2:21:44Simulate the funnel arithmetic right shifter, fail the test and investigate why
๐Ÿƒ
2:21:44Simulate the funnel arithmetic right shifter, fail the test and investigate why
๐Ÿƒ
2:21:44Simulate the funnel arithmetic right shifter, fail the test and investigate why
๐Ÿƒ
2:25:31Make funnel_arithmetic_right_shifter() use rep()
2:25:31Make funnel_arithmetic_right_shifter() use rep()
2:25:31Make funnel_arithmetic_right_shifter() use rep()
2:25:44Simulate the funnel arithmetic right shifter and pass the test
๐Ÿƒ
2:25:44Simulate the funnel arithmetic right shifter and pass the test
๐Ÿƒ
2:25:44Simulate the funnel arithmetic right shifter and pass the test
๐Ÿƒ
2:26:33Introduce funnel_right_rotator()
2:26:33Introduce funnel_right_rotator()
2:26:33Introduce funnel_right_rotator()
2:27:48Simulate the funnel right rotator successfully
๐Ÿƒ
2:27:48Simulate the funnel right rotator successfully
๐Ÿƒ
2:27:48Simulate the funnel right rotator successfully
๐Ÿƒ
2:27:54Introduce funnel_left_rotator()
2:27:54Introduce funnel_left_rotator()
2:27:54Introduce funnel_left_rotator()
2:28:35Simulate the funnel left rotator and fail the test
๐Ÿƒ
2:28:35Simulate the funnel left rotator and fail the test
๐Ÿƒ
2:28:35Simulate the funnel left rotator and fail the test
๐Ÿƒ
2:28:54rygorous pervognsen I think x[1:], but yeah
๐Ÿ—ช
2:28:54rygorous pervognsen I think x[1:], but yeah
๐Ÿ—ช
2:28:54rygorous pervognsen I think x[1:], but yeah
๐Ÿ—ช
2:29:03Fix funnel_left_rotator() to slice off the correct bit
2:29:03Fix funnel_left_rotator() to slice off the correct bit
2:29:03Fix funnel_left_rotator() to slice off the correct bit
2:29:09Simulate the funnel left rotator successfully
๐Ÿƒ
2:29:09Simulate the funnel left rotator successfully
๐Ÿƒ
2:29:09Simulate the funnel left rotator successfully
๐Ÿƒ
2:29:17Introduce funnel_shifter_unit() as a combined design
2:29:17Introduce funnel_shifter_unit() as a combined design
2:29:17Introduce funnel_shifter_unit() as a combined design
2:31:15rygorous pervognsen You probably want to cut the slices into three pieces: hi 31, middle, lo 31. That way each of the pieces needs fewer options (instead of having a big full-width mux)
๐Ÿ—ช
2:31:15rygorous pervognsen You probably want to cut the slices into three pieces: hi 31, middle, lo 31. That way each of the pieces needs fewer options (instead of having a big full-width mux)
๐Ÿ—ช
2:31:15rygorous pervognsen You probably want to cut the slices into three pieces: hi 31, middle, lo 31. That way each of the pieces needs fewer options (instead of having a big full-width mux)
๐Ÿ—ช
2:31:27Q&A
๐Ÿ—ฉ
2:31:27Q&A
๐Ÿ—ฉ
2:31:27Q&A
๐Ÿ—ฉ
2:32:09tw0st3p Question for an after hours stream: Have you heard of Julia language?
๐Ÿ—ช
2:32:09tw0st3p Question for an after hours stream: Have you heard of Julia language?
๐Ÿ—ช
2:32:09tw0st3p Question for an after hours stream: Have you heard of Julia language?
๐Ÿ—ช
2:32:50Try to time the performance of our barrel shifter, modifying get_operator_delay() to handle the necessary operators
2:32:50Try to time the performance of our barrel shifter, modifying get_operator_delay() to handle the necessary operators
2:32:50Try to time the performance of our barrel shifter, modifying get_operator_delay() to handle the necessary operators
2:34:38Check out the delay of our barrel shifter
๐Ÿƒ
2:34:38Check out the delay of our barrel shifter
๐Ÿƒ
2:34:38Check out the delay of our barrel shifter
๐Ÿƒ
2:35:38Call it a day
๐Ÿ—ฉ
2:35:38Call it a day
๐Ÿ—ฉ
2:35:38Call it a day
๐Ÿ—ฉ