Accepting Fracking

Or “How I stopped worrying and learned to love the injection of sand-derived proppants at a rate necessary to exceed the pressure gradients of shale.”

I’m an environmentally-minded liberal. I understand the science of global climate change, and understand that it is occurring at an alarming rate. I know that fossil fuels are finite, and that energy and energy derived issues (mass migration from global warming, drought) are going to be the basis for wars and chaos in the coming century. I acknowledge that I lead an embarrassingly energy inefficient life as compared to the rest of the world.

I want to live in a world in which all of our energy needs are met exclusively by windfarms on the plains and solar farms in the southwest, and in which we drive cars powered by electricity or hydrogen derived from electrolysis.

I am also, unfortunately, a realist and a bit of a pessimist. I’ve come to accept that we’re unlikely to make the jump from the current energy landscape to the ideal I’ve outlined in anything approaching the near term. I also believe that some of the issues I’ve outlined can’t wait. I’ve – grudgingly – accepted that nuclear (fission) will not gain prominence anytime soon. For all these reasons, I’ve come to accept fracking.

Let’s not candy-coat things. Fracking is really bad. It pollutes groundwater. It may cause earthquakes. It has the potential to free radioactive materials. Burning natural gas contributes to climate change, and the methane which can leak during fracking is an even worse contributor to the greenhouse effect than CO2.

All of this is very uncool. In a world of black and white absolutes, fracking would be a nonstarter.

But, big parts of reality are uncool. It’s easy to get hung up debating the ways in which fracking is worse than the environmental ideal – in which our choices are either “perfect” or “evil”. But, all the while, coal and oil power plants are spewing massive amounts of carbon, and people are dying in conflicts over oil.

The harms of fracking are largely localized and in my opinion are outweighed by the benefits. Burning natural gas contributes to the greenhouse effect, but far, far less (on a volume per kilowatt basis) than coal or oil. The other toxic materials emitted (sulfer, mercury) are negligible. Because I believe that slowing climate change is the number one imperative facing humanity over the medium-term, the tradeoffs of fracking-derived natural gas seem acceptable to me.

That said, there are a number of downsides and issues which need to be addressed.

Fracking makes energy derived from natural gas far too cheap. While this has had many positive short-term implications for the American economy, including helping drive the “insourcing” boom, it creates a playing field on which other types of energy cannot compete. It also encourages profligate energy use. Emily Bazelon commented on a recent episode of the Slate Political Gabfest that our incredibly wasteful energy consumption is one of the key social issues we’ll live to regret, and I couldn’t agree more.

Natural gas relies on existing distribution systems, and does very little to encourage the reconstruction that our power grid so desperately needs. It does nothing to disrupt the model of consumer-adjacent power generation – powerplants located near population centers instead of near energy sources. A shift away from this model is critical for realistic renewable utilization, and natural gas gets us no closer.

So, as an environmentally-conscious liberal who has accepted fracking, how can I continue to have a meaningful voice in the energy conversation? There are a few things I’ll push for with my voice, my vote, and my dollars.

We need a carbon tax. We need to push up the cost of energy derived from fracking, to account for the environmental impacts of not only the burning of natural gas, but also the fracking process. We need a carbon tax which makes the worst climate change offenders intolerably expensive, even in the short term. And we need to use the revenue from that carbon tax to fund the reconstruction of our power grid and the continued development of renewables. We need to stop ceding the solar technology industry to the Chinese and the Germans.

Is accepting fracking merely a case of selling out liberal causes? I don’t think so. But I think it’s important that we apply the pressure necessary to make sure that fracking is a transitional energy source. It goes a long ways towards stopping the bleeding – a United States powered entirely by natural gas is in a far better place environmentally, geopolitically and financially than our current state. It’s just not the place we need to create for our grandchildren.

(Ideally we’d accept nuclear as well, but I’m far too pessimistic to reasonably expect that. And, you know, as long as the plants aren’t in my backyard.)

Knowing Enough

I’m a fraud. I’ve convinced people that I know far more than I actually do. They seem to have bought it. By and large, this has served me well and I’ve embraced it.

This post was originally going to be “knowing enough math,” targeted at developers. That post will have to wait though, as I want to write a bit about the ways in which I try to force myself to encounter a breadth of subject matter and perspectives.

Let’s parse some terms first. I’m not sure we have a word to fully describe the notion I’m interested in. “Curiosity” seems to imply a certain degree of superfluousness or a lack of intellectual depth. “Polymath” is a term which, I suspect, cannot be used in describing oneself without sounding seriously pretentious. And that’s coming from me.

To me, “knowing enough” means having a depth of knowledge about a given topic, sufficient to allow you to know that there’s more to know. Donald Rumsfeld is, on the whole, a disastrously awful train wreck of a human being. That said, I give him credit for popularizing the notion of “known unknowns” – knowing the things you don’t know.

Much has been written about the dangers of a hyperpersonalized and siloed web. In addition to the detrimental impacts this has on our communities and relationships, it also means we’re less likely to be exposed to surprises or to be delighted by the unexpected.

Especially for those of us involved in technology, it’s exceedingly easy to live in this bubble. Daily stops at The Verge, Engadget, Daring Fireball and TechCrunch provide a set of very similar perspectives on the same news, and can easily eat up a day of casual browsing.

Fortunately, there exist some great options for being exposed to a diverse range of subjects. Traditional print publications like The Economist or The New Yorker provide both depth and breadth. I’m often surprised by the number of technology stories that I first learn about from the Economist, because they’re just far enough outside my daily bubble to have been totally off my radar.

The last few years have also seen the creation of a range of high quality “curation” websites, which aim to pull together interesting material from across the web. If you’re not already reading Kottke, Longform, and The Feature, I’d highly recommend it.

Things get really interesting when you take it one step further. Embrace the internet time-sink a little bit. Dive into wikipedia and build some subject matter expertise. Don’t just read the short article about flywheel energy storage (blog post coming soon!), check out the websites of the companies mentioned or take a look at the papers which are cited.

Conferences are another great way – though often more domain-specific – to get exposed to information which may have no immediate benefit for you. One of my favorite things about attending WWDC each year is the opportunity to attend sessions which have no relevance to work I’m doing at the moment. Sitting in a session about game optimization on iOS has no bearing on the work I do day-to-day. But inevitably, concepts I’m exposed to in sessions like this will circle back and become relevant in the future.

This is where the concept of “known unknowns” comes into play. When I sit in a random session at WWDC, I’m not aiming to learn everything there is to know about mobile OpenGL implementation or normalizing data from an accelerometer. What I do pick up on is the broad concepts – I’ll remember that, should I need to read data from an accelerometer at some point in the future, there are techniques for normalizing the data. From there, I can dive in and do the necessary research on specifics. The internet isn’t great at helping you take that first step – knowing that there’s a solution out there. Once you have an inkling of a solution, the internet can take over and provide the necessary depth.

I suspect none of this is interesting to most people. And, I suspect it comes across as deeply condescending to almost everyone. But the frequency with which I encounter people who eschew the acquisition knowledge on a variety of topics (sports, politics, entertainment, and so on) tells me that it’s a worth talking about. And, it’s the holidays, so nobody will likely read this anyways.

Happy New Year to you and yours.

NatureMill Neo Composter

I don’t intend to write many reviews on the relaunched version of this site – I don’t have new products passing through my hands in the kind of volume I used to, so I don’t have much to add to the conversation. That said, occasionally I still take a chance on an unknown or little-known product and like to share my thoughts.

In this case, it’s the NatureMill Neo Compost Bin. NatureMill makes automatic indoor composters. The Neo is part of their new (3rd generation) product line. I bought mine in August of this year, and have lived through enough of the ups and downs that I feel ready to give a verdict.

NatureMill Neo

The NatureMill product line aims to be a self contained, accelerated composting solution. You put compostable stuff in the top, and a week later, nutrient-rich compost comes out the bottom. It lives in your kitchen, and becomes an easy alternative to dumping stuff in the trash or disposall.

I was attracted to the NatureMill for a few reasons. First, I’ve never found a good place for a compost pile in my yard. Between neighbors, the dog, and the yard layout, it just hasn’t made sense. Additionally, being in Minnesota, compost piles are relatively unproductive in the winter months – plus it’s not much fun to have to dig through the snow to find your compost. However, the vast majority of the waste generated in my household is compostable – working from home and being a bit of a foodie, I do a fair amount of “from-scratch” cooking each day, which means there’s plenty of onion skins, apple cores, and carrot shavings going into the trash on a routine basis. And then there’s the coffee grounds!

NatureMill products are essentially composting Rube Goldberg devices. There are two chambers. You add your compostable items to the top. Inside that chamber is a metal mixing bar. This bar is activated periodically to stir and break apart items. The chamber is also heated and has an air pump. These combine to supercharge compost microbes.

When the top chamber is full and broken down into compost, you trigger a transfer, which causes the compost to drop into the lower area. This area houses a tray. You leave the compost in there until your next load is ready, giving it time to dry and cure. When you’re ready, pull the tray out and spread it on your garden (or store it for Spring).

Fresh Compost

So, how does it all work? In general, surprisingly well. It’s kind of awesome to dramatically cut down on the amount of waste generated in my kitchen, and the rapidity with which it turns into compost continues to shock me.

So, two thumbs up then?

Not quite.

My first NatureMill Eco self-destructed, quite dramatically, after about three weeks. The mixing bar jammed, but the motor did not cut out like it should have – instead, the torque literally split the entire unit in half, as the motor tried to escape. Needless to say, it made a bit of a mess. Disappointingly, the NatureMill customer service seemed relatively unconcerned. Repair turnaround was nearly a month, with little communication about the process. Frankly, I was surprised they didn’t just cross ship a replacement unit to me immediately.

The repaired unit has been up and running for about two months now, and seems to be operating fine, so for now I’ll call it a fluke.

Rube Goldberg devices have a reputation as being pretty fiddly and high maintenance, and this is no exception. First, your food waste must be balanced with an occasional scoop of sawdust pellets and baking soda to deal with excess moisture and smells. While not difficult, the need to find and maintain this balance makes the unit less like a trashcan and more like a small pet. The unit can also become jammed if you add too much at once, which can be a problem when cooking large meals. That said, I was able to add nearly all of the waste from Thanksgiving dinner without a problem.

The final negative is the noise – especially out of the box, the air pump is surprisingly noisy. Additionally, when the mixer runs, it makes quite a racket. As the unit fills up and the pump wears in a bit, the whole thing quiets down, but the initial out-of-the-box experience is pretty dispiriting in that regard.

Some owners have concerns about smells, but I haven’t noticed any issues in that regard – when adding items, you’ll get a whiff of the compost process, but it’s not particularly unpleasant, and doesn’t linger.

So, the overall verdict then. It’s not a perfect solution. It’s relatively pricey. It’s fiddly. And it may occasionally explode. In regards to actually using the compost, I suspect it’d never be a cost effective alternative to just buying compost at the garden store – you can buy a lot of compost for $250.

And yet, despite all of this, it makes me kind of happy – I honestly find it fun to get to add items and watch nature take its course. It’s one of the most flawed consumer products I’ve owned in years, and perfectly wonderful as well.

Learning to Count in Chinese

This week brought news that a bankruptcy judge has approved the sale of the assets of A123 Systems Inc. to Wanxiang Group of China. This makes me sad – not because I’m a protectionist, afraid of the Chinese – but because of what it symbolizes about the future of energy research and engineering in the United States.

Let’s start with a quick review of A123 Systems. A123 designs and manufactures rechargeable batteries based around lithium nanophosphate technology. In the future, I’m hoping to do more writing about different energy storage technologies, but it’s worth briefly exploring this technology. Lithium nanophosphate is an evolution of traditional lithium iron phosphate batteries. Nanophosphate batteries have a wider state of charge, meaning they’re able to output usable voltage deeper into their discharge cycle. Additionally, they’re more robust across a range of charge/discharge environments and cycles. Finally, they’re relatively safe and resistant to runaway conditions. They’re not exceedingly energy dense (lithium cobalt oxide is better), but for a variety of applications it’s a pretty cool technology.

The A123 technology grew out of research conducted at MIT, and the company principles are MIT researchers. The technology has been used in electric vehicles (the Fisker Karma), high-density energy grid storage, and a variety of industrial applications that benefit from the particulars of this technology.

So, if the technology is relatively robust, why is the company being sliced up by a bankruptcy court in Delaware? A123 certainly had some missteps along their path to commercialization. More fundamentally, as many energy startups have discovered, building a high technology, manufacturing-centric company from scratch is extremely capital intensive. A123 was simply unable to generate enough business quickly enough, and other options for funding did not appear in time.

Ok, a new business didn’t sell enough stuff, so they went away. Pretty normal, right? Heck, most businesses don’t survive. Why get so bent out of shape about this one?

I think the bankruptcy of A123, and the subsequent asset sale, is a canary in the coalmine, a harbinger of things to come.

Green technology, and anything even tangentially related to green technology, has become incredibly politicized. The country experienced a brief flurry of excitement around green technology from 2007 through 2011, spurred in part by a loan program from the Department of Energy. The failure of Solyndra, struggles at other energy startups, and a frigid political climate made the Department of Energy extremely conservative about doling out large loans to green startups. A number of startups that had built assumptions about DOE financing into their business plans suddenly found those resources unavailable.

In the past, these companies may have been able to find more traditional investment through capital markets. Unfortunately, two factors have conspired to make that all but impossible for many of these startups. First, the fallout from the 2008 financial collapse dramatically increased the difficult in finding capital on the scale necessary for these types of endeavors – finding a few million dollars to fund a smartphone app startup with a quick exit strategy is one thing, finding a billion dollars to build a manufacturing pipeline is a bit more difficult.

A far larger long term issue is the dramatic decline in domestic energy costs in the United States, as a result of the increased availability of natural gas from fracking. While the economic argument in favor of green energy was once relatively easy to make, given a bit of hand waving and optimistic projections, the low cost of natural gas has made that argument much more difficult. Because we don’t put a price on carbon in this country, these factors remove much of the economic incentive to invest in green technologies, given a limited opportunity for substantial short-term competitiveness in the domestic energy market.

While I enjoy low energy prices and cool smartphone apps as much as anyone, I’m also aware that the Earth is warming, fossil fuels are being depleted, and world energy use is rising.

As I discussed when writing about Kickstarter, making things is fundamentally difficult. If you think building an espresso machine from scratch is complicated, try building a car. Companies in this space need huge amounts of capital over long timespans, and many of them will fail. Some will fail because they have bad ideas. What worries me is the ones that fail because the ideas haven’t been given enough time or support.

A123 is, I believe, an example of the latter. Proven, working technology, already in the marketplace. An iterative improvement on other proven technology. And, most importantly, a collection of smart scientists and engineers continuing to iterate on future improvements. While we can all hope for massive leaps forward (see lithium-air), the history of successful “innovation” looks much more like A123 than EEStor.

So, A123 went bankrupt, and Wanxiang bid approximately double what Johnson Controls was willing to offer. Some members of Congress have now stepped in with some typical anti-Chinese protectionist arguments, rooted in a distorted understanding of the deal and the technology. While there’ll likely be hearings and protestation, it seems likely that this deal will go through.

The Chinese, like the rest of the world, are operating on a much more realistic understanding of the future energy landscape. It’s laughable to imagine a world in which things like high capacity batteries, photovoltaics, or wind turbines are declining in importance. And yet, we as a nation are choosing to cede our stakes in those technologies to other nations. Once again, this isn’t about protectionism or nationalism, as I have no jingoistic qualms about buying Chinese batteries or Korean solar cells. This is about global competitiveness, economic viability, and maintaining the places we love.

A handful of other “green” companies are on the brink. Fisker is currently scrambling for funding, having seen their future massively disrupted by the suspension of their DOE loans. Tesla, while in a far more robust financial situation, will require large amounts of external capital for the foreseeable future. MiaSole and Solibro have already been sold to China. I’m worried about who’s next.

It’d be more fun to light cigars

Kickstarter, the dominant player in the crowd-funding market, has seen rapid growth and adoption by a wide range of creative endeavors. Dollars committed have nearly quadrupled each year since launch.

With that growth, there’ve been an ever-increasing number of Kickstarter horror stories. Some, like Eyez by ZionEyez appear to have been outright fraud. Others, like Geode are well-intentioned projects that dramatically underestimate complexity and eventually give up. And for the vast majority, proposed timelines prove woefully ambitious.

I’ve been backing projects on Kickstarter for about a year, so it seemed like a good time to reflect on the ups and downs, and think about where it’s going from here. We covered some of this on episode 36 of Divergent Opinions but I want to dive a bit deeper. If you want an insider’s perspective on the Kickstarter process, I highly recommend It Will Be Exhilarating by Studio Neat.

I’ve personally backed 16 Kickstarter projects. Of those, 12 have been successful in achieving their funding goals. That’s a bit above the Kickstarter average of approximately 43% of projects meeting their goals. The total amount I’ve contributed is $604.

I treat Kickstarter primarily as a marketplace for interesting items. I’ll dig into different ways to think about Kickstarter in a bit. But my primarily motivation behind backing projects is because I want the item which is offered as a reward at a given funding level. To a lesser extent, I occasionally back projects for purely altruistic purposes. I suspect that I’m in a majority with this thought process.

Of the projects that have successfully been funded, 9 promised some sort of physical deliverable (books, gadgets, etc). Out of those 9, none have delivered, and 5 have missed their promised deadlines, in some cases by a substantial amount. Of the projects with digital deliverables (music, ebooks), 2 have delivered and none are behind schedule.

That simple statistic provides a pretty good insight into the ramp in complexity between creating a work (writing a book for example) and actually delivering physical copies of that work to people around the world.

So, of my successful projects, 16% have delivered on their promise, representing just 8% of the funds I’ve contributed. This doesn’t come across as a particularly solid investment.

But. I still fund things. Why is that?

Innovation is hard. Having a new idea and seeing it through to fruition is hard. Working out how to ship thousands of widgets around the world is hard. Hell, having boxes made to hold thousands of widgets is hard.

I fund projects because I want the things they’re promising. But more than that, I want the things they’re promising to exist in the world. And I want to support the people who feeling passionately about creating those things.

Let’s look at one project in particular, the ZPM Espresso Machine. Of the projects I’ve backed, this is the most severely behind schedule. The promise is a cafe-grade espresso machine for a reasonable amount of money. This is an incredibly ambitious project, involving not just manufacturing, but manufacturing an object that involves high pressure, heat, liquids and computer control.

At this point, I’d realistically guess that there’s substantially less than a 50% chance that this project will deliver a working, reliable machine to me. And yet, I’m not upset. Yes, I’d like to have that espresso machine, and I contributed funds to the project with the mindset of purchasing the object. More importantly, I want an object like this to exist. The creators saw a gap in the espresso machine market – cheap machines that produce slightly strong coffee are available starting at under $20, real espresso machines cost closer to $1000. While they may not succeed with this project, they’re pushing that market forward, making it clear that there’s a desire, and hopefully learning a lot so that next time, they can succeed.

Kickstarter is approximately three years old. Three years ago, it would have been laughable to think that a couple grad students without offices or factories could produce products that could sit on store shelves alongside products from Krups, Belkin, or Timex. It’s slightly less laughable now. And it’s getting more serious all the time.

I believe that we’re entering a new stage of Kickstarter-backed product development. There’s been enough time for a degree of expertise, specialization, and institutional knowledge to begin to be developed to support these projects. Kickstarter itself is beginning to get more savvy about filtering out projects that are unlikely to succeed. And projects themselves are beginning to appreciate the importance of bringing in outside experts early on.

While it may be too late for these projects, both the ZPM Espresso Machine and the Digital Bolex (of which I’m not a backer) have recently brought in outside project management and production professionals. This, to me, should be de rigueur for any serious hardware Kickstarter project.

Kickstarter, the company, needs projects to be successful. Not just successfully funded, but it needs them to successfully deliver on promises. They’re likely to face substantial legal challenges, in addition to a loss of credibility in the marketplace, if they don’t. And yet, they’ve always taken a hands-off approach to the projects that use their platform. Unlike Quirky, which shepherds projects through the process, Kickstarter is simply a website and a payment platform. I suspect they’ll need to reevaluate that if they want to survive.

In the meantime, I’ll continue to back projects that represent ideas which I believe will make the world a slightly more pleasurable place to be. I’ll continue to support people with big ideas. I know that, barring cases of outright fraud, the frustration I feel towards a project that fails to deliver is nothing compared to the frustration felt by the creators who’ve spent every waking moment trying to follow through on their commitments. In many cases, these projects represent years or decades of dreaming, prototyping, and sketching. While it may seem old-hat in Internet time, we’re still in the very early days of these sorts of projects, and I believe the future is bright.

Onshored, Outsourced, Overhyped

Apple CEO Tim Cook recently discussed plans to bring some Mac manufacturing to the US in 2013. Much of the coverage has focused on the labor aspects of this move – what it says about wages for American workers versus Chinese workers.

While labor costs are surely one part of any decision to move manufacturing, I haven’t seen enough exploration of other aspects, particularly as they relate to the specifics of Mac manufacture.

Tim Cook has repeatedly stated that labor costs are a relatively minor part of the decision to locate in China. Despite being an avowed Apple fanboi, the lefty in in me knows to take anything a CEO says about labor with a grain of salt. If labor in China was double the cost of labor in California, you can be certain that any other logistical issues would be dealt with. However, it’s clear that there are many more issues at play, and the importance of labor cost disparities will be increasingly diminished over time.

While the people sitting on the assembly lines in Foxconn factories doing the day-to-day manufacturing represent relatively unskilled labor, Apple has pointed out in the past that their manufacturing operations in China rely on a huge number of on the ground engineers. These are the sorts of people that develop the manufacturing process, figure out quality control, and make sure that Apple can build tens of millions of iPhones and iPads each quarter.

So, what’s changed? Has the US suddenly trained the number of engineers necessary to run these types of operations domestically? Has some great leap in manufacturing changed that dynamic? I think not. So what other reasons would Apple have to move some manufacturing back to the US, and how could it be feasible?

First, it’s important to note that Tim Cook explicitly said “an existing Mac product line” will be the target of the on-shoring move. (It’s worth noting, though not relevant here, that Mr. Cook also made it clear that Apple won’t be running this operation directly, but will be funding manufacturing partners, as they have in China.) The iOS devices ship in such massive scale that it seems unlikely that the end-to-end manufacturing capabilities (everything from making the cardboard boxes to the earbuds) will be available outside China anytime soon. So, which Mac makes the most sense to move back to the US?

Proudly trading my fanboi hat for my lefty hat, I’m going to operate on the assumption that even Apple doesn’t make decisions like this for altruistic reasons. There’s a business case that’s been made, and that’s what is being acted on. With that in mind, we can review the broad categories of existing product lines and make some determinations.

First, let’s take the laptop lines. To my mind, the laptop lines, and in the particular the Air line, have more in common with the iPad and iPhone lines than with the desktop Mac lines. They’re manufactured in similar ways, with relatively few customization options, are relatively compact, and ship in huge numbers. To me, if the plan were to move Macbook production to the US, we would also hear about similar plans for the iOS device line – it would indicate a dramatic shift in the manufacturing processes in use.

The Mac Mini is, in many ways, a screenless Macbook. It’s a candidate, but given the low profile of the device it seems unlikely.

We’ve already seen indications that some iMacs are being assembled in the US. If you’re not familiar with the differences between Assembled in the USA and Made in the USA, it’s worth taking a moment to read up. While there’s some gray-area here, the assembly of some iMacs in the US seems unlikely to be the end goal. The central feature of the iMac – its gorgeous, large LCD – is unlikely to be made in the US anytime soon. LCD fabrication facilities are long term investments, and it appears that Apple has recently made large investments in LCD manufacturing facilities overseas. The late 2012 iMacs also rely on specialized welding technology for the manufacture of the enclosure. Because this process requires substantial capital investment, which has clearly taken place in China, it’s safe to guess that they won’t be scrapping that investment in 2013 for a domestic move.

That leaves us with the near-dead, oft-forgotten Mac Pro line. We know that something Mac Pro-ish is coming in 2013. Why does the Mac Pro make sense to manufacture domestically?

First, it’s a low-volume product. It’s likely to stay a low-volume product. The market for trucks is unlikely to change substantially in the near future.

The Mac Pro is the only “traditionally” manufactured product in the Apple line. Because of the larger enclosure, the build process is closer to the assembly of a Dell or HP tower than to the assembly of a Mac Mini. This dramatically reduces the scale of the engineering problems that need to be solved for volume manufacture. Components are mounted in an enclosure and connected with cables. The Mac Pro also uses far more “off the shelf” components than any other Apple product. CPUs come from Intel (made, largely, in the US). Graphics cards come from either AMD or nVidia. Commercial spinning disk drives, standard-sized RAM, and full-size power supplies round out the product. While we can’t guess what the future Mac Pro will look like, it seems unlikely to deviate all that radically. The Mac Pro doesn’t include a screen. The components it does use from overseas are compact and easy to transport, and are manufactured by existing, known suppliers.

Domestic manufacturing of the Mac Pro also has a variety of logistical benefits. The small volume means ramping an all-new manufacturing operation from zero is reasonably achievable. The reduced seasonal variability of the Mac Pro line means the more rigid American labor market is less of an issue.

The Mac Pro is by far the bulkiest product in the Apple line. Approximately 540 Mac Pros can fit in a standard 40 foot shipping container. Shipping costs have been relatively volatile in 2012, due to global economic uncertainties and carryover capacity oversupply from the 2008 financial collapse. At the moment, the cost to move a 40 foot container from Shanghai to the West Coast is approximately $2000. While $4 per unit represents a relatively small cost in overall purchase price terms, this represents a large fixed cost on this product line as compared to other Apple products. For comparison, the same shipping container can hold more than 120,000 iPhone 5 boxes, representing just one penny per iPhone.

The Mac Pro is also (I believe) the product most likely to be custom-configured. Buyers have far more customization options, from drives to ram to more esoteric options like fibre channel cards. Customized products represent inventory risks. By moving manufacturing to the United States, Apple can likely reduce inventory costs associated with caching configurations. They could, conceivably, move to a just-in-time approach, wherein your specific Mac Pro doesn’t start down the line until the purchase has occurred, without having to rely on air freight from Asia.

There are a variety of intangible benefits as well – for example, having product manufacture in the US may make it easier to keep manufacturing decisions a secret.

If this is accurate, and we see a domestically manufactured Mac Pro in 2013, I think it’s likely we’ll see a gradual shift in other Mac products, beginning with the iMac and ending with (least likely) the laptops. Given the current landscape, it continues to be exceedingly unlikely that your iPhone will have “Made in the USA” stamped on it any time soon.

So, does the shift of some manufacturing to the US represent a change in heart at Apple? Is it suddenly responding to those who say they’d happily pay more for a domestically manufactured product? Is it about creating jobs in the US? I suspect not. It’s business.

Yet Another Blog Reboot

I’ve lost track of how many blogs I’ve had over the last 15 years.  While most of them have been personal or travel-oriented in nature, I’ve maintained Discrete Cosine – on and off – since January of 2006.

Originally, Discrete Cosine was intended as a video-industry oriented site – news, reviews and tips on things I was doing while working in the TV Studios at the University of Minnesota.  Over time, it followed my migration into academic-technology oriented work, and then became fully dormant when I left the University in August of 2011.

I’ve now migrated the old Discrete Cosine content to the WordPress platform, and that’s where you find yourself now.  Rather than start fresh, I’m considering this a bit of a reboot – I like the Discrete Cosine name too much to leave it behind.

For now, this site will just be a place for me to post thoughts about technology (and related stuff) which are too long to fit in a tweet.

I’ll continue to post more personal content on the major social networks, and my travel blogging will continue to live at travel.discretecosine.com.

We’ll see how long this lasts, but for now, it’s a start.  Please bear with me as I get things a bit more organized.

An introduction to reverse engineering

(This blog is still in hibernation, but I needed somewhere to post this)
Reverse engineering is one of those wonderful topics, covering everything from simple “guess how this program works” problem solving, to poking at silicon with scanning electron microscopes. I’m always hugely fascinated by articles that walk through the steps involved in these types of activities, so I thought I’d contribute one back to the world.
In this case, I’m going to be looking at the export bundle format created by the Tandberg Content Server, a device for recording video conferences. The bundle is intended for moving recordings between Tandberg devices, but it’s also the easiest way to get all of the related assets for a recorded conference. Unfortunately, there’s no parser available to take the bundle files (.tcb) and output the component pieces. Well, that just won’t do.
For this type of reverse engineering, I basically want to learn enough about the TCB format to be able to parse out the individual files within it. The only tools I’ll need in this process are a hex editor, a notepad, and a way to convert between hex and decimal (the OS X calculator will do fine if you’re not the type to do it in your head).
Step 1: Basic Research
After Googling around to see if this was a solved issue, I decided to dive into the format. I brought a sample bundle into my trusty hex editor (in this case Hex Fiend).
1-1.jpg
A few things are immediately obvious. First, we see the first four bytes are the letters TCSB. Another quick visit to Google confirms this header type isn’t found elsewhere, and there’s essentially no discussion of it. Going a few bytes further, we see “contents.xml.” And a few bytes after that, we see what looks like plaintext XML. This is a pretty good clue that the TCB file consists of a . Let’s scan a bit further and see if we can confirm that.
1-2.jpg
In this segment, we see the end of the XML, and something that could be another filename – “dbtransfer” – followed by what looks like gibberish. That doesn’t help too much. Let’s keep looking.
1-3.jpg
Great – a .jpg! Looking a bit further, we see the letters “JFIF,” which is recognizable as part of a JPEG header. If you weren’t already familiar with that, a quick google for “jpg hex header” would clear up any confusion. So, we’ve got the basics of the file format down, but we’ll need a little bit more information if we’re going to write a parser.
Step 2: Finding the pattern
We can make an educated guess that a file like this has to provide a few hints to a decoder. We would either expect a table of contents, describing where in the bundle each individual file was located, some sort of stop bit marking the boundary between files, byte offsets describing the locations of files, or a listing of file lengths.
There isn’t any sign of a table of contents. Let’s start looking for a stop bit, as that would make writing our parser really easy. Want I’m going to do is pull out all of the data between two prospective files, and I want two sets to compare.
I’ve placed asterisks to flag the bytes corresponding to the filenames, since those are known.
1E D1 70 4C 25 06 36 4D 42 E9 65 6A 9F 5D 88 38 0A 00 64 62 74 72 61 6E 73 66 65 72 42 06 ED 48 0B 50 0A C4 14 D6 63 42 F2 BF E3 9D 20 29 00 00 00 00 00 00 DE E5 FD
01 0C 00 63 6F 6E 74 65 6E 74 73 2E 78 6D 6C 9E 0E FE D3 C9 3A 3A 85 F4 E4 22 FE D0 21 DC D7 53 03 00 00 00 00 00 00
The first line corresponds to the “dbtransfer” entry, the second to the “contents.xml” entry. Let’s trim the first entry to match the second.
38 0A 00 64 62 74 72 61 6E 73 66 65 72 42 06 ED 48 0B 50 0A C4 14 D6 63 42 F2 BF E3 9D 20 29 00 00 00 00 00 00
01 0C 00 63 6F 6E 74 65 6E 74 73 2E 78 6D 6C 9E 0E FE D3 C9 3A 3A 85 F4 E4 22 FE D0 21 DC D7 53 03 00 00 00 00 00 00

It looks like we’ve got three bytes before the filename, followed by 18 bytes, followed by six bytes of zero. Unfortunately, there’s no obvious pattern of bits which would correspond to a “break” between segments. However, looking at those first three bytes, we see a 0x0A, and a 0x0C, two small values in the same place. 10 and 12. Interesting – the 12 entry corresponds with “contents.xml” and the 10 entry corresponds with “dbtransfer”. Could that byte describe the length of the filename? Let’s look at our much longer JPG entry to be sure.
70 4A 00 77 77 77 5C 73 6C 69 64 65 73 5C 64 37 30 64 35 34 63 66 2D 32 39 35 62 2D 34 31 34 63 2D 61 38 64 66 2D 32 66 37 32 64 66 33 30 31 31 35 65 5C 74 68 75 6D 62 6E 61 69 6C 73 5C 74 68 75 6D 62 6E 61 69 6C 30 30 2E 6A 70 67
0x4A – 74, corresponding to a 74 character filename. Looks like we’re in business.
At this point, it’s worth an aside to talk about endianness. I happen to know that the Tandberg Content Server runs Windows on Intel, so I went into this with the assumption that the format was little-endian. However, if you’re not sure, it’s always worth looking at words backwards and forwards, just in case.
So we know how to find our filename. Now how do we find our file data? Let’s go back to our JPEG. We know that JPEGs start with 0xFFD8FFE0, and a quick trip to Google also tells us that they end with 0xFFD9. We can use that to pull a sample jpeg out of our TCB, save it to disk, and confirm that we’re on the right track.
2-2.jpg
This is one of those great steps in reverse engineering – concrete proof that you’re on the right track. Everything seems to go quicker from this point on.
So, we know we’ve got a JPEG file in a continuous 2177 byte segment. We know that the format used byte lengths to describe filenames – maybe it also uses byte lengths to describe file lengths. Let’s look for 2177, or 0x8108, near our JPEG.
2-3.jpg
Well, that’s a good sign. But, it could be coincidental, so at this point we’d want to check a few other files to be sure. In fact, looking further in some file, we find some larger .mp4 files which don’t quite match our guess. It turns out that file length is a 32bit value, not a 16bit value – with our two jpegs, the larger bytes just happened to be zeros.
Step 3: Writing a parser
“Bbbbbut…”, I hear you say! “You have all these chunks of data you don’t understand!”
True enough, but all I care about is getting the files out, with the proper names. I don’t care about creation dates, file permissions, or any of the other crud that this file format likely contains.
3-1.jpg
Let’s look at the first two files in this bundle. A little bit of byte counting shows us the pattern that we can follow. We’ll treat the first file as a special case. After that, we seek 16 bytes from the end of file data to find the filename length (2 bytes), then we’re at the filename, then we seek 16 bytes to find the file length (4 bytes) and seek another 4 bytes to find the start of the file data. Rinse, repeat.
I wrote a quick parser in PHP, since the eventual use for this information is part of a larger PHP-based application, but any language with basic raw file handling would work just as well.
tcsParser.txt
This was about the simplest possible type of reverse engineering – we had known data in an unknown format, without any compression or encryption. It only gets harder from here…