All posts by Like Tangents In The Rain

Update: Laser v Xenon; Let’s See…the End Game

Seven months later Christie did somewhat the same, but made the demo last for 2 weeks. The initial show was fine, with no horror and a lot of good questions answered well. Seeing the presentation 2 weeks later was a bit of a different story, but no one broke the code of silence, and without going into details or in any way mocking their great efforts, let it just be said that we often learn more from our errors.

One thing that has been missing in all the past laser demos (SMPTE 2012 with Sony and LLE, Barco at CinemaCon 2012, Christie at IBC 2012 and pre-CinemaCon 2013 at AMC) has been real comparative viewing: Step by step, side by side, scene by scene, slow and with time for reflection (so to speak). Finally, that is what is being promised.

LLE makes splashy entrance for side by side demo

Thankfully, the PDF tells more of the tale than the PR Poster which simply says Hold the Date – 11-14 November at Technicolor’s Theater in Burbank.

“…the sessions will feature LLE’s latest RGB laser engines specifically adapted to an NEC 4K DLP Cinema® projector, to demonstrate image quality and despeckling performance, in side-by-side comparisons with an identical NEC 4K Xenon arc lamp projector.”

“…The event will also offer presentations and breakout sessions to explore the recent advances in laser illumination technology that make it a viable commercial solution for movie theaters, large venues, and theme park attractions. Scheduled sessions include a series of mini-tutorials on image quality, colorimetry, contrast ratio, speckle reduction, and the use of fiber optic light delivery to retrofit current and future projectors.”

One wants to see despeckling without shaking the screen. After reading the SMPTE paper Further Investigations Into the Interactions Between Cinema Loudspeakers and Screens (Brian Long, Roger Schwenke, Peter Soper and Glenn Leembruggen), one is suspicious of more things than one was before. More potential points of failure doesn’t seem like a good idea in any case, and one appreciated the Beck demonstrations at SMPTE/NAB and SMPTE Hollywood at the Academy that shows how tuning frequencies has the benefit of getting more watts from the wall (or some other user cuddly phrase) while tweaking for the proper light frequency.

But the real treat will be the side:side. It has been needed for a long time for both science and satisfaction. Who will be the first to declare that metamerism is a non-issue? Who will be the first to say that extended color gamut may be nice but a light source that doesn’t drop 15% during the first 100 hours of use is a much bigger issue? (Not to say that seeing greener greens or greater blue-green blue-greens won’t be cool.)

Now that there are 100,000+ DCI level projectors in the field, there is a logic to retrofits. But all arguments in that favor seem dim when compared to the potential elimination of expensive optics and lenses that will come with laser direct to the chip and everybody understanding bien étendue, of course. Perhaps we can flesh this out a bit in a future article.

The PDF is attached below. See you there.

Laser Light Engines – LLE – Save The Date Poster

States of Exhibition–Evolution

 

Snippet of Drawing: DCinema Facility

DCinema could be said to have started before the turn of the century, or possibly when George Lucas pushed so hard to get the first 100 systems installed to light up Attack of the Clones in 2002. My moment of ‘made it’ came during the set-up week prior to the Cannes Film Festival in 2004, when projector-derived subtitles were working on a 2K projector.

 

So choosing that date as when the R&D project stopped and real products began, we’re closing in on 10 years of evolution. Some tools came very recently, such as implemented standards and products for the deaf/blind/hard of hearing and visually impaired audience members. In North America there has been several chains which are now 100% covered for 100% of movies with closed caption and enhanced and descriptive audio. Obviously 3D got past the needles-in-the-eyes stage of Chicken Little, and it will only get better when laser light engines get integrated with HFR…and by that one presumes it will have to be after all the NIH leaves the projector manufacturers and 48fps leaves the field of HFR.

Here’s a drawing that tries to show the evolution to the degree that a 2D drawing can show such details. Anyone who wants to help map it into HTML for some obvious cool tricks is invited to write [email protected] – likewise, anyone who needs to strip the sponsored bits to make the drawing into a teaching device…please write. It is an evolving drawing as well, so if you’d like to be informed when revisions are made…you’ve got the address.

The full drawing is at: 
DCinema_Auditoria_and_Equipment_Network.pdf

States of Exhibition–Evolution

 

Snippet of Drawing: DCinema Facility

DCinema could be said to have started before the turn of the century, or possibly when George Lucas pushed so hard to get the first 100 systems installed to light up Attack of the Clones in 2002. My moment of ‘made it’ came during the set-up week prior to the Cannes Film Festival in 2004, when projector-derived subtitles were working on a 2K projector.

 

So choosing that date as when the R&D project stopped and real products began, we’re closing in on 10 years of evolution. Some tools came very recently, such as implemented standards and products for the deaf/blind/hard of hearing and visually impaired audience members. In North America there has been several chains which are now 100% covered for 100% of movies with closed caption and enhanced and descriptive audio. Obviously 3D got past the needles-in-the-eyes stage of Chicken Little, and it will only get better when laser light engines get integrated with HFR…and by that one presumes it will have to be after all the NIH leaves the projector manufacturers and 48fps leaves the field of HFR.

Here’s a drawing that tries to show the evolution to the degree that a 2D drawing can show such details. Anyone who wants to help map it into HTML for some obvious cool tricks is invited to write [email protected] – likewise, anyone who needs to strip the sponsored bits to make the drawing into a teaching device…please write. It is an evolving drawing as well, so if you’d like to be informed when revisions are made…you’ve got the address.

The full drawing is at: 
DCinema_Auditoria_and_Equipment_Network.pdf

Interesting Immersive

The politics of immersive audio is proving to be more difficult than the technology. No writer is able to tell the whole story, even if someone was able to figure all the angles.

Here are a couple of good articles, one on the technology, one on the politics.

From Page 15 of CineMontage – The Editor’s Guild Magazine, May/June 2013 – Mel Lambert details technology and interviews to give an excellent impression of immersive audio’s status at that time.

Rivalries go deep in immersive cinema – Professional Sound News | Sound & Audio Industry News | PSNE

If you are a SMPTE member, please get involved with the committee work that is moving forward.

Interesting Immersive

The politics of immersive audio is proving to be more difficult than the technology. No writer is able to tell the whole story, even if someone was able to figure all the angles.

Here are a couple of good articles, one on the technology, one on the politics.

From Page 15 of CineMontage – The Editor’s Guild Magazine, May/June 2013 – Mel Lambert details technology and interviews to give an excellent impression of immersive audio’s status at that time.

Rivalries go deep in immersive cinema – Professional Sound News | Sound & Audio Industry News | PSNE

If you are a SMPTE member, please get involved with the committee work that is moving forward.

Blending the Basics of Audio and Light (Pictures): Part One

It would be truly special if there was a knob-based solution for these issues, but a knob doesn’t even work for the first problem of increased volume (pardon the pun). To explain the reasons why goes into the gory details of reminding the reader that the difference between 80 watts of amplifier power and 100 watts of amplifier power is – at best – only 1dB of power at the speaker.

“At best” includes all the mitigating factors of distance and direction and absorption/reflection/phase that waves get tampered by. The effects of cable and connectors, the type of box that the speakers are in and the speakers themselves will determine whether adding more power at the front of the process will add significantly at the far end of the process (the audience’s ears), not only with quantity, but without making the quality worse.

And let’s not forget that an audience in thick winter clothing will hear something different than the mixer who was behind a flat reflective mixing console in comfortable clothes. Nor should we forget that the human hearing system doesn’t perceived all frequencies the same: for example, an increase of 2dB at 1kHz will require x power, but the same increase in perceived volume at 100Hz would require several times x power, and the lower the frequency the more power needed. See:Equal_Loudness_Contours and Phon.

The higher frequencies have their own problems getting through the perforations of the movie screen, but they also have problems with the sound waves that don’t make it through and which bounce back into the speaker that is busy producing the next waves. Increased level just increases phasing problems, and that ain’t the half of it. This and other facts are detailed in two papers in the December 2012 SMPTE Motion Imaging Magazine: Further Investigations Into the Interactions Between Cinema Loudspeakers and Screens and Can We Make Movie Theaters Sound Better and More Consistent? [Membership link]

So, there. Audio. From being able to hear a mosquito buzz at 3 meters, to understanding the roar of a jet engine (for not more than a slice of a second please…), that’s 15 orders of magnitude of sound pressure whether you measure it as Watts: 10-12 – 103 W/m2, or dB of Sound Intensity level (a logarithmic scale): 0 -150 dB, or in Pressure in Pa: 0.00002 to who knows…maybe 600 rms. What ever unit is used, what they are measuring is called Dynamic Range.

And just in case you were wondering, it isn’t much different for light. The amount of light that the human visual system can handle is defined by the sun (like the jet engine, not to be endured for not more than an extremely small slice of a second), which measures in at 1.6×109 cd/m2 at noon, while the dimmest that the eye can see, the threshold of vision, is 0.000003 cd/m2. Give or take an order of magnitude, sound and vision have much the same dynamic range. For both the ears and the eyes there are also a number of ranging mechanisms to protect the system while allowing this dynamic range – some physical, some chemical, some electronic.

Both sound and vision deal with waves and and a vary tight bandwidth of frequencies. It is these that we deal with when we design systems to play movies and sound in an auditorium. Fortunately they are spaced so far apart that they don’t interact with each other, but that is about the only benefit a scientist has when trying to reproduce stimulus recorded and stimulus played back. These waves interact and react differently at small differences in distance.

Which brings us to the end of Part One of this study. Further on we will look at what immersive audio systems and better screens and laser light engines are trying to solve – and it isn’t some conspiracy to put butts in seats and money in someone’s pocket. There are real problems with real compromises at every decision point. We’ll discuss speaker excursions and laser frequencies on the power curve in the next article.

Blending the Basics of Audio and Light (Pictures): Part One

It would be truly special if there was a knob-based solution for these issues, but a knob doesn’t even work for the first problem of increased volume (pardon the pun). To explain the reasons why goes into the gory details of reminding the reader that the difference between 80 watts of amplifier power and 100 watts of amplifier power is – at best – only 1dB of power at the speaker.

“At best” includes all the mitigating factors of distance and direction and absorption/reflection/phase that waves get tampered by. The effects of cable and connectors, the type of box that the speakers are in and the speakers themselves will determine whether adding more power at the front of the process will add significantly at the far end of the process (the audience’s ears), not only with quantity, but without making the quality worse.

And let’s not forget that an audience in thick winter clothing will hear something different than the mixer who was behind a flat reflective mixing console in comfortable clothes. Nor should we forget that the human hearing system doesn’t perceived all frequencies the same: for example, an increase of 2dB at 1kHz will require x power, but the same increase in perceived volume at 100Hz would require several times x power, and the lower the frequency the more power needed. See:Equal_Loudness_Contours and Phon.

The higher frequencies have their own problems getting through the perforations of the movie screen, but they also have problems with the sound waves that don’t make it through and which bounce back into the speaker that is busy producing the next waves. Increased level just increases phasing problems, and that ain’t the half of it. This and other facts are detailed in two papers in the December 2012 SMPTE Motion Imaging Magazine: Further Investigations Into the Interactions Between Cinema Loudspeakers and Screens and Can We Make Movie Theaters Sound Better and More Consistent? [Membership link]

So, there. Audio. From being able to hear a mosquito buzz at 3 meters, to understanding the roar of a jet engine (for not more than a slice of a second please…), that’s 15 orders of magnitude of sound pressure whether you measure it as Watts: 10-12 – 103 W/m2, or dB of Sound Intensity level (a logarithmic scale): 0 -150 dB, or in Pressure in Pa: 0.00002 to who knows…maybe 600 rms. What ever unit is used, what they are measuring is called Dynamic Range.

And just in case you were wondering, it isn’t much different for light. The amount of light that the human visual system can handle is defined by the sun (like the jet engine, not to be endured for not more than an extremely small slice of a second), which measures in at 1.6×109 cd/m2 at noon, while the dimmest that the eye can see, the threshold of vision, is 0.000003 cd/m2. Give or take an order of magnitude, sound and vision have much the same dynamic range. For both the ears and the eyes there are also a number of ranging mechanisms to protect the system while allowing this dynamic range – some physical, some chemical, some electronic.

Both sound and vision deal with waves and and a vary tight bandwidth of frequencies. It is these that we deal with when we design systems to play movies and sound in an auditorium. Fortunately they are spaced so far apart that they don’t interact with each other, but that is about the only benefit a scientist has when trying to reproduce stimulus recorded and stimulus played back. These waves interact and react differently at small differences in distance.

Which brings us to the end of Part One of this study. Further on we will look at what immersive audio systems and better screens and laser light engines are trying to solve – and it isn’t some conspiracy to put butts in seats and money in someone’s pocket. There are real problems with real compromises at every decision point. We’ll discuss speaker excursions and laser frequencies on the power curve in the next article.

How I Explained REST to My Wife

Wife: Who is Roy Fielding?

Ryan: Some guy. He’s smart.

Wife: Oh? What did he do?

Ryan: He helped write the first web servers and then did a ton of research explaining why the web works the way it does. His name is on the specification for the protocol that is used to get pages from servers to your browser.

Wife: How does it work?

Ryan: The web?

Wife: Yeah.

Ryan: Hmm. Well, it’s all pretty amazing really. And the funny thing is that it’s all very undervalued. The protocol I was talking about, HTTP, it’s capable of all sorts of neat stuff that people ignore for some reason.

Wife: You mean http like the beginning of what I type into the browser?

Ryan: Yeah. That first part tells the browser what protocol to use. That stuff you type in there is one of the most important breakthroughs in the history of computing.

Wife: Why?

Ryan: Because it is capable of describing the location of something anywhere in the worldfrom anywhere in the world. It’s the foundation of the web. You can think of it like GPS coordinates for knowledge and information.

Wife: For web pages?

Ryan: For anything really. That guy, Roy Fielding, he talks a lot about what those things point to in that research I was talking about. The web is built on an architectural style called REST. REST provides a definition of a resource, which is what those things point to.

Wife: A web page is a resource?

Ryan: Kind of. A web page is a representation of a resource. Resources are just concepts. URLs–those things that you type into the browser…

Wife: I know what a URL is..

Ryan: Oh, right. Those tell the browser that there’s a concept somewhere. A browser can then go ask for a specific representation of the concept. Specifically, the browser asks for the web page representation of the concept.

Wife: What other kinds of representations are there?

Ryan: Actually, representations is one of these things that doesn’t get used a lot. In most cases, a resource has only a single representation. But we’re hoping that representations will be used more in the future because there’s a bunch of new formats popping up all over the place.

Wife: Like what?

Ryan: Hmm. Well, there’s this concept that people are calling Web Services. It means a lot of different things to a lot of different people but the basic concept is that machines could use the web just like people do.

Wife: Is this another robot thing?

Ryan: No, not really. I don’t mean that machines will be sitting down at the desk and browsing the web. But computers can use those same protocols to send messages back and forth to each other. We’ve been doing that for a long time but none of the techniques we use today work well when you need to be able to talk to all of the machines in the entire world.

Wife: Why not?

Ryan: Because they weren’t designed to be used like that. When Fielding and his buddies started building the web, being able to talk to any machine anywhere in the world was a primary concern. Most of the techniques we use at work to get computers to talk to each other didn’t have those requirements. You just needed to talk to a small group of machines.

Wife: And now you need to talk to all the machines?

Ryan: Yes – and more. We need to be able to talk to all machines about all the stuff that’s on all the other machines. So we need some way of having one machine tell another machine about a resource that might be on yet another machine.

Wife: What?

Ryan: Let’s say you’re talking to your sister and she wants to borrow the sweeper or something. But you don’t have it – your Mom has it. So you tell your sister to get it from your Mom instead. This happens all the time in real life and it happens all the time when machines start talking too.

Wife: So how do the machines tell each other where things are?

Ryan: The URL, of course. If everything that machines need to talk about has a corresponding URL, you’ve created the machine equivalent of a noun. That you and I and the rest of the world have agreed on talking about nouns in a certain way is pretty important, eh?

Wife: Yeah.

Ryan: Machines don’t have a universal noun – that’s why they suck. Every programming language, database, or other kind of system has a different way of talking about nouns. That’s why the URL is so important. It let’s all of these systems tell each other about each other’s nouns.

Wife: But when I’m looking at a web page, I don’t think of it like that.

Ryan: Nobody does. Except Fielding and handful of other people. That’s why machines still suck.

Wife: What about verbs and pronouns and adjectives?

Ryan: Funny you asked because that’s another big aspect of REST. Well, verbs are anyway.

Wife: I was just joking.

Ryan: It was a funny joke but it’s actually not a joke at all. Verbs are important. There’s a powerful concept in programming and CS theory called polymorphism. That’s a geeky way of saying that different nouns can have the same verb applied to them.

Wife: I don’t get it.

Ryan: Well.. Look at the coffee table. What are the nouns? Cup, tray, newspaper, remote. Now, what are some things you can do to all of these things?

Wife: I don’t get it…

Ryan: You can get them, right? You can pick them up. You can knock them over. You can burn them. You can apply those same exact verbs to any of the objects sitting there.

Wife: Okay… so?

Ryan: Well, that’s important. What if instead of me being able to say to you, “get the cup,” and “get the newspaper,” and “get the remote”; what if instead we needed to come up with different verbs for each of the nouns? I couldn’t use the word “get” universally, but instead had to think up a new word for each verb/noun combination.

Wife: Wow! That’s weird.

Ryan: Yes, it is. Our brains are somehow smart enough to know that the same verbs can be applied to many different nouns. Some verbs are more specific than others and apply only to a small set of nouns. For instance, I can’t drive a cup and I can’t drink a car. But some verbs are almost universal like GET, PUT, and DELETE.

Wife: You can’t DELETE a cup.

Ryan: Well, okay, but you can throw it away. That was another joke, right?

Wife: Yeah.

Ryan: So anyway, HTTP–this protocol Fielding and his friends created–is all about applying verbs to nouns. For instance, when you go to a web page, the browser does an HTTP GET on the URL you type in and back comes a web page.

Web pages usually have images, right? Those are separate resources. The web page just specifies the URLs to the images and the browser goes and does more HTTP GETs on them until all the resources are obtained and the web page is displayed. But the important thing here is that very different kinds of nouns can be treated the same. Whether the noun is an image, text, video, an mp3, a slideshow, whatever. I can GET all of those things the same way given a URL.

Wife: Sounds like GET is a pretty important verb.

Ryan: It is. Especially when you’re using a web browser because browsers pretty much justGET stuff. They don’t do a lot of other types of interaction with resources. This is a problem because it has led many people to assume that HTTP is just for GETing. But HTTP is actually ageneral purpose protocol for applying verbs to nouns.

Wife: Cool. But I still don’t see how this changes anything. What kinds of nouns and verbs do you want?

Ryan: Well the nouns are there but not in the right format.

Think about when you’re browsing around amazon.com looking for things to buy me for Christmas. Imagine each of the products as being nouns. Now, if they were available in a representation that a machine could understand, you could do a lot of neat things.

Wife: Why can’t a machine understand a normal web page?

Ryan: Because web pages are designed to be understood by people. A machine doesn’t care about layout and styling. Machines basically just need the data. Ideally, every URL would have a human readable and a machine readable representation. When a machine GETs the resource, it will ask for the machine readable one. When a browser GETs a resource for a human, it will ask for the human readable one.

Wife: So people would have to make machine formats for all their pages?

Ryan: If it were valuable.

Look, we’ve been talking about this with a lot of abstraction. How about we take a real example. You’re a teacher – at school I bet you have a big computer system, or three or four computer systems more likely, that let you manage students: what classes they’re in, what grades they’re getting, emergency contacts, information about the books you teach out of, etc. If the systems are web-based, then there’s probably a URL for each of the nouns involved here: student, teacher, class, book, room, etc. Right now, getting the URL through the browser gives you a web page. If there were a machine readable representation for each URL, then it would be trivial to latch new tools onto the system because all of that information would be consumable in a standard way. It would also make it quite a bit easier for each of the systems to talk to each other. Or, you could build a state or country-wide system that was able to talk to each of the individual school systems to collect testing scores. The possibilities are endless.

Each of the systems would get information from each other using a simple HTTP GET. If one system needs to add something to another system, it would use an HTTP POST. If a system wants to update something in another system, it uses an HTTP PUT. The only thing left to figure out is what the data should look like.

Wife: So this is what you and all the computer people are working on now? Deciding what the data should look like?

Ryan: Sadly, no. Instead, the large majority are busy writing layers of complex specifications for doing this stuff in a different way that isn’t nearly as useful or eloquent. Nouns aren’t universal and verbs aren’t polymorphic. We’re throwing out decades of real field usage and proven technique and starting over with something that looks a lot like other systems that have failed in the past. We’re using HTTP but only because it helps us talk to our network and security people less. We’re trading simplicity for flashy tools and wizards.

Wife: Why?

Ryan: I have no idea.

Wife: Why don’t you say something?

Ryan: Maybe I will.

How I Explained REST to My Wife

Ryan Tomayko

Sunday, December 12, 2004

Translations of the following dialog available in JapaneseFrenchVietnameseItalianSpanish,Portuguese, and Chinese. Huge thanks to YAMAMOTO YoheiKarl DubostjishinBarbzTordekEdgard Arakakikeven lw, respectively. If you know of additional translations, please leave a comment with the location.

How I Explained REST to My Wife

Wife: Who is Roy Fielding?

Ryan: Some guy. He’s smart.

Wife: Oh? What did he do?

Ryan: He helped write the first web servers and then did a ton of research explaining why the web works the way it does. His name is on the specification for the protocol that is used to get pages from servers to your browser.

Wife: How does it work?

Ryan: The web?

Wife: Yeah.

Ryan: Hmm. Well, it’s all pretty amazing really. And the funny thing is that it’s all very undervalued. The protocol I was talking about, HTTP, it’s capable of all sorts of neat stuff that people ignore for some reason.

Wife: You mean http like the beginning of what I type into the browser?

Ryan: Yeah. That first part tells the browser what protocol to use. That stuff you type in there is one of the most important breakthroughs in the history of computing.

Wife: Why?

Ryan: Because it is capable of describing the location of something anywhere in the worldfrom anywhere in the world. It’s the foundation of the web. You can think of it like GPS coordinates for knowledge and information.

Wife: For web pages?

Ryan: For anything really. That guy, Roy Fielding, he talks a lot about what those things point to in that research I was talking about. The web is built on an architectural style called REST. REST provides a definition of a resource, which is what those things point to.

Wife: A web page is a resource?

Ryan: Kind of. A web page is a representation of a resource. Resources are just concepts. URLs–those things that you type into the browser…

Wife: I know what a URL is..

Ryan: Oh, right. Those tell the browser that there’s a concept somewhere. A browser can then go ask for a specific representation of the concept. Specifically, the browser asks for the web page representation of the concept.

Wife: What other kinds of representations are there?

Ryan: Actually, representations is one of these things that doesn’t get used a lot. In most cases, a resource has only a single representation. But we’re hoping that representations will be used more in the future because there’s a bunch of new formats popping up all over the place.

Wife: Like what?

Ryan: Hmm. Well, there’s this concept that people are calling Web Services. It means a lot of different things to a lot of different people but the basic concept is that machines could use the web just like people do.

Wife: Is this another robot thing?

Ryan: No, not really. I don’t mean that machines will be sitting down at the desk and browsing the web. But computers can use those same protocols to send messages back and forth to each other. We’ve been doing that for a long time but none of the techniques we use today work well when you need to be able to talk to all of the machines in the entire world.

Wife: Why not?

Ryan: Because they weren’t designed to be used like that. When Fielding and his buddies started building the web, being able to talk to any machine anywhere in the world was a primary concern. Most of the techniques we use at work to get computers to talk to each other didn’t have those requirements. You just needed to talk to a small group of machines.

Wife: And now you need to talk to all the machines?

Ryan: Yes – and more. We need to be able to talk to all machines about all the stuff that’s on all the other machines. So we need some way of having one machine tell another machine about a resource that might be on yet another machine.

Wife: What?

Ryan: Let’s say you’re talking to your sister and she wants to borrow the sweeper or something. But you don’t have it – your Mom has it. So you tell your sister to get it from your Mom instead. This happens all the time in real life and it happens all the time when machines start talking too.

Wife: So how do the machines tell each other where things are?

Ryan: The URL, of course. If everything that machines need to talk about has a corresponding URL, you’ve created the machine equivalent of a noun. That you and I and the rest of the world have agreed on talking about nouns in a certain way is pretty important, eh?

Wife: Yeah.

Ryan: Machines don’t have a universal noun – that’s why they suck. Every programming language, database, or other kind of system has a different way of talking about nouns. That’s why the URL is so important. It let’s all of these systems tell each other about each other’s nouns.

Wife: But when I’m looking at a web page, I don’t think of it like that.

Ryan: Nobody does. Except Fielding and handful of other people. That’s why machines still suck.

Wife: What about verbs and pronouns and adjectives?

Ryan: Funny you asked because that’s another big aspect of REST. Well, verbs are anyway.

Wife: I was just joking.

Ryan: It was a funny joke but it’s actually not a joke at all. Verbs are important. There’s a powerful concept in programming and CS theory called polymorphism. That’s a geeky way of saying that different nouns can have the same verb applied to them.

Wife: I don’t get it.

Ryan: Well.. Look at the coffee table. What are the nouns? Cup, tray, newspaper, remote. Now, what are some things you can do to all of these things?

Wife: I don’t get it…

Ryan: You can get them, right? You can pick them up. You can knock them over. You can burn them. You can apply those same exact verbs to any of the objects sitting there.

Wife: Okay… so?

Ryan: Well, that’s important. What if instead of me being able to say to you, “get the cup,” and “get the newspaper,” and “get the remote”; what if instead we needed to come up with different verbs for each of the nouns? I couldn’t use the word “get” universally, but instead had to think up a new word for each verb/noun combination.

Wife: Wow! That’s weird.

Ryan: Yes, it is. Our brains are somehow smart enough to know that the same verbs can be applied to many different nouns. Some verbs are more specific than others and apply only to a small set of nouns. For instance, I can’t drive a cup and I can’t drink a car. But some verbs are almost universal like GET, PUT, and DELETE.

Wife: You can’t DELETE a cup.

Ryan: Well, okay, but you can throw it away. That was another joke, right?

Wife: Yeah.

Ryan: So anyway, HTTP–this protocol Fielding and his friends created–is all about applying verbs to nouns. For instance, when you go to a web page, the browser does an HTTP GET on the URL you type in and back comes a web page.

Web pages usually have images, right? Those are separate resources. The web page just specifies the URLs to the images and the browser goes and does more HTTP GETs on them until all the resources are obtained and the web page is displayed. But the important thing here is that very different kinds of nouns can be treated the same. Whether the noun is an image, text, video, an mp3, a slideshow, whatever. I can GET all of those things the same way given a URL.

Wife: Sounds like GET is a pretty important verb.

Ryan: It is. Especially when you’re using a web browser because browsers pretty much justGET stuff. They don’t do a lot of other types of interaction with resources. This is a problem because it has led many people to assume that HTTP is just for GETing. But HTTP is actually ageneral purpose protocol for applying verbs to nouns.

Wife: Cool. But I still don’t see how this changes anything. What kinds of nouns and verbs do you want?

Ryan: Well the nouns are there but not in the right format.

Think about when you’re browsing around amazon.com looking for things to buy me for Christmas. Imagine each of the products as being nouns. Now, if they were available in a representation that a machine could understand, you could do a lot of neat things.

Wife: Why can’t a machine understand a normal web page?

Ryan: Because web pages are designed to be understood by people. A machine doesn’t care about layout and styling. Machines basically just need the data. Ideally, every URL would have a human readable and a machine readable representation. When a machine GETs the resource, it will ask for the machine readable one. When a browser GETs a resource for a human, it will ask for the human readable one.

Wife: So people would have to make machine formats for all their pages?

Ryan: If it were valuable.

Look, we’ve been talking about this with a lot of abstraction. How about we take a real example. You’re a teacher – at school I bet you have a big computer system, or three or four computer systems more likely, that let you manage students: what classes they’re in, what grades they’re getting, emergency contacts, information about the books you teach out of, etc. If the systems are web-based, then there’s probably a URL for each of the nouns involved here: student, teacher, class, book, room, etc. Right now, getting the URL through the browser gives you a web page. If there were a machine readable representation for each URL, then it would be trivial to latch new tools onto the system because all of that information would be consumable in a standard way. It would also make it quite a bit easier for each of the systems to talk to each other. Or, you could build a state or country-wide system that was able to talk to each of the individual school systems to collect testing scores. The possibilities are endless.

Each of the systems would get information from each other using a simple HTTP GET. If one system needs to add something to another system, it would use an HTTP POST. If a system wants to update something in another system, it uses an HTTP PUT. The only thing left to figure out is what the data should look like.

Wife: So this is what you and all the computer people are working on now? Deciding what the data should look like?

Ryan: Sadly, no. Instead, the large majority are busy writing layers of complex specifications for doing this stuff in a different way that isn’t nearly as useful or eloquent. Nouns aren’t universal and verbs aren’t polymorphic. We’re throwing out decades of real field usage and proven technique and starting over with something that looks a lot like other systems that have failed in the past. We’re using HTTP but only because it helps us talk to our network and security people less. We’re trading simplicity for flashy tools and wizards.

Wife: Why?

Ryan: I have no idea.

Wife: Why don’t you say something?

Ryan: Maybe I will.

How I Explained REST to My Wife

Ryan Tomayko

Sunday, December 12, 2004

Translations of the following dialog available in JapaneseFrenchVietnameseItalianSpanish,Portuguese, and Chinese. Huge thanks to YAMAMOTO YoheiKarl DubostjishinBarbzTordekEdgard Arakakikeven lw, respectively. If you know of additional translations, please leave a comment with the location.

Free iOS Apps Celebration – Get NOW

Celebrating a gajillion app sales, and for an unknown length of time, there are dozens of free iPad and iPhone apps available.

The original 10 are at: AppShopper » Apple Celebrates App Store’s Fifth Year with 10 Free Apps

Subsequently, many more have been released, and are mixed into AppShopper’s usual fare:

iPad Apps, iPhone Apps, Deals and Discovery at App Shopper – Popular Recent Changes for iOS

Free iOS Apps Celebration – Get NOW

Celebrating a gajillion app sales, and for an unknown length of time, there are dozens of free iPad and iPhone apps available.

The original 10 are at: AppShopper » Apple Celebrates App Store’s Fifth Year with 10 Free Apps

Subsequently, many more have been released, and are mixed into AppShopper’s usual fare:

iPad Apps, iPhone Apps, Deals and Discovery at App Shopper – Popular Recent Changes for iOS