Annotate bitwise047

This commit is contained in:
Matt Mascarenhas 2018-07-07 19:04:29 +01:00
parent b2026babd9
commit 82fd07025c
1 changed files with 51 additions and 2 deletions

View File

@ -1,2 +1,51 @@
[video member=pervognsen stream_platform=twitch project=bitwise title="Domain-Specific Languages In Python, Part 5" vod_platform=youtube id=cyVFbdW2Qjw annotator=] [video member=pervognsen stream_platform=twitch project=bitwise title="Domain-Specific Languages In Python, Part 5" vod_platform=youtube id=cyVFbdW2Qjw annotator=Miblo]
[/video] [0:06][Recap and set the stage for the final stream in this portion of the series][:speech]
[0:57][Review newly added optional display of types and labelling of nodes to our DotGenerator][:language :research]
[4:19][Review our new parity() circuit][:language :research]
[5:46][Introduce parity2() as a naive way to XOR a collection of bits][:language]
[7:46][:Run it to see our graph for parity2()][:"debug visualisation" :language]
[9:43][:Run it on the original parity() to see our graph with logarithmic depth][:"debug visualisation" :language]
[12:52][:Run it on LinearXorScanner8 and explain our graph for this][:"debug visualisation" :language]
[17:56][Compare the LinearXorScanner8 graph with that for Parity8][:"debug visualisation" :language :run]
[18:35][:Run it on LogarithmicXorScanner8 and explain our graph for this][:"debug visualisation" :language]
[19:55][Walk through parity(), scan() and scan2(), with a mention of the Brent-Kung adder[ref
site=Wikipedia
page="BrentKung adder"
url=https://en.wikipedia.org/wiki/Brent%E2%80%93Kung_adder]][:language :research]
[26:38][Highlight the skewed fanout in our LogarithmicXorScanner8][:"debug visualisation" :language :run]
[28:00][Generate a 32-bit LogarithmicXorScanner8 circuit and check out the skewed fanout in its graph][:"debug visualisation" :language :run]
[29:39][Consider expanding our vocabulary with when() and case(), and optimising our graph visualisation][:"debug visualisation" :language :speech]
[32:46][Flattening graph slices by short-circuiting the second level of a slice-of-a-slice][:"debug visualisation" :language :speech]
[34:58][Enable IndexNode to flatten slices][:"debug visualisation" :language]
[36:21][:Run it to see that there might be a bug][:"debug visualisation" :language]
[37:55][Step in to IndexNode and inspect the data][:"debug visualisation" :language :run]
[39:00][Fix IndexNode to correctly flatten slices][:"debug visualisation" :language]
[39:38][:Run it to see that it looks better][:"debug visualisation" :language]
[39:47][Enable SliceNode to flatten slices of slices][:"debug visualisation" :language]
[40:30][:Run it to see our flattened slices of slices, and consider short-circuiting indexing into concatenations][:"debug visualisation" :language]
[41:46][Loft out the construction part of IndexNode and SliceNode to make_index() and make_slice() respectively][:"debug visualisation" :language]
[47:45][:Run it to see the same stuff we had before][:"debug visualisation" :language]
[47:53][Enable make_index() to short-circuit ConcatNode indexing][:"debug visualisation" :language]
[50:59][:Run it to see that some of it looks dubious][:"debug visualisation" :language]
[51:59][Consider our previous graph without short-circuiting of concatenation indexing][:"debug visualisation" :language :run]
[52:34][Continue to investigate why our concatenation indexing doesn't always get flattened][:"debug visualisation" :language :research]
[59:12][Enable make_index() to recursively apply flattening to ConcatNodes][:"debug visualisation" :language :run]
[1:00:19][:Run it to see exactly what we wanted to see][:"debug visualisation" :language]
[1:01:18][Check out the fanout in a 32-bit LogarithmicXorScanner8 circuit][:"debug visualisation" :language :run]
[1:04:15][Incorporating registers, in the context of a Counter module][:hardware :memory :speech :timing]
[1:09:34][Introduce RegisterNode][:"debug visualisation" :language]
[1:13:36][Introduce Counter module][:language]
[1:14:28][:Run it to see our Counter circuit][:"debug visualisation" :language]
[1:15:00][Add a value to the RegisterNode()][:"debug visualisation" :language]
[1:15:11][:Run it to see our Counter circuit][:"debug visualisation" :language]
[1:15:51][Define __add__ and __radd__ operands for our Counter module to use][:language :mathematics]
[1:16:47][:Run it to see our Counter circuit, with a cycle][:"debug visualisation" :language]
[1:17:07][Add an increment input to our Counter module][:"debug visualisation" :language]
[1:17:30][:Run it to see the terrible layout of our Counter circuit][:"debug visualisation" :language]
[1:18:10][Change the inc input in our Counter module to an enable input which controls the count via a (newly introduced) WhenNode][:"debug visualisation" :language]
[1:25:34][:Run it see our Counter circuit with conditional operation][:"debug visualisation" :language]
[1:26:55][A few words on flipflop enables][:hardware :speech]
[1:27:58][Change our Counter module to contain a D-flipflop with builtin enable][:"debug visualisation" :language]
[1:29:26][:Run it to see this Counter module][:"debug visualisation" :language]
[1:29:43][That's probably enough, with a glimpse into next week's ordered introduction to :hardware][:speech]
[/video]