Mastodon

AuthorTom Lee

I went to UVA

I

It was the best school that I could afford, and I think it gave me a good education. But it was never a great fit for me. I met some people there that I really liked and many more that I didn’t. I identified with these kids, not the ones in ties at football games. I seemed to be the only person thrilled that Stephen Malkmus had gone to UVA (including Mr. Malkmus).

When I read the Rolling Stone article, I believed it. I had known and disliked the callous frat culture. I had been disgusted by the university judicial system’s failure to grapple with the beating of Sandy Kory, and was unsurprised to hear that it had failed Jackie, too. And I believe that sexual assault is an enormous problem on American college campuses. I didn’t bother to finish reading the story, to be honest. It only took a few hundred words to bring me to despair, and I knew what the rest would say.

When critics raised doubts about the story, I believed them, too. I knew and was friends with people in frats — the stoner and geek frats, but frats nonetheless. I even rushed one, briefly! At a school like UVA these connections to the Greek system are all but unavoidable, particularly if you are underage and keen on drinking. Although their culture was sexist and aesthetically distasteful, it never seemed violent to me. Individuals behaving despicably was and is all too believable. But a premeditated, group-level endorsement of predatory violence seemed unlikely, particularly given the frats’ years of experience projecting the most upstanding image they could manage to help keep the party going.

And of course there were other problems, some of which will only make sense to alumni. Gawker’s dismissal of the timing of fraternity rush as a salient factor seems unwarranted, for instance.

I was unsure what to think. Because of conflicting evidence and heuristics? Only superficially. In truth, it’s because I have competing self-conceptions that can justify themselves in different ways depending on what we collectively decide this episode’s moral will be. I am a supercilious iconoclast who disdained the frats, even as he let them buy him oceans of beer. And I am a UVA graduate who thinks but does not say the phrase “public ivy” and who doesn’t want people to think of rape when he tells them where he went to school.

My thoughts are ambivalent but they are uniformly tainted by emotion and vanity. And although their reasons are different, I think this true for most people discussing this case, and everything else, on the internet.

How could it be otherwise? We don’t have enough information to judge the truth. There are endless explanations and additions that could modulate every atom of the narrative, but no amount of reporting is likely to let us access them satisfactorily. Luckily, we don’t care that much. Instead we will settle for asserting, by fiat, how the world must have worked in this instance, reasoning from first principles: we are good, and the people we dislike are bad, and reality, in the long run, must surely reflect this distinction.

I no longer believe that I have a right to hold an opinion about what it was or when it happened, but I am pretty sure that something very bad happened to Jackie and that she’s suffering because of it, and because of this she deserves sympathy and help. I believe it’s her right to go to advocates for support or to the police for justice, but I don’t believe that the rest of us deserve to continue gawking at her horror — particularly now that the conversation surrounding it has lost any plausible claim to preventing future violence.

genies, bottles & GPS

g

Over the past few months I’ve been idly picking my way through You Are Here, a review copy of which was generously sent to me while I was still at Sunlight and in the wrong industry to review it. It’s enjoyable!

Inertial navigation — tracking position by keeping a careful tally of acceleration (originally, by using gyrocopes) — is particularly badass.

giphy

This is even more amazing now that we have solid-state accelerometers in our phones and wiimotes and laptops.

The RoomScan app uses these techniques to let you build accurate models of interiors by sliding your iPhone along the wall. Using it during the home-buying process was an I’m-living-in-the-future moment. (Making light saber noises is also good.)

The two things that jumped out at me from the book were about the GPS system and the silliness of politics. First, on the popular myth that Ronald Reagan’s bold vision is the reason the military-built GPS system was opened to civilian use:

reagan_gps

And second, on the idea that Bill Clinton’s brave decision to unlock the GPS system’s full precision to civilian uses is what delivered our current era of accurately-positioned benefits:

coast_guard_gps

It turns out various other agencies were successfully building systems to defeat selective availability, too, notably including the FAA. But good for you, Coast Guard. This might have been the highest-altitude DRM system of all time, but it didn’t work any better than the rest.

Our positioning is going to get even better, incidentally. iPhone chips can already use not only GPS signals but those of GLONASS, Russia’s competing (and never-crippled) system. The EU is launching Galileo, which promises to improve accuracy even further. In fact, its (paywalled) commercial version will allegedly deliver precisions of just a few centimeters.

Flickr users are wrong

F

creative-commons-flickrA lot of people are upset about Flickr’s plans to begin selling prints of user photos that are available under Creative Commons By-Attribution licenses.

Some people have told me that Flickr’s plans bother them because it changes their understanding of their relationship with the company. Companies are not people, and I will gently suggest that it is unwise to cultivate emotional relationships with them. Doing so invites disappointment or manipulation.

So let’s look at the other reasons that people are upset about this. I think that many people are either behaving irrationally or do not understand what free culture licensing means.

  1. Flickr users are under no obligation to add a Creative Commons By-Attribution (CC-BY) license to their work. It is and has always been easy for users to retain complete control over distribution of their photos if they care to do so.
  2. Just as easily, Flickr users can select a CC-BY-NC license, which allows reuse of their work for noncommercial purposes.
  3. Right now, CC-BY images on Flickr are often used for various commercial purposes. There is nothing stopping anyone, anywhere, from selling a print of your CC-BY licensed work, nor from downloading your CC-BY licensed photo and making a print for themselves.
  4. Flickr’s sale of prints does not deprive photographers of their work or money. Users have the same ability to use their work that they always had. The vast majority would never have taken the steps necessary to profit from their work, so print sales do not deprive them of money. When a user really expects to sell prints, they should avoid Creative Commons licensing, which, as I’ve mentioned, is easily done.
  5. Flickr’s sale of prints provides benefits to other people. People who work for and own Flickr make money. The vendors producing and delivering the prints make money. And people who buy prints get to enjoy works of art.
  6. Some people have earnestly-held beliefs about this last point amounting to a bad thing. But not very many (it’s a difficult trick to pull off without also rejecting most aspects of global civilization). Most people think these are good things.
  7. I suspect that many Flickr users agree that the things in point 5 are good. It’s just that they’d like to have control over when they happen. Maybe it’s okay for the local coffeeshop to use your photos on a flyer, but it’s not okay for Archer-Daniels-Midland to put them on a billboard. I suspect this is how a lot of people feel, because I used to feel this way, too. But if you insist on control, those good things in point 5 usually won’t happen, because it’s too hard to ask for permission every time you want to use a piece of culture. This is one of the main reasons why Creative Commons licensing was invented.

Open licensing is about giving up control so that other people can benefit. That’s all it will cost you: control. Having control feels nice. But you should ask yourself what it really gets you. And you should think about what others might gain if you were able to let go.

Think carefully and decide what you need. No one is going to make you tick that Creative Commons box. But when you do, it’s a promise.

LEDs for halloween

L

I’ve continued to drift away from my commitment to dressing as villains. In my defense, Cyclops is kind of a jerk.

I worry that I’m beginning to stagnate: my palette of duct tape, under armour and LEDs is flexible enough for a variety of comic book characters. If augmented with adhesive velcro strips and the choice of a pouch-laden Rob Liefeld character, it’s even sort of convenient.

The LED components are always a hit, and I’ve seen more costumes incorporating them in recent years. I’ve added light to my costumes with a variety of different systems in the past, but they always had shortcomings. This is the first year that I achieved a well-engineered yet simple implementation, so it seems worth writing up how best to do it.

LED strips

China now produces these in great volumes, and they’re both cheap and easy to work with. Tons of different colors and configurations are available from eBay and Amazon, invariably arriving on black plastic spools and with peel-off adhesive backing. Besides color, you’ll have to decide on brightness, which varies both LEDs per meter and LED type, and waterproofing. For a halloween costume, pretty much anything will be fine — which is to say blindingly bright.

The strips can only be cut in certain spots, but these are clearly marked. Solder tabs are present if you want to connect strips together. You’re going to need a soldering iron to connect the strip to power, but it’s about the simplest soldering job imaginable.

Power

The strips aren’t just LEDs: they also have integrated resistors that are rated for 12 volts, presumably because this is the voltage at which automotive systems run. That’s what you’ll need to supply to the strip. You have a few options:

  • Batteries’ voltage is summed when wired in series. Alkaline batteries like AA cells, AAA cells and D cells are all 1.5 volts per cell, meaning that 8 placed in series will give your LEDs the power they need. You can find appropriate battery cases at Radioshack or eBay (you might need to chain two four-battery cases together). This is arguably the easiest of the approaches listed here, but also the shortest-lived and the one most likely to cause problems if asked to power too many LEDs (particularly with AAA cells, which I don’t recommend).
  • Lead-acid batteries are rechargeable, can hold a ton of power, and come in 12 volt or 6 volt varieties. Avoid the latter, buy a cheap trickle charger, and connect directly to your LEDs. The downside, as the name suggests, is weight (and price — a small battery will probably run $30). Any lead-acid battery is likely to be 10 or 15 pounds. For the right costume, this is no problem. For others, it’s a huge pain in the ass. If it suits your needs, though, a lead-acid battery can be a handy thing to have around: keep one charged and one of these doohickeys on hand and you’ll be able to power your cell phone for a solid week when civilization finally collapses.
  • Lithium-polymer USB batteries are rechargeable, pack a lot of juice, are compact and lightweight, and can now be had for less than ten bucks. They’re ideal for costumes, and they often wind up being useful cellphone supplements after the holiday. Their downside is complexity. USB power is always 5 volts. That’s not enough for a 12 volt LED strip. Chaining these batteries together isn’t a great idea, either. There are already electronics in play in those enclosures; and anyway 12 isn’t divisible by 5. We need a way to turn 5 volts into 12.

Boost converters do this pretty efficiently, and cost just a few dollars on eBay. You’ll need a few more things to use them, though: wirecutters, a USB cable you don’t mind ruining, and a multimeter. This last tool might sound intimidating, but a crappy $10 multimeter will work just fine.

At this point your mission is to cut the USB cord in half and expose conductive portions of its four wires. Plug the USB connector into the battery and use the multimeter’s probes to test the wires until you find a pair that gives you a reading close to 5 volts (it might not be exact, but it should be within a tenth of a volt or two). If your USB cable was designed by good people, these wires will be red and black, like the probes of your multimeter almost certainly are. But maybe they won’t be. I’ll assume they are.

Disconnect the USB plug from the battery. Then solder the USB wires onto the boost converter. Red is positive; black is ground. They go to the IN(+) and IN(-) solder terminals of your boost converter, respectively.

Now reconnect the cable to the battery and use the multimeter to probe the output terminals of the boost converter. There’ll be tiiiiny screw on top of a plastic box on the boost converter. Turn it while reading the measurement from the multimeter until it reads twelve. It can be tough to do all of this with only two hands, so finding someone to help is recommended.

Once your boost converter is set to twelve volts, you can solder your LED strip’s connection to the output terminals. Simple.

You can avoid the multimeter hassle by buying one of these units and using its integrated display to set the voltage.

This is both more expensive and a waste of energy (the display will remain on while powering your costume). It’s also not something I’ve personally tried — I’ve only used these to step down voltage from 12 to 5, not to step it up. I think it should work, but I can’t make any guarantees.Either way you’ll need to chop up a USB cable. And a basic multimeter is a handy thing to have around.

How Much Power?

It’s a drag, but if you’re powering more than a dozen LEDs, you should do at least a little math to ensure longevity and safety. Batteries can get dangerously hot when they’re drained quickly. Besides, you wouldn’t want to run out of power before the end of the party, would you?

We’re concerned with amperage — milliamperage, to be more precise. A liberal estimate of an individual LED’s power consumption is 30 milliamps. This level of current draw, held for an hour, equals 30 milliamp-hours (mAH). Conveniently, this is also the unit that battery capacity is measured in.

If your battery assembly’s output is 12 volts, the math is really easy: just divide the mAH rating of a your alkaline battery type by the number of LEDs in use multiplied by 30. A typical AA battery might hold 1200 mAH (check the label). Given that rating, a 12-volt assembly of them (8 in series) could power 40 LEDs for an hour.

If you’re using a single lead-acid battery, it’s just the same, except your battery’s capacity might be measured in amp-hours. One amp-hour equals 1000 milliamp-hours. That means a 6 amp-hour lead-acid battery could power 200 LEDs for an hour.

With varying voltages, like we’ll encounter with a USB lithium battery, things get slightly trickier, but only slightly. We need to figure things out in terms of energy, not just current — that means watts, which are amps times voltage. Here’s how it works out:

(5 volts * USB battery milliamp hours) / (12 volts * number of LEDs * 30 milliamp-hours)
=
number of LEDs

The boost converter we use with the USB battery isn’t perfectly efficient, so we should include a fudge factor. Let’s be conservative and say it’s only 90% efficient:

(0.9 * 5 volts * USB battery milliamp hours) / (12 volts * number of LEDs * 30 milliamp-hours)
=
number of LEDs

A small USB lithium battery might hold 2400 mAH (the packaging will usually say). Using the above math, that means such a battery could power 30 LEDs for an hour.

Of course, you probably want to power your costume for more than an hour. In fact, you should make sure of it: asking a battery to dump all of its power in an hour is fairly aggressive, and might make it heat up more than is comfortable or wise. Use the above to figure out the capacity you need per hour, then double it. Remember, you can always swap out batteries. Or, for the alkaline and lead-acid otions, you can increase capacity by adding more cells in parallel (don’t do this with the USB lithium option — just plug a new one in, or power different sections of LEDs from different batteries).

The above estimates are conservative. Boost converters are generally more than 90% efficient, and the types of LEDs I’m suggesting you use generally draw 15 or 20 milliamps, not 30. But it’s good to employ a generous fudge factor. I’ve always been pleasantly surprised by how long my batteries hold out. You’ll probably want to give your rig a test run before the party, anyway.

Fading

The first time I tried to dim the LEDs in a Halloween costume it didn’t work very well. I had attached a potentiometer: a knob that can add resistance to a circuit when you turn it. Increasing the resistance lowers the voltage that gets to the LEDs. A lower voltage does dim LEDs, but the behavior isn’t very smooth. At first the change is almost imperceptible, then it’s very sudden, and then the LEDs just turn off completely. This is because LEDs emit photons in response to voltage in a nonlinear way; even worse, humans perceive brightness in response to number of photons in a nonlinear way.

The solution is not to alter the brightness of the LED, but to change its duty cycle: how much of the time it’s turned on. If an LED is only turned on every third microsecond, it will appear 33% as bright as if it were on steadily. LEDs turn on and off very quickly, so it’s easy to make them strobe so fast that the human eye can’t notice the flicker.

The way to do this is beyond an introductory blog post, but the short answer is: a MOSFET, an Arduino, and the analogWrite() function. The first two can be had for less than $5 combined, and the last is free. If you decide to try this but have no idea what you’re doing, get in touch with me and I’ll try to help.

A nice side-effect: by adding an Arduino you can easily start programming strobing or fading effects. You could even make your costume respond to the partygoers around you.

EL Wire

LEDs aren’t your only options for lighting a costume. Electroluminescent wire, strips and panels are fairly cheap and generally come with their electrical systems prebuilt, thanks to their unusual power requirements (very high voltage and frequency alternating current at very low amperages). Those power supplies generally run off of just one or two alkaline batteries and can last for many hours.

The downside to EL systems is how difficult they are to manipulate. EL wire and panels can be cut, but they can’t be spliced without unusual tools and more skill than I can muster. The power supplies also tend to be made cheaply, and when they are they emit a quiet but high-pitched whine which might be annoying in environments that are supposed to be silent and spooky, like a haunted house.

building artificial minds is going to be the most important thing our species ever does

b

And you shouldn’t let anyone tell you otherwise!

I’m prompted to write this by my friend Tim Lee’s new piece on Vox: Will artificial intelligence destroy humanity? Here are 5 reasons not to worry. It is characteristically smart, but I disagree with most of it.

Tim’s first and second points concern the difficulty of interfacing artificial minds with the physical world. This is accurate, but decreasingly so. The internet now provides programmatic means by which I can command a huge variety of commercial activity (Amazon, Uber, Push for Pizza); puts most of the people on Earth within easy communication range (email, SMS, POTS); and, in rich countries, is increasingly connected to ubiquitous telemetry (traffic cams, fitbit, mobile phone location trackers).

Progress in robotics seems to be accelerating, and is still temporarily constrained by discontinuities between the field’s capabilities and its market size. There are only so many buyers for automotive welding robots and creepy robot dogs, after all. The consumer market is currently mostly about robot vacuum cleaners that sort of work. But we’re on the cusp of ubiquitous robot cars, and it seems plausible that geriatric caregiver bots will be viable in my lifetime. If a machine intelligence has a strong desire to interact with the real world (which it might not), it’s hard to imagine the physical interface remaining a substantial obstacle for much longer.

The third bullet is the meatiest, but also runs into the most problems:

Digital computers are capable of emulating the behavior of other digital computers because computers function in a precisely-defined, deterministic way. To simulate a computer, you just have to carry out the sequence of instructions that the computer being modeled would perform.

The human brain isn’t like this at all. Neurons are complex analog systems whose behavior can’t be modeled precisely the way digital circuits can. And even a slight imprecision in the way individual neurons are modeled can lead to a wildly inaccurate model for the brain as a whole.

Yes, neurons are complex. But their behavior seems to be computable in a Church-Turing sort of way. You can consider digital music playback as an analogy. Music exists as a continuous and extremely complex transformation of air pressure. It is very dissimilar to how digital circuits work. But those circuits can operate so quickly that trains of on/off pulses can recreate an arbitrary piece of music perfectly. So it is, plausibly, with neurons.

Although brains are very complex mechanisms, it is overwhelmingly likely that you can strip out much of their functionality without any impact on their computational capacity. Most of the cells in the brain are glia, responsible for things like immune function, garbage collection and building myelin sheaths. As far as anyone knows they’re just there for biological support. How abstract can you make your model’s neurons before they lose any hope of spawning a mind? Nobody knows. Neurons actually are weirdly computerlike, in that an action potential firing down an axon is an all-or-nothing event. But the threshold excitation that triggers firing is manipulated in lots of subtle ways (both temporarily and over longer time periods), and no one knows how many will have to be simulated or how accurately. Still, you can certainly perform recognition tasks with highly stylized approximations of neurons.

It’s also not clear that we need a particularly accurate simulation of the brain to create a mind. Tim:

A good analogy here is weather simulation. Physicists have an excellent understanding of the behavior of individual air molecules. So you might think we could build a model of the earth’s atmosphere that predicts the weather far into the future. But so far, weather simulation has proven to be a computationally intractable problem. Small errors in early steps of the simulation snowball into large errors in later steps. Despite huge increases in computing power over the last couple of decades, we’ve only made modest progress in being able to predict future weather patterns.

Simulating a brain precisely enough to produce intelligence is a much harder problem than simulating a planet’s weather patterns. There’s no reason to think scientists will be able to do it in the foreseeable future.

It’s really hard to predict the exact sequence of a particular weather pattern. But modeling a plausible weather pattern is pretty easy. And neural systems seem to be able to operate in a really huge variety of configurations. Not only is every person’s (presumably) conscious brain different, but they keep operating in mindlike ways after suffering severe alterations to their performance characteristics. Drugs! ALS! Concussions and lesions! Lobectomies, for pete’s sake! Not to mention the seeming likelihood of many or most animals having substantial phenomenal experience despite wildly varying biologies. Once we figure out how to do it, there will probably be a considerable fudge factor in building minds.

Tim’s fourth argument concerns the importance of human relationships. This is fair: there’s good reason to think human social behavior is one of our most evolved and convoluted systems, and one that a machine might have a hard time figuring out quickly. But although our behavior is complex it’s also fairly predictable–we have already systematized a surprisingly large amount of this knowledge in fields like marketing and political campaigning. There’s every reason to think that a machine intelligence that’s immune to fatigue, moodiness, territoriality, jealousy and other human social impairments could master relationship-building.

Tim’s final point is an argument about the falling value of intelligence in a world where superintelligent machines proliferate. I’m not sure it makes a ton of sense to treat cognition as a simple commodity, but even if it does, this ignores the potentially trivial relative value of human minds in such a world.

It’s important to remember just how lousy our neural hardware is. When a neuron fires, it does so by opening channels along its axon, which allows an uneven gradient of sodium and potassium ions (maintained by a ceaseless cellular pump) to equalize between the inside and outside of the cell. This opens up adjacent channels, flowing down the length of the axon, stimulating the release of neurotransmitters at its synapses. The whole thing takes about a millisecond, which is several million times slower than a transistor. That our brains work despite this sluggish mechanism is a testament to the power of parallel computation, of course. And neurons perform analog operations (summing excitation, for instance) that would require many transistor switchings to simulate. And there are about twenty billion neurons in the human brain.

So simulation isn’t easy, exactly. But if a workable hardware configuration can be found, one can imagine scaling scenarios that transcend biological limits on sentience very quickly indeed. If your neurons had the switching performance of contemporary transistors, you could plausibly experience two lifetimes in an hour. You’d also be able to throw away a bunch of subsystems devoted to autonomic processes and other unnecessary biological and social functions, simplifying the problem further.


I have no idea if we’ll build machine intelligences. I think it’s pretty likely that consciousness is an epiphenomenon free-riding on top of a powerful neural network, and that some aspect of causally isolated panpsychism is a basic component of the universe. But there’s a mystic in me that wants the real source of our minds to retreat away from our plausible guesses.

I think he’ll be disappointed, though. If we do create a thinking machine, it’s hard to imagine what it will want or do. It will be designed by our hands, not by evolutionary processes. So I don’t think there’s any particular reason to expect it to want to reproduce or grow or consolidate power or even avoid death. Perhaps it will have no volition at all.

But if it does constitute a conscious being in a way that we can relate to, I think we should expect to be surpassed by it pretty quickly. Whether that presages extinction, irrelevance or transcendence, I couldn’t say. But it’s certainly going to be a big deal.

arduino class notes

a

For the last four weeks I’ve been teaching an Intro to Arduino class at Sunlight. It’s been fun! I’m hopeful that the participants have gotten a new hobby out of it. Being able to translate your software skills into the physical world isn’t exactly sorcery, but it’s the next best thing.

The notes are available at the links below. And the class Github repository can be found here.

It’s safe to say that this curriculum isn’t too different from other Arduino classes. The extent to which it relies on the sample code that ships with the Arduino IDE is proof enough of that. But in my experience the hardest-won pieces of knowledge in any technical hobby are the bits of folk knowledge that don’t rise to the level of Timeless Principle. What vendors have the best deals? What’s the name of that kind of connector? Which stuff do I really need to know, and which stuff is just there because the instructor thinks it’s good for me?

I tried to focus on these questions in the notes attached to these slides. Hopefully you’ll find them useful! Based on student response, I think that lesson 3 needs some touch-up work for non-Python users, but otherwise they’re probably in pretty okay shape.

advice for an aspiring programmer

a

Last week we interviewed a candidate who we really liked but who was much too green. He asked for some advice, so here’s what I wrote — might as well put it online. Hopefully it’s a little more specific and opinionated than these things tend to be.

—–

It was a real pleasure to meet you, but your instincts are right: at this point we have to invest in people with a bit more experience under their belts. I do want to stress, though, that your enthusiasm and interest in software engineering came through clearly, and made us all enthusiastic about the developer you will no doubt become.

Toward that end, let me offer a little more advice than I usually put into these sorts of emails:

  • Pick a technology and invest time in it. There is tremendous value to understanding the repetition of patterns across engineering domains, but you need to gain deep expertise in one before you can do so effectively.
  • I’ll be more specific: pick one of these technologies — Ruby, Python, Node/Javascript. All have vibrant open source communities from which you can learn a lot for free. All have bustling job markets. All have bindings in a huge variety of domains. All are abstract and widely supported and will spare you many of lower-level languages’ headaches. All have robust web frameworks. Personally, I’d suggest Python, because it is the most stable and widely supported. It’s everywhere– it is Google’s noncompiled language of choice, for instance, and widely used in scientific computing and a huge number of other areas. But its community is less fun and accessible than the others, and it’s more sedate. The others will take you on a wilder ride, but you will probably have to learn things a few times as the community changes its mind about how to solve a problem. This is extra true for Node and less so for Ruby — which reflects each community’s age.
  • There is a premium for mobile dev work, but I wouldn’t invest in that right now because it’s too specialized to be a great way to learn. Also iOS will be in turmoil thanks to Swift, and Java dev is a drag outside the genuinely-exciting opportunities of Android.
  • Focus on the web and the key tasks associated with it. Skim the topics that other languages’ web frameworks cover — they all solve the same problems in slightly different ways. Invest a little time in learning jQuery — being able to build out web templates is a very plausible starter job, and one you can get good at fast. Also, make a point of learning regular expressions and the network libraries and functions necessary for using APIs.
  • You do not need to know much about data structures, compiler design, sorting algorithms, recursion or most of the other things that they teach you in a CS program.
  • Microsoft technologies can earn you money but will never fully integrate with the world of open source software, which is where the best engineers and most exciting projects exist. I have written Visual Basic for a living; I don’t think you should write any more of it. The .NET frameworks are okay but basically a less-open version of Java. Everyone hates Java.
  • I wrote PHP for many years professionally and still think it is a cheap, useful tool. It gets zero respect in programming circles, though — I would not suggest spending more time learning it until/unless you have mastered something more prestigious and just want it for quick personal projects.
  • You should probably learn with a good text editor (but not an IDE) and the command line as your primary tools. On OS X I like Sublime Text 2. Speaking of which: you should be developing on OS X or Linux (people around here tend to favor Ubuntu or Mint). If you’re on Windows now this will be painful, but you will never fully connect with the open source world and its idioms unless you get used to the *nix command line interface.
  • There is no substitute for working with engineers who are better than you are. This is tough until you get yourself hired somewhere, though! On the far end there are code bootcamps, but those cost money. On the near end there are technical meetups — shop around and find one that seems technical enough to teach you things. Contributing to open source projects is a good idea, too — writing an IG scraper for Sunlight might be an approachable task (he said selfishly). Online tutorials can take you a long way if you put in the time.
  • Get active on Github! Follow how people like Eric Mill (@konklone) and Tom Macwright (@tmcw) and Josh Tauberer (@govtrack) do their work. Recognize that filing tickets is a valid way to contribute, as long as they are well-informed. It doesn’t have to all be pull requests.
  • Master the art of googling for error messages. Using search engines, Stack Exchange, mailing lists and IRC properly to uncover unknown answers is maybe the most important skill in real-life programming.
  • Once you identify superstar programmers, follow them on Twitter or their blogs. The writing of people like Ian Bicking will get you familiar with the cultural context surrounding your programming language of choice. Speaking of which: conferences can be pricey but once you’re ready they can be a really good way to learn — if you pick the right one. Pycon is excellent. I know less about the other languages’ marquee cons.
  • Spend some time reading about diversity in technology. The situation is not good, and a lot of people are working very hard to change it. This is a huge topic of discussion right now and you need to be able to talk about it intelligently.
  • If someone mentions linked data or the semantic web and they have never held a job at Google, assume they are about to waste your time.

There! I think that’s all the advice I can come up with for someone in your shoes. Ask me questions when you have them. And good luck.

the thing about the Internet of Things

t

thingsWired makes a yeoman’s effort at turning a basically boring Pew report about the Internet of Things into something worth wringing your hands over. If you actually read the report, the experts seem much less worried (and quite a bit less compelling) than Wired wants us to think.

Partly this is because only a few of them seem to know much about it. There are a lot of very impressive people on the list of respondents, but at a glance they seem to mostly be drawn from the Internet’s Elder Statesperson class. And this IoT business has less to do with the internet than the name implies–it’s really about hardware, sensors and microcontrollers. So we wind up with some warmed-over and implausible futurism from the guy who runs the Webbys.

I think the milquetoast ambivalence flows from this: we understand what we’re facing. We’ve been at this industrial revolution business for a while now, and it’s mostly apparent how it works. We’ve all lived through the advent and democratization of various manufactured technological conveniences, and we are confident both of their steady pace and their limited capacity for delivering transcendence. Consumerism: we get it.

This was not the case with software! Infinite abundance, communication and human potential — you could tell a really amazing (and, alas, often overblown) story about what this would mean for all sorts of social institutions. Something truly new was happening, emergent forces were emerging, and nobody could tell how it was going to end. It was unclear why your boss was paying for you to get drunk at SXSWi but he was and it was awesome and everything was surely about to change.

This is not the case with the Internet of Things. With the exceptions of miniaturized-yet-affordable PCB manufacturing and solid state accelerometers, most of the central technologies have been achievable for a while. They just haven’t been used. For example, the idea of a home thermostat you can set from your office is sort of neat, but such products have existed for decades. Why are we excited about this now? Well, prices have dropped, the gadget-purchasing habit has been solidified, and control interfaces have improved (thanks, smartphones). Ubiquity is newly practical.

But we still don’t have many really compelling stories about what it’s all going to do for us. The benefits to these use cases are known, or at least can be imagined. It’s nice to have a door open itself for you or an alarm clock that knows when you’re sleepy, but how much is it really worth? We’ve been able to network appliances for quite a while. We did it a long time ago for cardiac monitors in hospitals, because in that application it’s worth the money. Giving your fridge an IPv6 address? We can certainly do it, and we probably will. But don’t kid yourself about the scale of the benefits that will flow from this innovation.

(One exception: the quantified self movement *does* have a bunch of compelling stories about gigantic improvements to health that careful self-measurement can deliver. Given the enormous amounts of money we invest in not-very-effective healthcare interventions, it seems safe to say that if this idea could deliver a fraction of what it’s being used to promise, our failure to implement it already would represent one of the greatest market failures in history.)

I love playing around with hardware, so don’t mistake my skepticism about IoT futurism for a lack of enthusiasm. Filling the objects around us with dancing grains of sand that we’ve etched with runes and whispers of ions, so that they might ceaselessly observe and manipulate the environment for our convenience: I think that’s a lovely thing for a species to do, and often a pretty fun art project. And I suppose emergent network effects are always possible. Seems a little far-fetched to me, though, at least so long as we’re mostly talking about thermostats and pedometers. But my imagination is admittedly terrible.

I’ll boil it down to a few things, I guess:

  • The adoption of ubiquitous computing is a function of physical technology’s ever-falling price versus the benefit it confers. There are many applications enabled by lower prices that are just now achieving market viability. But that’s because their benefit is meager, not because the tech was impossibly pricey. This may not be universally true, but it’s probably true for the anticipated uses that are currently being used to sell this phenomenon: quantified self and home automation.
  • Concerns about maintaining the software in a zillion different devices seem legit (though people are underestimating just how awful embedded tech can get away with being, and overestimating both the incentives facing bad actors and the threat surface present on devices that are designed to be *extremely* limited). Partly for this reason, functions will continue to accrue to your phone whenever possible (we’re running low on compelling sensors at the moment, but IR photography and laser rangefinding might sell some iPhones). Some will try to achieve a profitable, lock-in-driven business through proprietary solutions to this headache, but I doubt they’ll succeed.
  • The most interesting questions surrounding these issues concern transhumanism.

UPDATE: You know, I did leave off one huge thing–the sharing economy (with apologies to Tom Slee). Uber, Bixi, AirBnB–using technology for access control really is only recently possible, thanks to the evolution of IT payment and identity systems. And it really can make our collective use of property hugely different and better.

a man, a plan

a

Panama: pretty great. The Panama City aesthetic is the first thing that strikes you on the drive from the airport: chrome and colorful and BIG, with absurdly distracting animated LED brake lights sprinkled throughout. Optimus Prime was designed by a Panamanian, I’m sure of it.

They are mostly not kidding around about the whole not-speaking-English thing, but otherwise I think you can safely count Panama as an absurdly American-friendly travel destination. This is probably pretty obvious — after all, we’re responsible for spurring Panamanian independence from Colombia, they use American currency, and the School of the Americas boasted both Panamanian facilities (now a resort!) and graduates.

Honestly, what’s most striking is how benign this history of meddling currently seems. At the moment, at least, the country is prosperous, proud and happy. Panama City is an impressive, cosmopolitan place. A tourist’s perspective can’t be trusted, and we didn’t venture toward the more dangerous Colombian border, but driving through a large chunk of the country without seeing any real human suffering must count for at least something. The experience made me feel uneasily comfortable with American hegemony — though it was well timed for our burgeoning Cold War resumption, I suppose. Probably I’ll eventually be deeply embarrassed to have thought this, but for now: things seem like they’ve worked out.

Otherwise? The canal is pretty cool. Santa Catalina is a lovely little surf town. The coffee is sadly not as good as Panamanians think (mostly because they don’t brew it strongly enough), but the hats seem legit. Panama City is very impressive, and Casco Viejo is particularly lovely. Boquete was a lush respite from the heat (though its animals failed to cooperate with our hiking plans). We fucked our rental car up pretty good. All in all, a great vacation.

bracketography

b

Reentering an NCAA bracket across multiple sites drives me nuts — it’s an obvious data format problem that could be solved very simply.

I used to think the incompatibility was deliberate, designed to capture audiences and keep them staring at a given sports site. Now I’m not so sure. The bracket functionality doesn’t try to extract all that much value from us, to be honest — these things are sponsored, sure. But there’s a definite whiff of sports fan developers taking advantage of principal agent dynamics to simply build sportsy things.

But even if the incentives for compatibility aren’t completely backward, the mayfly lifespan of bracket sites makes coordination difficult. Last year, after the tournament ended, I spent a few minutes emailing and tweeting at developers who seemed to have worked on the highest-profile bracket sites, but I received no responses.

So for now, bracket compatibility remains a pipe dream. It’s a shame, though, because the problem is a simple one. I used to think about this in terms of JSON data formats, files that you would download and upload between sites. But it can be handled much more efficiently. There are only 64 + 32 + 16 + 8 + 4 + 2 + 1 = 127 games, after all (let’s ignore the play-ins for a moment, since most bracket sites do). Each game has a binary outcome. That’s 127 bits of data.

Decisions about encoding that data can be made arbitrarily; they just have to be agreed upon. Getting the order of games correct, from 0 to 126, is essential. It doesn’t really matter how you do it, but here’s one scheme that would work.

For each region (ordered alphabetically, A-Z); then for each round (low to high); assume the highest-ranked seed wins — no upsets — and assign games consecutive numbers, from highest seed to lowest. Tiebreakers fall back to the alphabetical region name ordering.

You now have 127 ordered slots to fill with ones and zeros. 1 encodes a win for a higher-numbered seed; 0 an upset. In cases of identical seeding, 1 encodes the team from the region with the alphabetically-first name.

Here’s some Python that demonstrates how the resulting sequence of bits could be assembled and encoded into an easily transportable string:

import random, base64

def retrieve_winner(game_number):
return random.choice((0, 1))

picks = 0
pick_bytes = [] for i in xrange(0, 128):
picks = (picks << 1) | retrieve_winner(i) if (i % 8)==7: pick_bytes.append(picks & 255) picks = 0 print base64.b64encode(''.join(map(lambda x: chr(x), pick_bytes)))

This just makes random picks, but you could easily connect retrieve_winner() to a web interface. The output is something like "IXNcAyp72iGVl9iGE4i4FA==" (those trailing equal signs can be dispensed with), which is easily portable through email or twitter or copying and pasting. If you want it to be easily readable over the phone, you could change that "b64encode" to "b32encode" and get an all-caps string like "EFZVYAZKPPNCDFMX3CDBHCFYCQ======" -- that's only four meaningful characters longer (you have to chop off a few more ='s). Bracket tiebreakers -- usually the total score of the championship game -- could be added for a cost of 4 or 5 more characters.

In conclusion, I hate CBSSports.com

quis custodiet ipsos chief analytics officers?

q

Cocoa Krispies will make your child invincibleVia my former colleague Luigi Montanez, now of Upworthy, here’s an interesting look at how the media industry is reexamining its use of analytics. The search for more meaningful measures of media efficacy is interesting in its own right. But I think the structural incentives that surround it deserve some attention, too.

It’s worth reflecting on the metrics that have fallen out of style: most notably conversions (how often an online message leads directly to a measurable action) and impressions (how often an online message is seen, perhaps affecting the viewer unconsciously). For the past few years there has been an outsize focus on the level of social activity spurred by a message — though this kind of result is increasingly viewed as a overvalued. In the past few months, there has been growing enthusiasm, including at Sunlight, for measures of how thoroughly a message is considered by its viewer. Upworthy’s attention minutes metric is leading the charge — unsurprisingly, given the organization’s undeniable sophistication at measuring and driving traffic.

Although it would be hard to completely deny a fad dynamic to these successive waves of focus, I think efforts to find better analytics have been driven by good intentions. But I also think these efforts may be leading us to a different future than many imagine. For instance, I wonder if my colleague Eric is mistaking a feature for a bug here:

I can see why Eric thinks black-box metrics would be bad. But the bespoke nature of the new, increasingly in-house analytics trends carries advantages for those creating them. And this isn’t the first time that content creators have evolved toward capturing the mechanisms by which their own success is measured. A little over three years ago, before many of the aforementioned analytics trends occurred, I wrote this:

[B]y all accounts online advertising doesn’t work very well. You can measure whether someone clicks on an ad, and often whether they buy something after that click. But it turns out they rarely do those things. So businesses aren’t willing to pay very much for ad space on websites.

Is it really a coincidence that the advertising medium with the best instrumentation also appears to be the least effective? I suspect it’s not. It may be that ads never worked as well as the industry had told us; or it may be that the eyeballs/clicks/conversions funnel is a naive conceptualization of how the system works. Either way, Google has succeeded by giving advertisers what they think they want, which is analytic tools that seem to reveal that the whole enterprise is horribly ineffective.

I think the push for better tools and more efficient ads is basically a race to the bottom. In fact, less perfect instrumentation might allow the ad industry to capture a bit more revenue from business thanks to decreased efficiency.

The lure of incomparability is very strong. Forget Google AdWords for a moment. Big ad buys are still largely arranged by salespeople, working on commission, making phone calls. And how could it be otherwise, for people in the business of convincing other people? Having objective, universal measures of efficacy is not helpful to that kind of endeavor. Much better to have a measure that works for you, that people are excited about, and that you control. It could just as easily be manipulable circulation numbers as a boutique web metric.

This case can be overstated. As I’ve said, I think people are largely working on these problems in good faith — particularly at outfits like Upworthy, which focus on a social mission; or the journalists I know who have left comfortable jobs because they care about whether their work affects the world.

But the incentives for a metrics Tower of Babel are real. To some degree, they’re even admirable, insofar as they’re driven by varying conceptions of success. Is my goal to make my audience think deeply, talk loudly, or spend freely? All of these can change the world for the better; ad-buyers’ temptation to ask which is best can reasonably be resisted, even if I do a little cherry-picking to make my case.

Besides, if one is prepared, for a moment, to disregard the capacity for world-improvement that widely-viewed and ethically correct publications represent, there’s no real problem here. Advertising often has strongly positional aspects, determining who will come out on top but not the overall level of welfare (a world in which Pepsi is the number one cola may strike some as more dystopian than it does me). Not only that, advertising is in some ways a force that directly opposes human agency — it’s designed, quite explicitly, to turn dollars into altered desires and behavior. I have limited enthusiasm for the kind of improved instrumentation that might let us hone that weapon’s edge even further.

In its most benign form, advertising is a tax on industry that flows according to influences too numerous to understand. There’s an appeal to the idea of rationalizing this process, of making it measurable, quantitative and objective — making it legible, as James Scott might put it. It seems like the result would be more fair. And admittedly, the human systems that make up the alternative are not fair: they’re sexist, racist and elitist.

But I suppose I’m optimistic that those systems don’t have to stay that way. And keeping advertisers confused about what they’re buying might preserve room for some wonderful things. So three cheers for analytic innovation — even if the innovators aren’t wholly aware of what they’re doing.

Flappy Bird and the case for fads

F

flappy_space_smallIn a tab not far from this one, a small bird orbits an 8-bit Earth on a ceaseless elliptical. I put him there, and feel a certain pride about it. You should launch some birds, too, if only to remind yourself that physics is pretty weird.

Too much has been written about Flappy Bird, but I’m going to pile on anyway: it reminds me of a conversation I’ve had with Kriston (and more recently John Bergmayer). Kriston was complaining about some not-that-great book that was sucking up a ton of public attention. These people could be reading the classics! he said. Or just last year’s much-better crop of novels!

I agreed with him about the objective merits of whatever book it was, but I stuck up for fad-chasing. There’s something great about having everyone settle on a single conversation for a week or two, applying all their capacity for inventive criticism, clever jokes and feedback loops of enthusiasm. Faced with exile on a desert island, I could assemble a media library that was very self-edifying. Faced with participation in culture, I’m happy enough to watch the new season of House of Cards even though it’s sort of garbage. I keep an eye on new album releases for the same reason, even as experience makes each band’s influences and lack of invention clearer.

Flappy Bird is compelling for a number of reasons, foremost among them the narrative surrounding its author and the ineffable appeal of a game with neurologically agreeable physics. But I’m also really enjoying it as a cultural rallying point: the aforementioned orbit game, the MMO, the essays.

Admittedly, this is because, so far, the conversation is mostly among people who enjoy essays and indie games — for me, this is a comfortably skintight demographic. One doesn’t have to look far to find other, grosser avian videogame phenomena.

But for now, and maybe for the rest of its run, it’s something everyone can talk about.

less horrible still!

l

I’m almost done fiddling with it, I think. Please excuse the infinite scroll effect on the photos. I know it’s tacky.

I will mention one other thing: if you scroll allllll the way down, there is now both a search box and an email subscription option. Since even fewer people use RSS these days than before Google Reader died, it might be of interest to this blog’s profoundly modest readership.

a less horrible theme

a

Though still quite horrible. I couldn’t stand the old one anymore, though.

I’ve only just begun messing around with customizing this one, so apologies for its work-in-progress nature. I suspect nobody really feels too strongly about it, though.

Goa

G

pano

There are not a lot of flights into Goa, but one of them comes directly from Moscow. This explains a lot. The beach is full of unhealthy-looking Russian women and their monolithic husbands, whose hairless, pressurized torsos pivot atop speedos like artillery turrets. In the afternoon they are as drunk and passed out as our xenophobic cold war stereotypes have promised. Just like those topless glamor shots of Vladimir Putin, theirs is a virile aesthetic almost completely divorced from physical beauty. I’ve found Goa to be a very agreeable place to be carrying ten spare pounds of holiday weight.

But perhaps this is just Baga Beach, where we stayed. A day trip to Anjuna, the purported center of Goan hippie culture, revealed even fewer Russians than hippies. The people on the beach seemed athletic and competent and not in the mood for anybody’s shit. Absurdly, there were even a few joggers. The Bob Marley towels and offers of drugs seemed mostly about delivering the local color promised in the guidebooks. Anjuna is an American beach, a beach from which conference calls have been joined.

Seasides are timeless. The surf is perpetual, very nearly immune to seasons and human meddling. Shells and driftwood and sand are relentlessly ground down in a process that clearly does not require much supervision. Everything about the ocean is, frankly, much too big.

I used to like to sit in front of it and (pretentiously) read Calvino and feel as tiny and quiet and unnoticeable as a stone buried in the sand beyond the breakers. But that was years ago, when my self-regard was still immaculate. Pondering mortality and insignificance was a nice vacation experience once upon a time, but was never any more life-changing than a cooking class.

It’s less fun now. I’m no pebble, I’m just part of a huge herd of mammals, wallowing in the surf and shade and beer like everyone else. It’s certainly still relaxing, but regular life has lost its childish grandiosity and so the old idea of escape feels a bit more desperate. How can you relax when, back home, entropy is increasing?

I went into the Indian Ocean, which I never thought I’d do. The sand was smooth and the waves were like bath water. Soon I found myself amid some Indian boys who were bodysurfing.

Where are you from? USA. He was going there soon, he said, to work for a new company, had I heard of it. I was sorry, I hadn’t. He told me how many lakhs he was going to make. I wished him luck, which his friends thought was funny. I started to head out further and they asked me if I could swim. I told them yes; they seemed disappointed.

My cousins were born here. Or maybe that’s not right. Were they raised here? I can’t remember. One day they arrived at my grandparents’ house on Kenmore Street, in Virginia, so that the process of civilizing them could begin. Within weeks my cousin Emily gave herself a haircut, which became an important chapter in subsequent family lore and cemented a sense of wildness that was probably undeserved.

Why did my aunt go to India, and why did she come back? I’ve never been told and have certainly never asked. I imagine that she was, like many others of her generation, attempting an experiment. Sometimes I worry that its failure has disappointed her since.

My cousins seem none the worse for it, though. They are now implacable Vermonters, wise and capable and, if one insisted on naming a fault, perhaps even too strong for their own good. Just like their grandmother, and her grandmother. A generational displacement as geographically and culturally vast as possible couldn’t dislodge their destiny. At times I find this immensely reassuring.

Bangalore

B

The guidebooks try to be polite about it, but they don’t have many compliments for Bangalore. They have to admit it’s not great for temples or monuments or palaces. But they hasten to note that it’s clean! And wealthy! If Lonely Planet were about Victorian ladies instead of cities, Bangalore’s fluency in French and skill at the pianoforte would be discussed extensively.

This city has been gentler to me than I’d been told to expect. There is dizzying traffic and choking smog, but it’s navigable. There is horrible poverty and software-driven wealth — authors of Medium posts about San Francisco’s spiritual destruction via Google Shuttle will find much to like — but so far my heart is only being broken once every ten miles or so. The taxi drivers don’t seem to see enough tourists to know how to properly gouge us. And gastrointestinally, I am at the part of the cartoon where the coyote opens a clenched eye and begins to chuckle nervously, thinking the bomb must be a dud.

So I’m not as overwhelmed as I might be. But the experience has still been satisfyingly foreign.

I finished rereading Jonathan Strange & Mr. Norrel shortly after landing, and this passage seemed about right:

They had been recommended to a hotel in Shoemaker-street which belonged to a Mr Prideaux, a Cornishman. Mr Prideaux’s guests were almost all British officers who had just returned to Portugal from England or who were waiting for ships to take them on leave of absence. It was Mr Prideaux’s intention that during their stay at his hotel the officers should feel as much at home as possible. In this he was only partly successful. Do whatsoever he might, Mr Prideaux found that Portugal continually intruded itself upon the notice of his guests. The wallpaper and furnishings of the hotel might all have been brought originally from London, but a Portuguese sun had shone on them for five years and faded them in a peculiarly Portuguese manner. Mr Prideaux might instruct the cook to prepare an English bill of fare but the cook was Portuguese and there was always more pepper and oil in the dishes than the guests expected. Even the guests’ boots had a faintly Portuguese air after the Portuguese bootboy had blacked them.

I think this unavoidable, insistent foreignness can be illuminating. There are layers to the effect.


In the old days, before anyone knew what yeast was, styles of beer came from specific places. The critters in the air and the minerals in the water determined the options available to a brewer. That pilsners came from Pilsen was an immutable feature of the world, not just clever coordination by the Pilsen Chamber of Commerce.

Maybe foreignness begins with these biological conditions. They’re no more detectable by a tourist like myself than they were to medieval brewers (although I’m told I would certainly come to notice something if I drank the tap water). But they’re real and they must shape the environment surrounding me.

Those contrasts make me begin to wonder about how I’ve been shaped by similar forces at home. Sometimes, at the gym, I’ll work out next to someone and notice that their sweat smells of berbere. It’s a physical manifestation of how saturated they are by their culture.

Of course I can only detect this because my own culture is different. I’m no less steeped. Supposedly when Westerners first came to Japan, the islanders couldn’t bear the visitors’ stink. “They smell[ed] of butter and fat.” I wonder what I’m suffused with; what I smell like to the people here. Even my friends say that Subway stores smell awful, which is worrying.

The opportunity to reflect on these contrasts is what I like I like about travel (communication technology’s erosion of the case for sightseeing is hugely underconsidered). But these contrasts are growing duller, aren’t they? It’s banal to lament the homogenizing effect of global commerce. I wouldn’t want to claim there’s anything principled about my supercilious yuppie dismay at the prospect of a Bangalore Baskin-Robbins.

But the larger phenomenon seems real enough. How distinctive can a global set of cultures remain when their TV producers are all ripping each other off at internet speed?


Conscientious citizens of the universe will already be familiar with the wikipedia article about its heat death:

From the Big Bang through the present day and well into the future, matter and dark matter in the universe are thought to be concentrated in stars, galaxies, and galaxy clusters. Therefore, the universe is not in thermodynamic equilibrium and objects can do physical work.

Why can anything happen at all? Because there’s more of something in one place than another. Charge, pressure, heat — any one of them out of equilibrium, and it’s able to be harnessed for work as it seeks balance.

It’s tempting to apply this metaphor to society: imagining that the diffusion of concentrated idiosyncrasy is the only means by which cultural invention can be pushed to an acceptable pace. The transmutation of African-American musical traditions into pop genres; the adoption of anime tropes by American filmmakers; the dizzyingly reciprocating cross-pollination that produced the Gangnam Style fad single; fusion cuisine.

Is cosmopolitanism another word for entropy? Is a Diplo mixtape analogous to an exploding oil tanker? This is not a cheerful idea — it’s a prediction of eventual globalized monotony and stagnation — but it does seem compatible with Kurt Andersen’s ideas about postmodern exhaustion.

And it could serve as a framework for understanding which parts of globalization we should resent. If cultural distinctiveness is a resource we spend it should be spent on worthwhile pursuits rather than on selling hamburgers and cola; just as we should burn petroleum to empower humanity rather than to power larger SUVs.

Admittedly, this idea is also compatible with an ugly primitivism. I don’t mean to do that. I don’t want to be tempted into imagining that India (or any place else) is some sort of wellspring of authenticity; its colonial history makes that idea laughable. Besides, it seems impolite to insist that other societies act as cures for our neuroses.

But if I squint I can imagine India as an engine, doing fascinating things as it burns away the divisions between east and west and other places beside. I wonder if it will ever run out of fuel.

in honor of CES

i

Let us revisit the opening paragraph of The Hitchhiker’s Guide to the Galaxy:

Far out in the uncharted backwaters of the unfashionable end of the Western Spiral arm of the Galaxy lies a small unregarded yellow sun. Orbiting this at a distance of roughly ninety-eight million miles is an utterly insignificant little blue-green planet whose ape-descended life forms are so amazingly primitive that they still think digital watches are a pretty neat idea.

If I squint just right I can almost, almost talk myself into believing that smartwatches will be useful. But this is a personal failing.

My Dumb Raspberry Pi-powered Fantasy Football Trophy

M

Well, another fantasy football season is behind us. I entered the season as the reigning champion and left it as the… not champion. It would be churlish to try to make excuses for my poor showing. So instead I’ll simply note that there is an ongoing, pressing need for organ donors in this country, and many of my fantasy players’ families are proud to have done their part. My heartfelt congratulations to Ben on his apparent championship and the masterfully subtle campaign of cheating that must surely lie at its foundation.

But the season did have a few bright spots, even beyond the news that my WR1 is expected to walk again. In particular, I embarked on a semi-ridiculous project to build a Raspberry Pi-powered fantasy football meter. It worked out pretty well!

I should probably begin by assuring you that I’m not actually all that maniacal about fantasy football. It was a purchase that spurred this project: a few months back I bought a big lot of antique electrical gauges on eBay.

(OK, actually I bought two lots.)

Since then I’ve been building some little projects with them using Raspberry Pis and lasercut wooden enclosures. The fantasy football meter is one of the more grandiose examples.

The top gauge measures my ranking in the league. The bottom gauge measures how many points ahead or behind I am at the moment. I realize that this is deeply stupid.

It’s fair to say that I have been working to (slowly) accumulate the expertise necessary for these projects for more than half a decade. It’s made me really, really wish that I had taken some electrical engineering classes in college.

Still, I’ve learned a lot during this process! So why not blog about some of those things?

Cut A Hole In The Box

3D printing gets a lot of attention, and it is indeed frighteningly neat. But for my money a good old-fashioned robotic lasercutter is even more exciting. Anyone who has turned an IKEA flat-pack into an unattractive wine rack will be familiar with the basic principles underlying my approach.

Conceptualizing the transformation from two to three dimensions is trivially easy for some people and essentially impossible for others. I fall somewhere in the middle, and find that I am best served by workshopping a given geometric idea under a variety of pharmacological conditions — specifically alcohol, caffeine and post-workout endorphines. Probably there is some nootropic cocktail available on the streets of San Francisco that delivers innovative furniture design insights and permanent synaptic damage instantaneously, but I’m uncool enough to require lengthy periods of mulling instead.

I would dearly love to employ interesting woodworking techniques, but working in two dimensions more or less mandates the use of finger joints. And really, that’s fine. The one thing you have to watch out for is kerf. Lasercutters work by vaporizing a small amount of material. The width of this area — called kerf — usually amounts to just a tenth or fifth of a millimeter, but it does add up.

I’ve written some python scripts to help generate finger joint geometries that account for tedious kerf calculations automatically. They do require quite a bit of fiddling and subsequent modification in Illustrator or Inkscape, but they work well enough. A nicer online application can be found at makercase.com, but I know my code and like it well enough.

I used Ponoko for this particular trophy, and they provide a wonderful service. But HacDC now has a lasercutter, and though it’s less powerful, you can’t beat the price and turnaround time. I’m still experimenting with materials, but have purchased a bunch of stuff from laserbits.com that I hope will produce good results.

Raspberry Foray

I’ve spent a lot of time playing around with Arduino, and the experience has taught me a lot. But if you want to connect to the internet — and look at you, of course you do — you’re going to want to turn elsewhere. I spent quite a bit of time on the BeagleBone, and I admire its commitment to openness.

But there is no competing with Raspberry Pi right now. It wins on price. It wins on its choice of native distro. Most importantly, it wins on community. Next to these things, its just-OK (nongraphical) technical capabilities are afterthoughts.

Still, making the damn thing useful in embedded applications takes some thought! I have condensed a number of these lessons into this repo. You might want to borrow parts of it (you probably won’t want all of it). Among the things the bootstrap.sh script and its siblings accomplish:

  • Installs Bonjour so you can get to the Pi without looking up its DHCP-delivered IP address
  • Gets a decent Python environment in place, complete with virtualenv
  • Installs the wiringpi and wiringpi2 libraries, which are what you’ll want to use to control the General Purpose Input/Ouput (GPIO) pins on the device
  • Sets up my default wifi networks. Whoops! You probably don’t want that. But use this /etc/network/interfaces and /etc/wpa_supplicant/wpa_supplicant.conf file templates to get yourself online. Note that you can have more than one network={} statements in the latter.
  • Gives my SSH key root on the system. You probably don’t want that either.
  • Turns off the swap file. Swap files are the means by which your disk impersonates RAM to expand your system’s capabilities. It’s a super-neat idea in general, but less so if your disk self-destructs the more often you write to it — which is indeed the case with a flash SD card. You should find a way to make do with physical memory. I’ve gone through a lot of SD cards.
  • Relatedly! And not present in this install script! You should turn off journaling in the filesystem. Instructions can be found here. Journaling is a neat idea by which every change to the filesystem is first cached in a central location before being executed as a transaction. This allows for graceful recovery from a number of failure modes that can occur if an operation that requires multiple steps — and which really, really needs to complete all of them for things to make sense — is abruptly interrupted by a power loss or other failure. But that caching requires a ton of writes to disk, and will burn up your SD card in short order. You’ll just have to get by without journaling, and commit to pulling the power as little as possible
  • The script also turns on the watchdog module in the Broadcom processor that lives at the heart of the Pi. This is a little piece of hardware that listens for a heartbeat signal from the system and, if it doesn’t hear one, reboots everything. Step one is turning on the hardware; step two is setting up the heartbeat. This can give your system a gentle kick when something you’ve done screws it up.
  • Want to install a Python script in your virtualenv as a system service that starts at boot? I’ve made that fairly simple, though the script does bake in a few assumptions about your directory structure.
  • Optionally, this script will help you set up outbound mail via your Gmail account
  • Finally, there’s a script to install an ARM processor-compatible version of PhantomJS. More on that in a sec.

Some things are best done once, however. For a long time I installed whatever the latest Raspbian image was, then went through the raspi-config script (which launches automatically on the first boot) and then ran my bootstrap script.

This takes forever, though. I got particularly sick of reconfiguring raspi-config to expect a non-UK keyboard.

But creating a new and improved disk image eluded me for a while. Installing all the aforementioned junk requires that you expand the filesystem to use more of the SD card (the default uses only 2GB). But if you use the dd tool to image the result, it’ll show the full size of the SD card. And an image of one 4GB SD card (for instance) won’t necessarily fit on a different model or brand of 4GB SD card. (You should be using 8+GB cards anyway, to minimize system failures due to repeated writes to the same sector.)

The solution: expand the filesystem manually to 3GB or so. Use raspi-config to assert your American independence. Get everything set up. And then record an image using something like this:

sudo dd if=/dev/disk1 of=preconfigured_raspberry_pi.img bs=1048576 count=3000

This instructs dd to copy from /dev/disk1 in 1 megabyte chunks, and to pull three thousand of them. The remaining five thousand or so (on an 8GB card) can simply be ignored, I think? Honestly, it’s a bit difficult to keep track of which levels of filesystem abstraction and definition are included where. Perhaps those missing five thousand megabytes will come back to haunt me someday. But not yet.

Somehow the Vital Connection is Made

All of the above gets us a wooden box and a cheap and useful Linux environment. How do we make it actually translate Things On The Internet into a dial moving… somewhere?

Well, first you’ll need a wifi adapter. I tend to buy this one, which is tiny, less than ten dollars, compatible with the Raspberry Pi default distro without any additional drivers, and can mostly connect to wifi networks without exceeding the Pi’s rather wussy USB power capabilities. But there are other perfectly fine choices out there.

Getting wifi working on Linux is awful under the best of circumstances, but when done without a GUI it easily competes with the most imaginative punishments Greek mythology can offer. Please, please use the /etc/network/interfaces and wpa_supplicant.conf patterns linked above. For me, they’re the culmination of more than a year’s worth of trial and error across multiple embedded systems (next time you see me, ask to see my FUCK CONNMAN tattoo). Others will have wisely gone straight to LadyAda’s excellent series of Raspberry Pi lessons, from which this solution is cribbed.

But wifi connectivity is only the beginning.

A Ghost Is Born

Fantasy football is one of those strange areas of human endeavor in which Yahoo is successful. It’s free and it’s what my friends and I use, anyway. And it’s comforting to begin to know the annual rhythms: unnecessary redesign, mobile app flakiness, disastrous week 1 server outage, ensuing apology, eventual system stability. I look forward to repeating the cycle next year.

Alas, the API seems basically useless for anything beyond establishing that Yahoo runs a fantasy football service. So we’re going to be screen-scraping, navigating and disassembling messy HTML pages in just the same way that your browser does.

This is not a reliable process. Worse still, Yahoo counts on tons of Javascript to render portions of the page after the initial HTML has been delivered. Knowing what is supposed to happen after that point requires a Javascript interpreter, which is a sophisticated piece of machinery beyond most scripting environments. Instead, you have to connect your script to a browser and ask it, intermittently and politely, what the hell is going on right now.

This task used to be so hellaciously finicky that I’d never gotten it to work. But Phantom.js has removed most of those difficulties, and as I mentioned above, there’s a compiled version for Raspberry Pi which can simply be copied onto the device and used. I employed the Selenium Webdriver interface, but mostly because of peer pressure. I’ve been hearing good things about Casper.js.

Yahoo ensures that this will not be the end of your woes, but I’ve encoded a number of hard-fought lessons in this Python class, and will probably update it once the 2014 season redesign arrives and breaks everything. (The rest of the code for the meter is here, incidentally.)

Moving the Needle

The last piece of the puzzle: making the damn needles move. Most of the excitement is already recorded in this post. But in short: microcontrollers are all-or-nothing beasts, setting output pins to zero volts or ALL THE VOLTS (3.3 in the case of the Pi). But they can approximate intermediate values by turning a pin on and off very rapidly, with the ratio of on:off determining the voltage that’s being approximated. This is called pulse width modulation, and the Pi has built-in hardware that allows it to deal with this constant switching without expending any brainpower — but only on one pin.

Luckily, the wiringpi library has included as sophisticated a system for additional, software-controlled pins as one could hope for, though each additional pin comes at the cost of a bit more CPU utilization. Fortunately we only need two for this meter (the -100 to +100 meter is actually set up to behave as if it’s two separate meters).

The vintage gauges themselves are not configured for 3.3v, of course. But that’s where trim potentiometers come in:

Those little blue and white dials labeled 1, 5 and 6 are the trim pots in question. Some trial and error can deliver resistor levels that max out the meter’s range without overpowering it. The gauge’s response might still not be perfectly linear, but that’s where this little library comes in.

Wrapping Up

All that’s left is to add a little flair:

Ben will get a plaque now, too. I guess.

how scared should you be of your webcam?

h

Yesterday Tim Lee and Ashkan Soltani reported a surprising and alarming revelation: some webcams can be activated without their accompanying light being turned on. This means it’s conceivable that criminals or government agents could compromise your computer and take surreptitious pictures of you. It’s a frightening prospect.

It’s also one that I had more or less deemed impossible based on what I know about electrical engineering. I owe Tim and Ashkan my thanks for teaching me something new.

But I think it’s worth delving into exactly what makes this attack possible. The paper their story focuses on concerns one particular attack on one particular type of webcam. Left unanswered is whether vulnerabilities like this one are commonplace. Examining how this attack works can provide some reassurance about engineers’ good intentions, but leaves plenty of reasons to worry about their insufficiency.

You can find the paper detailing the attack here (thanks, guan!).

Before we walk through how the attack works, let’s establish our cast of characters — one that’s slightly simplified relative to the specifics of this attack, but which will suffice for our purposes.

First, there’s your computer. It looks like a computer, and behaves in a computerlike fashion.

Second, there’s the webcam microcontroller. This is also a computer! But it’s a much tinier, lousier computer — one that fits on a single microchip. Still, it can run programs, and it can talk to your computer. And we’re not going to ask it to do very much: mostly it’s just supposed to manage the other components in the webcam and report their outputs back to the computer when asked.

Third, there’s the image sensor. It’s digital and electronic, certainly, and it even speaks binary code and executes commands, but it doesn’t run arbitrary programs. It does have internal states and settings, though — it’s not a completely passive, memoryless device like a lightbulb or motor.

Here’s the key diagram from the paper:

webcam_vulnerability

On the bottom is the microcontroller. On the top is the image sensor. There is a connection between the two of them labeled “standby”. When operating normally, the image sensor will go into standby mode whenever the microcontroller sends a voltage to this connection.

On the right side of the diagram is the LED. Its input side is connected directly to the system’s power source (Vcc), and its output side is connected to the “standby” line. A circuit can only do work when energy flows through it, so when both sides of the LED are set to the same voltage — when the standby line is “high” — no current will flow and the LED will remain dark. When the voltage on this connection is low, the image sensor will emerge from standby mode; current will flow from Vcc, through the LED and out the “standby” line; and light will be generated.

This is a pretty good system! The LED’s function is tied directly to something that enables or disables the image sensor. This arrangement can’t be undone without cutting wires. Really, that “standby” line looks a lot like a power switch.

But it isn’t. The image sensor was designed to be a flexible component that might be used in many different configurations, not just the iSight. This is the norm in electronics, with a few exceptions like the custom chips that Apple designs for its iPhones. In this case, the image sensor can be configured in different ways by sending it different setup commands from the microcontroller. One can imagine modes for “low light” or “video” or “grayscale”, but there are also numerous esoteric settings that are only useful to engineers. In the case of this particular image sensor, it’s possible to tell it to ignore any signals it sees on its “standby” pin.

This probably sounds pretty outrageous, but it’s not hard to imagine configurations in which this capability could be useful. When prototyping a circuit, minimizing the number of features and connections that must be used can make the process faster and simpler. In some applications the image sensor might be on all the time, making a usable “standby” line irrelevant (or, if not properly grounded and shielded, even a source of buggy behavior).

Alternately, it might seem outrageous that the engineer designing the webcam system overlooked this capability in the image sensor. This is a stronger argument. But this is an easy mistake to make.

Here’s the datasheet for the image sensor. At 61 pages it’s not especially long (microprocessor datasheets can be thousands of pages), but I think you’ll agree that it’s not the easiest thing to read. What you probably can’t see is that datasheets are often riddled with errors. They are usually written by engineers, which produces a terrible product but is better than the alternative. As you might imagine, the result is more or less impervious to editing and verification by humans. Datasheets for very popular or venerable chips can be very good, but for complicated, new or little-used products, they can contain serious problems. Partially for this reason, datasheets often contain information about “reference implementations”: partially or wholly built systems that show how the component is supposed to be used with a minimum of complicating details, and which engineers are implicitly encouraged to follow without question.

None of this excuses the webcam engineer’s failure to foresee this security hole. But you can imagine how it happened. Having someone manipulate this completely undocumented hardware system, reprogramming a microcontroller to, in turn, reprogram an image sensor to use a counterintuitive operational mode that (for all I know) might be completely idiosyncratic to this image sensor chip? It’s tough to get too angry over someone’s decision to spend their time on other problems.

Is this comforting? Sort of. It’s an awfully specific vulnerability. It’s pretty easy to see how to design around it (use the LED to test for power to the image sensor, not the state of its standby line; harden the microcontroller’s programming; the paper’s authors discuss a number of possible remedies and the occasional tradeoffs they entail). It’s clear that the engineer was trying to tie the LED’s activity as closely and irrevocably to the image sensor’s operation as he could, which is the right idea. We have no specific reason to think that similar bugs are present in other webcams that use different chips or have more careful authors.

Still. This is a reminder that the systems we use are wildly complex, executing code in many more places than just the CPU. And it’s increasingly clear that many of those places have never been scrutinized for vulnerabilities. It’s cheering to see security researchers uncover these problems, but criminals and governments have vastly greater resources and incentives to pursue this work, and have had plenty of time to do so. Some masking tape might not be a bad idea.

teaching everyone to code is a fine idea

t

I often find myself defending Sam Biddle’s brand of Silicon Valley nihilism to Matt, so I’m sort of surprised to see us switching sides: today Matt joins Sam in deriding President Obama’s calls to teach schoolkids to program. He’s not alone! I think Matt’s specific objection doesn’t get us very far — some students’ failure to attain basic skills doesn’t really tell us all that much about what should be included in a general curriculum, just as the continued existence of murder doesn’t tell us much about the wisdom of enforcing speed limits.

But it is worth spelling out the case for teaching people to code. It’s not because we expect them to become programmers. We don’t expect every student in English class to write a novel or every student in Trigonometry to wind up manipulating triangles for a living. We certainly don’t expect every kid in music or art class to carry those skills beyond the classroom, or even to achieve proficiency within it.

Rather, we teach those skills because they are varyingly enriching and instructive windows onto reality and culture. They help kids navigate the world. In a few cases they’ll wind up being of practical value or make for a fulfilling hobby. But mostly they’re about building competent and intelligent human beings.

Coding qualifies. I still distinctly remember programming my grandparents’ VCR for them — a cliche of childhood technical affinity, yes. But also an instructive experience! Why was the schedule set with a 24-hour clock scheme? Why were the on-screen fonts the same across different brands of VCR? What the heck was the difference between SP, LP and SLP? The answers involve the nature of modulo arithmetic, the electronic industry supply chain and electrical engineering practices, and some pretty fundamental concepts from information theory. Some of these revealed themselves quickly; others came decades later. Gaining that simple, unimportant technical skill gave me a window into how engineers’ minds work and how the constraints imposed by physical reality shape the systems they build.

Without realizing it, the simple daily use of technology imparts lessons about data normalization, computability and signal processing. Stitching these hunches together with a light classroom introduction to the procedural nature of Turing-style computation is not a bad idea. It’s also not a trivial idea — some people think this perspective has enough explanatory power to describe the entire universe.

Nor is it of merely intellectual interest (though I’ll happily admit that I do find it deeply intellectually rewarding). In the same way that the economic perspective has largely triumphed over other dialectic forms in our culture, our physical environments grow ever more engineered. And engineering grows ever more digital in nature. Understanding how those processes work at a fundamental level is an increasingly necessary precondition to deciphering our deeply unnatural world.

Do you want to be able to quickly use a new product? Or organize a spreadsheet so that it will be useful later on? Do you want to know why your partner missed that SMS, or why the football broadcast looks blocky? Do you want to know what to fear, and when you’re being lied to, and how?

Learning to code “hello world” won’t guarantee you those answers any more than it’ll guarantee you a job at Facebook. But it isn’t a bad place to start.