I've started reading A. T. Winfree's book (father of Erik): "Geometry of Biological Time". Sometimes one finds just the right book that fills in the gaps of one's knowledge; this book is just right for me at this moment, as if I was fated to read it.
It begins with an excellent introduction to topology mapping. I had picked up some of the ideas by osmosis, but the first 20 pages were an excellent and helpful series of discussions that help solidify my understanding of this subject. He lucidly expands on abut 15 topological mappings in increasing complexity. For each, he provides intuitive examples with lovely side discussions such as relating the S1 -> I1 mapping to the international-date-line problem and the astonishment of Magellan's expedition to the loss of a day upon the first round-the-world trip. (I first heard of this idea as the climax of the plot of "around the world in 80 days"). He introduced the idea of all such mapping problems as singularities in the mapping functions. Again, this was something that I half-understood intuitively and thus it was very helpful to have it articulated clearly.
I now realize that in previous amorphous computing experiments described in this blog, I had been exploring S1 x S1 -> S1 mappings (circular space by oscillator space mapping to a visible phase). This S1xS1->S1 mapping is exactly where he heads after his introduction as a place of interest. In other words, I had ended up by intuition exactly where he did.
It's a very long and dense book, if I can maintain my way through it, it may generate a lot of blog entries!
Monday, April 6, 2009
Wednesday, April 1, 2009
House projects
Arch cut for the handrail on the main stairs.
Kitchen nearly complete.
Bruce gets out the Gallagher Saw!
Bruce and I start mounting branches on the front porch.
This one branch was a bitch, we gnawed away it it with probably 30 cuts before we got it to fit right!
We wrapped up many of the recent house projects. The upstairs porch is screened in and has a pane of glass on one side which significantly reduced the noise from the neighbor's AC unit -- now I can have my bedroom windows open!
The rear kitchen is done except for drawer pulls and a couple of electric outlets.
We cut an arch into one of the supports along side the staircase that had been bothering me for a long time because it didn't leave room for your hand to slide along the hand rail. Bruce and I came up with this cut arch solution which also I think looks really cool -- opened up the space a lot.
We started adding branches to the front porch beams which was part of the original plan but we had never gotten around to it. One of these branches was much harder than the others we ended up make many small cuts until we got it positioned just right.
Monday, March 30, 2009
An Idea: Federal Reserve Random Moves
Reference historical DJIA (log scale)
Self Organized Criticality (SOC) is a model to describe the dynamics of certain kinds of systems built out of many interacting non-linear actors. The "sand pile" model" relates the frequency of avalances to their magnitude by 1/f (i.e. avalances happen with inverse frequency to their size).
It seems intuitive that economic systems should also show this "sand pile" behavior and this paper claims that stock markets do indeed show "near-self organized critical" behavior. (The exact function is not relevant to my argument.) This intuition for this comes from the fact that each economic actor relies on others in a complicated web of interactions. The value of assets in the system are subjective and are strongly biased by the perception of other actor's subjectively valued assets. Moreover, the perceived future value of those assets is a strong function of the cultural perception of the unknown future. In other words, the macroeconomic system is in a strong, multi-scale, positive feedback.
In the sandpile model, a few grains of sand will end up holding an enormous load of upstream stress and therefore their perturbation will create large avalanches. Analogously, a few economic actors (insurance companies, banks, hedge funds, etc) will end up with an enormous load of upstream dependencies that will similarly cause avalanches if they are disrupted.
In the sand pile model one can imagine a large conical basin of uphill dependencies resting on a few critical grains -- those critical bits are the ones that are "too big to be allowed to fail". Playing very loosely with the analogy, the stress on a gain from its uphill neighbors is analogous to the balance sheets of an economic actor. But not exactly. In the sand pile, all potential energy is explicitly accounted for -- there's no hiding the cumulative stresses due to the weight of each particle. This is not true in the economic analog. Real balance sheets do not account for total stresses because complicated financial transactions (like mortgages and insurance contracts) contain off-balance-sheet information that is usually one-way. For example, when a bank realizes that there is risk in a mortgage they will pass on this cost to the uphill actor but when a debtor realizes that there's more risk (for example, they might know that their financial situation is not as stable as it appears on paper) they will not pass along this information. In other words, there will tend to be even more uphill stress than is accounted for by the balance sheets of each downhill actor.
Now the point.
If you wanted to reduce the number of large scale catastrophic avalanches in the sand pile model, the method for doing so is easy: add noise. The vibration of the sand pile would ensure that potential energy in excess of the noise energy would not be allowed to build up. It's the same idea of forest management -- lots of small fires prevent larger ones. Therefore, by analogy, a good strategy for the Federal Reserve might be to similarly add noise. Conveniently, this "add noise" strategy is inherently simpler to execute than is their current strategy -- they would simply roll a die every few months and change the discount rate by some number between zero and ten percent.
Crazy? Well, as it stands now, the Federal Reserve operates under the belief that it can act as a negative-feedback regulator of the macro economic system. The idea is sound, but based on my experience attempting to control even very simple systems, I'm skeptical of the reality. To begin with the obvious, the economy is anything but simple. Furthermore, the Fed does not have, never has had, and never will have, an accurate measurement of the economy. To wit: it neglected the huge volume of CDOs built up in the last 10 years, and the S&L stress of the 80s, and the tech bubble of the 90s, etc, etc. History shows that there have always been, and will always be, bubbles and newfangled leveraging instruments so anything short of draconian regulation that stopped all financial innovation (which would be worse) will not be anything but reactive. But it gets worse. There are also large and unpredictable latencies in both the measurements and the results of the Fed's actions. Even in simple linear systems, such latencies can have destabilizing effects and since the macro economic system is highly non-linear and constantly evolving the effects are essentially unknowable apriori.
In summary, I suspect that the macroeconomic system is not directly controllable in the way that is envisioned by the creators of the Federal Reserve due to non-linearity, poor measurability, and latency. Therefore, given that the economy probably has some SOC like organization, I suspect that random Fed moves would probably be no worse than the current strategy and would probably be better.
Flagella assembly video (external link)
This is a really nice video about flagella assembly (thanks to Ken for the forward). One detail I didn't know before was that the flagella proteins are denatured for export through a ludicriously small 1 nm channel. All the stuff about the hook length measurements were particularly interesting. Very cool!
http://video.google.com/
Saturday, March 28, 2009
An Idea: Internet Security Though Random Compilation
This morning an idea occurred to me -- a way to stop malware, viruses, and worms. When someone wishes to crack an internet protocol for nefarious purposes, one way to do so is to exploit bugs in buffer handling. For example, some specific implementation of the email protocol might have a bug whereby if certain characters are passed in the addess field then it causes a buffer overflow that could permit writing onto the stack. By sending the right set of characters, the overflow might be directed to upload and execute arbitrary instructions. Similar exploits have existed/still exist in many systems such as the image handlers for Microsoft Outlook and countless other programs.
As clever as it is, exploiting such a bug requires having a copy of the code locally during development so that the programmer can step through it and figure out exactly how to exploit the overflow. Thus, a way to defeat this is to ensure that every single instance of that code running on every machine is unique. Therefore the solution is simple. Write a compiler that generates random code that performs the same task but with different execution paths. Such a complier would stop all such exploits by effectively creating a local unique encryption. A random compiler would be easy to write and indeed already exists in Java as "code obfuscators" for the purposes of reducing reverse engineering. The only difficulty in deploying such a system is that the relevant software could no longer be deployed on mass-produced media such as CDs since each instance has to be different. But this is a declining issue as more and more software is delivered online where each instance could be different. Furthermore, many of the main internet protocols are open source implementations and where local compilation is already possible or, in many cases, already occuring. Therefore adding this feature to Gnu C would be a big step in the right direction.
As clever as it is, exploiting such a bug requires having a copy of the code locally during development so that the programmer can step through it and figure out exactly how to exploit the overflow. Thus, a way to defeat this is to ensure that every single instance of that code running on every machine is unique. Therefore the solution is simple. Write a compiler that generates random code that performs the same task but with different execution paths. Such a complier would stop all such exploits by effectively creating a local unique encryption. A random compiler would be easy to write and indeed already exists in Java as "code obfuscators" for the purposes of reducing reverse engineering. The only difficulty in deploying such a system is that the relevant software could no longer be deployed on mass-produced media such as CDs since each instance has to be different. But this is a declining issue as more and more software is delivered online where each instance could be different. Furthermore, many of the main internet protocols are open source implementations and where local compilation is already possible or, in many cases, already occuring. Therefore adding this feature to Gnu C would be a big step in the right direction.
Tuesday, March 17, 2009
Sound insulation, screens
The wallboard guys came today and added two layers of sound proofing to my bedroom wall.
Kurt finished the screen installation. You can hardly see them. Of course, after a while they'll get dirty. The section on the left is where glass will go which will hopefully abate some of the sound of the neighbor's AC unit.
Monday, March 16, 2009
Sound proofing, Screens
Looking up into the ceiling Bruce cut a hole to gain access to underneath the bathroom.
This wall and the adjacent one are going to have sound proofing board added tomorrow so bed and pictures were taken out of the room.
Bruce finished up the back of the new shop cabinets. The wall board guys will clean this up tomorrow.
Crammed my bed temporarily into the spare room.
Pulled the railings out from the back porch to insert the new screens. But the screens didn't quite fit so there's some modification to be done.
There is a bathroom immediately adjacent to my bedroom and anytime it is used at night I can hear, well, everything. This is despite the fact that the walls are filled with 3" of foam. To abate this, Bruce opened up the the ceiling and sprayed in cellulose insulation above and below the bathroom. This made a tremendous amount of dust but didn't do much to dampen the sound. Tomorrow the wallboard guys come and we're going to expand the adjoining walls with another inch of special sound-proofing board. This requires rebuilding two walls, two doors, and repainting so I've temporarily moved my bed into the spare bedroom. Meanwhile, the cabinets were framed up and an attempted mounting of the porch screens determined that there were a few mis-measurements and will require some modifications.
Subscribe to:
Posts (Atom)