Bill's Computer Circus
Don't get caught with your system down.
NOTICE: This web site may not render correctly in older browers like
Internet Explorer 5.2 for the Mac. May the gods help you if you are
using Internet Explorer on any machine! Otherwise, if this site does
not look right on your browser, please let me know what browser you
are using (and what version and on what computer). Thanks!
"Visual Basic makes the easy things easier. Delphi makes the hard things easy." -- unknown |
||
|
Monday, July 19, 2004
I'm afraid to look. I was up a little after 2:00 a.m. this morning when the power went out. I was really mad, because I had been typing an entry into this 'blog for about an hour, and was about two minutes away from saving it.
I really (key word here: REALLY) don't like living in this area. I have seen more power outages since I moved here four years ago than I ever did growing up in Tucson, Arizona. At least in Tucson, the power would go out for a reason (thunderstorms, drivers mating with power poles, etc.). But out here, the power just seems to quit because it feels like it. Maybe it's tired. Anyway, I will try to recapture the 'blog entry that I tried to post this morning. I haven't checked to see if I have lost anything else, yet - I haven't gotten up the nerve. OK, maybe I will check now. Whew! I didn't lose any work! I would have been a little pissed if I had lost work, especially considering what I have accomplished over the past two or three days. I feel like I have created a whole new science. Well, I know it's not new - in fact, I have probably re-invented a couple of wheels. But it's just like me to re-invent wheels, because I am always hopeful that I will see something that the original creator missed along the way and wind up with a better wheel. Mostly, I just wind up wasting my time (although I do learn a lot in the process). It all started with the one last critical issue on my issues list for my RC4 device. In the process of trying to determine where the problem was and how to fix it, I noticed some abnormal behavior on an unrelated issue. So, before I knew it, my issues list expanded to two items. I decided to tackle this new item, first, because I thought it would be easier. HA HA HA HA HA HA HA HA HA HA HAAAAAAAAAA!!!!! Don't make me cry. It is interesting that I had been thinking about bits and Boolean logic, etc., a couple of days before this new issue popped up - it is as if I somehow knew what was coming. During the course of RC4's development, I have not created a concise reference document that consolidates all the features into one quick-reference chart. Due to feature creep, this information was not known, fully, at design time, so new conditions and new modes have been added along the way. I had failed at previous attempts to create a table listing all of the possibilities, but now it appeared it was something I had to do in order to make progress on this issue. So, I set out to reverse engineer my own creation, and now I have a better and clearer perspective on this thing than I ever have before. It became important to attain this clarity, because there is one key routine at the very heart of RC4 that determines how the device behaves depending on current conditions. There is one of eight possible base modes of operation that RC4 can be set to at any given time (R/C, R/C Fixed, R/C FailSafe, R/C Presets, Command, Command Override, Command FailSafe and Command Protected). If you want to know more about what these modes are and what they mean, you can read all the gory details in the online docs for Revision F on the web site. Each of these eight modes are augmented by the state of other features of the device, including the Fail-Safe mechanism, whether or not signal is currently detected, and whether noise rejection is enabled. Depending on these conditions, RC4 selects one of four tables as its source for input signal data. In fact, that is the sole function of this one key routine - to select the proper signal table based on current conditions. In all, there are six bits that describe the possible states in question at any given time. Therefore, there are 64 unique conditions, and the proper signal source table had to be selected for each of those conditions. The code that was in place worked except for one or two conditions. After attaining this new perspective, I was amazed it was working as well as it was - I had done a good job of distilling the code down to a bare minimum without the help of a truth table. But without a truth table, it was a nightmare to try to figure out how to change the code to pick up that last incorrect state. And three attempts to change the code, failed. So I embarked into the world of Boolean Algebra. My skills were rusty and weak, but I dove right in. I created a truth table with 64 "input" bits and four "output" bits to represent the logic needed for a fully functional routine. But in my efforts to simplify the resulting Boolean equations, I kept making mistakes and after a few tries, still did not have the correct equations. So then I began to study the bits to see if there was some way I could distill the table down to a simplified form without the use of Boolean Algebra. This is where the [re-]invention of the wheel began. I don't know if I have re-invented a wheel here or not or if my algorithm is unique, but after a few false starts and dead ends, I began to feel as if I was just wasting my time again. But I eventually stumbled onto an approach along the way that led to success! I now have a working algorithm (and some Delphi code) that will take a truth table and spit out the simplified Boolean equation(s) that describe it. I call it the "Bit Sifter." It works with any number of inputs and outputs (though currently with a 32-bit limit). I was able to use a couple of tricks the greater simply my immediate problem, which helped tremendously. First, two of the signal tables that RC4 chooses from are kind of shadows of each other, so I reduced the truth table output possibilities from four to three, as there was only one simple condition to check afterward to see if the selected signal table really needed to be the other signal table (otherwise, I actually would have needed to add a seventh input, with 128 possible permutations). The other trick was based on the fact that the outputs of the truth table were exclusive - in other words, only one output was selected for any given input - and the fact that EVERY input condition resulted in an output. This enabled me to solve for two outputs, only, because if neither of the two produced an output, I could deduce that the third output must be the chosen one (essentially tying the two outputs to a NOR gate to get the third output). Therefore, I was able to pick the two simplest Boolean equations and model the code after them, leaving the third output condition as the default selection. As a result of all my hard work, I was able to distill this truth table down to 25 instructions in the microcontroller code. It is amazing to me that 64 possible conditions with four possible outputs can be represented by only 25 lines of code! Not just 25 lines of code, but 25 INSTRUCTIONS! I am now looking at the possibility of having this algorithm spit out optimized microcontroller code as well - something that I believe could be adapted to spit out code for any language, even Verilog or VHDL, or even spit out a schematic of logic gates. I am also looking for ways to improve the algorithm to determine the absolute simplest Boolean equation (I am exploring if there are conditions where a false table with an inverted output may produce a more simplified equation - you know, the other side of the bit, like I mentioned in an earlier 'blog entry). Anyway, it is a whole new arena to explore. When I first learned Boolean Algebra so many years ago, I wanted to write software that would reduce the equations to their simplest form, but I just was never able to figure it out. And now I have it! I just wonder if maybe there is some way to make some money here. Perhaps a little utility to assist designers (hobbiests?) in hardware design, especially with the rising popularity of FPGAs (now that they're starting to become affordable to hobbiests). Well, it's cool, and I'm happy. Now I just need to assemble my code and see if it actually works. I haven't done that, yet. But I am confident that it will work. At least, it will work according to the truth table I put togheter - this much I know. And if the truth table is wrong, at least now I have the tools to help me fix it! YIPPIE! I thought it might be interesting to show the code that resulted from this, so here it is: MOVLW ITABLE ; Default = ITABLE The nomenclature in the comments is something I created to help me keep understand what is going on. The letters (A through F) represent the six inputs to the truth table, and the + and - indicates which branch of the decision tree the code is following. Where I have indicated a letter with no + or -, the instruction is testing the input that is represented by that letter. By the way, only the code needed to select the proper table is shown here - the branch to STOEX saves the selection into a register and returns to the caller...just in case you were wondering. The point here is not to understand my work, but to show the small size of the code that resulted in my efforts. For what it's worth. "ITABLE" and "PTABLE" are those shadow input tables I mentioned, so the last test in the code checks to see if the ITABLE selection really needs to be PTABLE. That was the seventh input that I excluded from the truth table. Oh, and if you want to see the truth table, here it is: ABCDEF|CIO And here is the resulting output from my algorithm: ---- 001 OTABLE ---- As you can see, the resulting equation for ITABLE was really ugly and would have completely cluttered up my code. It was much easier to simply solve for CTABLE and OTABLE and then select ITABLE only if neither of the other two were selected. And here is the decision tree (using my nomenclature) from which I implemented the code: Decision Tree: I have not yet automated the process of creating a decision tree, but I have an algorithm worked out in my head to do it. That is my next task after testing RC4 with the new code. |
Archives:
February 2004March 2004 April 2004 May 2004 June 2004 July 2004 August 2004 September 2004 October 2004 November 2004 December 2004 January 2005 March 2005 April 2005 June 2005 July 2005 September 2005 October 2005 November 2005 December 2005 January 2006 February 2006 April 2006 May 2006 July 2006 June 2007 July 2007 May 2008 January 2009 March 2009 October 2009 |