ESP Wiki is looking for moderators and active contributors!

Why software is different

Revision as of 14:51, 1 December 2009 by Mhkay (talk | contribs) (Statistics)

Software is different to traditional fields of engineering in many ways.

Statistics

"[s]oftware patents are more than twice as likely to be litigated as other patents" - Bessen & Meurer, at 22.

Mathematical nature

The rules that exclude software from patentability do so on the grounds of similarity with mathematics: you should not be able to patent a mathematical formula, and an algorithm is essentially the same as a mathematical formula. A mathematical formula is not patentable because it is like a law of nature: it is a discovery, not an invention.

Abstraction

Software is highly abstract: you can't look at two pieces of software from the outside to see whether they look the same. Two engineers will describe the same piece of software in very different terms. It's therefore highly subjective whether the ideas embodied by one piece of software are essentially equivalent to the ideas in another. In short, there is no objective test for infringement.

The test of obviousness

Because software is abstract, the test for whether an idea is obvious "to one skilled in the art" is very difficult to apply. The test cannot be based on the amount of effort expended in working out the idea, because the least obvious ideas are often the simplest. Nor is it clear what it means: what if an idea is obvious to a thousand of the best programmers in the world, but not obvious to a million others? Simultaneous and independent invention is not unique to the software field, but it is certainly a characteristic feature of software that good programmers will tend to come to the same solution independently.

Prior art

Because software is invisible, determining prior art is notoriously difficult. Many software patents appear to be granted despite the ideas being well known to practitioners, but it can be very difficult to find acceptable documentary evidence that the ideas were already in widespread use. Most programmers do not publish written papers about their work, for a variety of reasons: they are too busy, they don't consider the idea significant, or they don't want their competitors to know what they are doing.

Continuous innovation

Programming is by its nature innovative. Programmers have new ideas every day, in a way that is not true of engineers in other fields. If every new idea were patented we would have billions of patents rather than merely tens of thousands. Many of these new ideas have little significance, but there is no meaningful way of distinguishing those that deserve a patent monopoly from those that do not.

By the same token, it is impossible for programmers to check every time they write a line of code whether it infringes a patent. Programmers take the risk of patent infringement every day, because they have no realistic alternative. It is unfair that society should penalise them for this.

The 2008 Berkeley Patent Survey

The 2008 Berkeley Patent Survey revealed big differences between software companies and biotechnology companies in their use of patents.

How patents on different domains affect society

One thing to keep in mind is that plenty of things are excluded from patentability. Being excluded doesn't mean that software is special.

For the manufacturing of cars, you have to consider how patents will affect:

  1. the cost of mass production
  2. the impact on quality/safety of what's offered to citizens
  3. the impact on the economy overall

Campaigners against software patents are usually not general experts on those topics, so we might not know if innovations in car manufacturing should be patentable or not.

For software, there are similar questions to the three above, plus there is the fourth question of individual liberty and the effectiveness of communities.

This question isn't pertinent to car manufacturing because individuals and communities don't manufacture cars in significant quantities - or at all.

If someone patents a method for making a car, that doesn't reduce people's liberty. Making cars requires a lot of cash and materials, and there are already many laws that places regulations and restrictions on making cars. So people already excluded. Adding a patent problem doesn't change anything.

For one thing, software is mass produced by individuals and groups who don't get paid directly for that work (or do it for non-commercial reasons). Adding the cost of the patent system is unfair to these people.

Communities write great software (a community wrote most of GNU/Linux). People should continue to have their right to participate in the development and distribution of software, and to continue to benefit from the work of the vast community that develops the software that people use. Patents would create problems for individuals' liberty, and for the general software development which society as a whole benefits.

Related pages on ESP Wiki

External links

Counter articles