What website is that? Did anyone else go to its homepage (http://www.muktware.com/) and notice an unhealthy obsession with Linus Torvalds and exclusive interviews?
No there's a definite creep factor going on with this site. The article page has his image as the background of the website and in the logo...::shudder::
If you check the rest of the site, you might notice that it is a very Linux centric blog. Nothing wrong with that. Also I don't see his image in a logo anywhere on the home page. Only on the Linus interview pages. Seems reasonable to customize sections of a site.
I know his picture isn't in the logo on the homepage...thats why I said "article page". I also never said it was wrong to have Linux-centric blog.
If I were Linus and I saw a blog with my picture as the background of the website, all along the sidebar, and sitting above the blog logo, I'm sorry but I'd be creeped out.
I think he is just the background for articles related to that interview. Although I do agree it is a little weird just how many times his face shows just throughout the site.
Linus Torvalds tends to favour patents, and has three himself.
> I think patents probably work better in certain areas than they do in ours. Software patents? No. Process patents? No. They just don't make sense.
It's not clear from the actual quote that he thinks both software and process patents "don't make sense" as the title states (or just process patents). He probably does, but it's not clear from this interview.
I think he's very insightful about patent and copyright litigation being especially nasty from a legal perspective, because it's winner take all with no middle ground.
Oh, and he think Java and the JVM are "horrible". So consider this polemic approach when assessing his patent views.
Everything we create and think of is based on experiences (sight, smell, feelings....). Therefore it's very strange to have patents. A patent is just a smart mix of things that already exist. Software is always mixing existing things using existing tools. So it's very difficult to have a 'smartness' value for a software patent.
Fortunately Harrison Gray Dyar and Samuel Morse don't have all rights for binary code...
Patents are about ideas and inventions which must be "novel", "useful" and "non-obvious". A smart mix of things that already exist would not be patentable unless it is "inventive", "novel", useful" and "non-obvious". If it is all of these, it should be patentable whether it is software or hardware. (Note however that laws of physics, mathematical formulas, etc. are not patentable.)
What's broken is not the concept of a patent, what's broken is its implementation. Patent applications that do not satisfy the set criterion often get accepted. "Non-obvious" often is equated to "currently non-existing" even though it may be very obvious. (In fact, one of the ways to show non-obviousness of an idea is to show non-existence of it in spite of the problem being existing for long.) As you stated, it is difficult to have a "smartness" value for a software (and I think even hardware) patent.
Another reason why the real-life implementation is broken is that people and companies want it to work both ways based on whether it is helping them or working against them. But nothing specific to software here, the same happens for hardware too.
What needs fixing is the implementation, not the idea itself of the patents, be it software or hardware.
> What needs fixing is the implementation, not the idea itself of the patents, be it software or hardware.
There are two issues here:
1. You assume the implementation is fixable, I have seen no sign of it so far, especially for software and method patents. Even more so as the number of patents applications is skyrocketing worldwide and intellectual propriety offices have neither the resources nor the qualifications (at least in software) to do a good job at it. This is not helped by
2. Patents themselves have little value if there is low risk and investment in what is being patented. That's the case for software (relatively). Even more so because reinventions are very common in software, if you have a given problem there will be converging solutions independently devised. Patents were originally thought of to grant a short-term monopoly to a creator in exchange for that knowledge being public. The goal was twofolds, to encourage potentially costly innovations and to ensure that knowledge gets into public domain at one point, to benefit all.
The second goal is broken by the duration of patents, especially in domains with high rates of innovation (hello software) and the first one is likewise broken in domains with high rates of innovation because patents hinder reinvention (this is made even worse with the new hare-brained schemes of first-to-file as it starts breaking even *pre*invention) or synchronous invention by making them far riskier.
I submit that not only is the implementation broken, but the concept itself is broken for any domain with low investment costs and high innovation rates: for patents to "work" their duration would have to be so low (months, or even weeks) as to make them not worth the time.
When reinvention is too common, and converging solutions to a given problem can be readily devised, it's not a patentable idea by the constraint of "non-obviousness". But such patent applications readily get granted still. That does not mean the concept (including non-obviousness requirement) is flawed. I agree that it may be impractical given that non-obviousness is not measurable.
The duration of the patent in my terminology is also an implementation issue and not a conceptual issue. I agree that in today's world, twenty years are a bit too long. Or rather inventions that can be so readily made should be failed on "non-obviousness" basis again.
The real issue is this: Not the patent system, but the companies are interested in protecting "everything" they do. The law does not provide protection for everything. Copyright applies to specific material or implementations while patents apply when those three constraints are met. There are clearly things that are not protected by either and they should remain as such. The issue is that they don't (and both companies and patents office are responsible for this).
To fix (the implementation), the bar on non-obviousness, novelty, etc. as well as the duration of the patent needs to be made commensurate with the reality, taking into account the low investment costs and timeline that you mention. Maybe even by having varied durations for different domains just as the non-obviousness bar is different for different domains just by virtue of being unmeasurable.
All in all, I have not heard any real reason why software patents should be distinguished from other patents, other than possibly having the bar on them and duration adjusted accordingly.
It would seem that one of the main arguments against software patents that is thrown around is that "software is mathematics". As a software engineer currently knee deep in learning Haskell, I believe that this argument carries plenty of weight. However, when judging software patents, we shouldn't overlook the reason for which patents themselves were originally invented.
I think the best description of a patent that I ever heard was:
"A government granted use monopoly in exchange for full disclosure of how the invention works."
This is, in my opinion, not a bad idea. It promotes the sharing of knowledge, whilst not depriving the inventor from the spoils of their work, but only if a full, formal design of a working system is disclosed.
In software, patents are granted based upon a technical description of the concept. But the requirement of a formal definition - which in the case of software boils down to either a proven mathematical model, or some code that implements the concept - is absent. Since written language is full of ambiguity and uncertainty, it is very possible and regularly the case that patents are granted on an idea that provides no concrete specification. As a result, the disclosure part of the agreement is not satisfied.
True that mathematical formulas and laws of physics are not patentable. However, a specific use of either to solve a specific problem is patentable provided the three constraints (non-obviousness, usefulness and novelty) are satisfied.
Software is not mathematics -- A computer science algorithm could arguably be, but "software" is not. Software is a specific implementation using that mathematics that sits onto your CD or hard-disk where "mathematics" cannot sit (sure copyrightable representations of that mathematics do). And software gets appropriately subject to copyright laws.
Applying software to solve a specific problem is no different than applying hardware or mathematics to solve a specific problem. If those patent-ability constraints are satisfied, there is nothing wrong with software patents "in principle". Fixing the practice is another thing.
Second refutation I have comes from my personal experience. No, most of the software developers are not mathematicians. Often far from that in practice. Many don't even understand computer science (including myself partly). We can still however make software inventions that satisfy the three constraints.
I know this topic remains debatable. And at least a part of the reason is that the issues are often not correctly understood by people and the law-makers. Add to that the pace at which laws are adjusted to changing practices in the industry.
>> the disclosure part of the agreement is not satisfied
Again, a software patent is not about the software. It is about that technical description of the concept. That concept is what carries the invention (while the software itself carries a copyright). Written language is indeed full of ambiguity and uncertainty but the language of patent claims is not (some separate comments in this thread talk about this). When deemed necessary, source code is included in a patent application. Flow-charts are also often included. But all of that is out -- the core part of a patent are the claims, written in a well-defined unambiguous language that defines the concept of invention as clearly as possible and it does not need diagrams and source code.
The purpose of a patent isn't to grant ownership over mixes of things that already exist. The purpose of a patent is to incentivize full disclosure of novel ideas, ideas that otherwise would be locked up as trade secrets, by trading disclosure for time-limited monopolies over those ideas.
The patent system isn't a prize we give to people for innovating. It's one of the ways we pay people to document and publish their inventions.
Irony: Samuel Morse did in fact vigorously patent his inventions.
Sometimes people say silly stuff that isn't particularly relevant. They're making a mistake. You don't have to explain it.
If you do, maybe someone like me who is interested in meta topics like conversation itself will appreciate it, and maybe you'll enjoy writing it, but you can't expect it to further the conversation you were having, and can't really expect the silly person to learn much.
What novel ideas did the One-Click patent cover? Seriously.
I think we're overpaying. And we're not paying the actual creative types. And we're not paying for what's really useful, just what receives the paperwork and has enough lawyers to attack based on it.
If we really wanted to do this right we'd have a big vote for the people who made things (even textbooks, etc, like Knuth) that made the biggest difference in their industry. Then we'd take the money not being wasted on patents and give it to these people as part of a Technical Excellence Award. They'd also trickle some upwards to their resources and mentors, as disclosed before you voted.
It's still got some holes in it but it's a better system because there are no limits on industry. No government employee is breaking open boxes of smart-phones and denying the right to sell them because they use some exclusive new innovation. That's just more proof that whoever invented that deserves more votes.
You're describing a patent system that functions as an achievement award. But that's not the purpose of a patent. Knuth already published his best work without the incentive of a patent. The extra award would not get him to publish a new volume of TAOCP any faster.
Think of it this way: to function as intended, the patent system has to make it economically less attractive to closely hold inventions as trade secrets. Your idea, however laudable it is, doesn't do that.
I don't really understand your objection. If, instead of trying to impose an artificial scarcity on copyable works (which includes inventions), we had a pool of "awards" that were distributed to creators proportionally to the value of the works, then of course that would provide incentive to disclose copyable works. So what if Knuth would get paid for work he would have made available anyway? There are plenty of people in our economy getting paid to do what they love and would do for free/much less.
The main problem with the idea is that it eliminates negotiations between self interested parties as the means for value estimation. "Voting" on the most valuable works is quite simply a terrible idea. With copyrightable works, we could probably have some technological way (think DRM) of tracking popularity / frequency of use. But for patents, I'm not sure how it would work. I suppose that as long as you make it where the total tax levied on an individual to fund this system doesn't depend on how many or which works they used (though it could depend broadly on what they produce, what industry they are in, etc), they won't have an incentive to hide what they used. It's not at all clear to me that the difficulties inherent in such an approach are greater than those in current approach (which can be charitably describe as "a mess").
The notion behind patents is that if we didn't have them, society would be poorer off because people would invent things and then keep them secret, perhaps far longer than the term of a patent, like the formula for Coca Cola.
No, the award system that's being discussed leaves applicants with no certainty that they'll actually be compensated for disclosing. That's not the case with the patent system; subject to modifications, competent patent applicants are virtually certain to get a patent 7 years after applying.
The existing patent system doesn't guarantee you'll be compensated. In fact, most patents are worthless. The award system could easily incorporate a patent scheme, based either or first to file or first to invent. The important difference between this system and our current one is that licenses are not negotiated. Compensation is decided after the fact based on actual use.
Yes, in the current system if you inject enough money you're virtually certain to receive a patent. Otherwise you wouldn't play again...
But, there's no guarantee of reward. Far from it, you've only got a letter of marque, not the ship or crew to profit from it with.
In a reward system it'd be totally different. No applications, no licenses, just instant wide disclosure. If you don't tell people they can't use it and you won't get rewarded.
And you could just document and teach someone else's invention and get rewards that way, in proportion to the value of the accessibility you added.
Linus: "I don't actually know the details. I mean Java I really don't care about. What a horrible language. What a horrible VM. So, I am like whatever, you are barking about all this crap, go away. I don't care."
Why? He just bashes Java using strong language and not providing any arguments. This could get my respect if Java were some kind of sacred cow that nobody dares criticize. This is not the case AFAIK.
Why do so many people say Java is slow? What's slow? In fact Java compares fairly well against pretty much everything except C.
It's a memory hog, but it sure isn't slow, whatever that means.
You must think everything but well optimized, hard to write and read C/C++ is slow and bloated then. Which is fine if that is what you are comparing it to.
It's rare that I've seen the Java VM described as horrible.
In fact, it seems to be quite highly respected and seems to be working out well for Scala and Clojure. Obviously, there's also Twitter who partially moved to the VM from Rails.
Would you care to elaborate? Has Linus talked about the VM before?
The Java VM is quite bad. There just isn't an alternative that meets these criteria:
1. cross platform (windows, mac, linux, mobile devices, embedded)
2. kinda fast
3. reasonably mature
4. bunch of libraries
If you want to create a new programming language today Java is the only viable platform. .NET and Mono isn't quite mature enough (and it's very similar to Java anyway). If you bootstrap from C it'll be fast and portable but you'll have no libraries for the first 5 years or so.
There just isn't a low level language layer, just above C that can be used for interopability between programming languages. What we need, what we really need, is some sort of Java--. A simple bytecode layer that other languages can target. So libraries written in one language can be used (and inspected) from another language. I know it's not going to happen anytime soon, but it'd be nice.
Correct me if I'm wrong, but aren't you confusing Java the language with the actual JVM? On your last paragraph, you pretty much described what the JVM is in my perspective.
There is no proper separation of concerns in the JVM. The JVM instruction set has instructions like `invokevirtual` and `invokestatic`, `invokeinterface`, which are Java specific features. The JVM also knows the concept of classes and methods and fields, even though those abstractions should be defined at the language level, not at the VM level (a Lisp or Forth-like stack machine needs different abstractions).
The datatypes in the JVM are pretty weird. You have chars, but not unsigned chars, some integer types (but not all). You have no support for unicode. There is a low-level struct for arrays and multidimensional arrays (of a specific type), but for nothing else. It supports exceptions, but only Java like exceptions. (You can't make an exception system where execution can be retried or resumed; it's just not supported). It also has a java-specific thread model (want to create lightweight threads with lockfree data structures? nope, not gonna work).
What you want is a low-level platform with different modules that can be picked by the people who implement the programming language. Pick a parser module, a garbage collection module, a JIT compilation module, and so forth. This is really difficult, because you have to have a good understanding what kind of primitives different programming languages need. When all these things are fixed and non-interchangeable you end up with a virtual machine that is suitable only for a specific kind of language. It's turing complete, so of course you can make any language on the JVM, but it's just not a good fit.
It sounds like you're saying The JVM is the worst possible VM, except for the alternatives
My understanding is that it is state-of-the-art, and includes many innovations (unlike Java itself). Of course, state of the art does not mean perfect. There's still room to improve, which the JVM, CLR or some other VM might manage. But it seems over-the-top to bash the best in the world. It's like saying that, as a sprinter, Usain Bolt is quite bad.
The real tiger is never a match for a paper one, unless actual use is wanted. - Brooks
Parrot is basically just a VM for Perl. The opcodes are tied heavily to Perl 6 semantics (type coercion for everyone, the string "0" is false, etc etc).
Intellij, Eclipse and Netbeans, great software written in Java. Haddop, as well. Not to mention Minecraft, but this point I'll leave to Techcrunch[1]
Java is not a great language by all means, the VM does have it issues (it is very old, and has to deal with its legacy), but it is not on a really important piece of software, its quality is quite good.
At the very least, it is, ironically, responsible for LISP's renewed interest through Clojure.
It's highly respected by people who are willing to use JVM based software. Frankly, typical JVM startup times alone is enough of a pain that I avoid anything-JVM if I can.
> " Frankly, typical JVM startup times alone is enough of a pain"
The default JVM options are biased toward long running processes. That's kinda what most software running on a JVM is going to be though - start it running, leave it for weeks.
If you want a JVM that is tailored for short lived processes, then quick startup time is just a few options away after you RTFM. Or use a language/runtime more tailored to short lived scripting.
FWIW I've never seen a JVM take more than a second to startup though, which is more than adequate for server software.
Well I didn't know that US patent cases can be presented to a jury. I don't envy them on that considering the language these things are written in.
I wonder how many hours are spent 'training' the jury in the legalese required to understand the case? And this would have to be done for each and every case that has a jury!
Patent claims constructions are carefully written so as to present a decision tree to the court. The court translates the language into that decision tree worded for laypersons; expert witnesses for both sides make arguments at each node of the tree.
It's the judge's responsibility to explain the legal basis to the jury in the form of jury instructions. These will usually be created in consultation with the lawyers for both sides.
Trial by jury is the reason why East Texas is the court of choice for patent claims. For some reason jury verdicts there seem to be biased towards the patent holder.
I should also note that being a juror in a federal case sucks. The first issue is that you're "on call" as a juror for 30 days instead of a day or two like most counties/municipalities. The second part is the cases are usually boring. People don't like to bring cases that they're likely to lose to a Federal court.
As 'tzs pointed out a few weeks ago, the East Texas issue is something that the America Invents Act (the recent patent reform bill) actually addresses:
> Trial by jury is the reason why East Texas is the court of choice for patent claims.
Not true. The local rules in the Eastern District are seen as favorable to patent plaintiffs. It's (basically) nothing to do with the jury pool out there.
Don't you just love this quote:
"I mean Java I really don't care about. What a horrible language. What a horrible VM. So, I am like whatever, you are barking about all this crap, go away. I don't care."
Possibly because it's duplicated content. They were both posted about the same time, so it's arbitrary which gets voted up and which gets voted down. But ideally only one would exist; voting one into oblivion is the easiest way to approximate that situation. I'm just speculating though.
"... and that's the reason you have to have a patent lawyer because the language makes no sense. In US it’s technically English but it’s not really English. It’s like using English words but there are different meanings to them. There is a whole different set of rules about what things mean when they do a patent application."
Well guess what - that is not unusual when everyday words migrate into a technical area and the law is such an area. To complain about words having specialist meanings in a specific subject area strikes me as naive.
While I certainly agree that it can seem naive, when it comes to law it is taken to such an extreme that it's almost to the point that definition of "is" isn't "is" anymore.
Yes, it's naive. They're naively believing the legal fiction that patents are supposedly required to enable a reasonably skilled practitioner in the field of the patent to be able to reduce the invention to practice in a straightforward way from reading the patent.
But you're right, patents are for lawyers, not software practitioners. We should expect them to use a technical language that they, not we, understand.
Bear in mind that a patent consists of several sections and these sections vary a great deal in how intuitive the use of language is.
The section which Linus is almost certainly referring to is the claims. These are indeed expressed in a technical vocabulary which is tricky for a lay person to penetrate.
But the section which is supposed to enable a person ordinarily skilled in the art to be able to make the invention is not written in such vocabulary. On the contrary, it typically written in language which is perfectly comprehensible. The difficulty if any is in having the patience to read a tediously long description with endless references to diagrams.
Wouldn't that be nice. Now consider the case of a pharmaceutical company that has to spend hundreds of millions of dollars to develop a new drug and get it past FDA. If there is no IP protection would you as the CEO of this company spend that kind of money on innovating when the resultant drug could be copied a week after it appears on the shelves? In this case you would be competing on product alright - exactly the same product. But the copier has had no R&D cost and can undercut you and put your offering out of business.
The issue is often framed in terms of all patents being bad, or all software patents being bad but to anyone to gives the matter more than the kind of superficial thought stemming from ideology the reality is rather more complicated.
Pharmaceutical and other physical patents make sense and appear to work. But arguing that software companies won't innovate without patents ignores the fact that software companies did innovate without patents, for years. And software patents obviously haven't been working: see Microsoft's patent on "if not", among other things.
You are absolutely correct. There are differences between the two industries. The two key ones would seem to be that (a) the investment required in time and money to create the software and its likely lifetime value are low compared with a drug, and (b) the ease of difficulty with which the software may be copied can vary a great deal. Compiled source code is harder to reengineer than a drug. Server side code that is held as a trade secret, such as google's search algorithms, is hard to recreate. So in these cases it is quite true that there has been innotation (ignoring the fact google did have some IP protection). But there are cases I can think of where it would be downright foolish for a software company, particularly a small one, to invest substantially without protection. The key characteristic is that the code cannot be held secret and can be readily read and thereby copied. The key point is that it really isn't very helpful to generalize to broadly about the software industry.
I do not think a lawyer have to specialize in patents specifically to support byzantine laws. I think it is the willingness and propensity to accept laws and regulations for everything.
Have you ever talked to an IP lawyer? It is surprisingly difficult to become one. You responded to an interesting point with more superficial innuendo about congress.
If Congress wanted software patents to be legal, Congress would have made them legal in 1972 or 1973. They wouldn't have waited around for the Federal Circuit court to contradict previous Supreme Court opinions.