Friday, August 27, 2010

[Node:Michael Migdol] [Edge:Attends] [Node:SVST Meetup on Open Graph Protocol] [Location:Facebook]

Sorry for the cryptic title, but I think you guys can probably figure it out. Last Monday I had a nice time at the Silicon Valley Semantic Technology (SVST) Group Meetup hosted by Facebook, where I got to learn a little bit about Facebook's Open Graph "protocol". I put "protocol" in quotes because Facebook's spin on this idea isn't so much as a protocol as it is an extended definition of HTML meta tag content in your web pages. Open Graph is simply a web of nodes (people, movies, etc. ) interconnected by predicate edges ("likes", "checked into", etc) that can be defined by this metadata content. Should sound very familiar to those of you familar with RDF graphs.

On the surface, the idea of using this "protocol" to create an interconnected web of things that can be "liked", or "attended" or "checked into" seems reasonable. Unfortunately, I really thing Facebook rushed this product out the door and dropped the ball in a few key areas.

The first deficiency by far was the lack of ability to query the Open Graph. Although this was my first SVST event, my take on things is that the bulk of the attendees are consumers, rather than producers, of semantic content. When we got to the Q&A part of the meeting, my hand shot up, but came back down when the attendee who was picked asked my question: "what about querying?" Facebook had no good answer, however, and it seemed to me that this functionality will be far off into the future. The only current real tangible output of OpenGraph seems to be the enhanced like button that shows how many people and which friends of yours like the web page that you are visiting, and to provide more content for your Facebook news stream. Facebook - please give us the ability to:
- Query for nodes on the graph with specific criteria, e.g. "tell me the movie liked by the most people in the 95124 zip code in the last 24 hours"
- Query for people's interests (for those who opt-in to making those interests public)
- Provide recommendations from within your graph

The second deficiency I noted was the lack of a "same-as" functionality in the same vein as the OWL:sameAs property. So if I "like" the Avatar node defined by IMDB, and you "like" the Avatar node defined by Rotten Tomatoes, there is no relationship between those two edges in the Graph. The guys at Facebook promised that they're working on this problem, but couldn't provide a timeline.

Finally, I don't think that Facebook did a very good job at separating the concept of a web page from a block of content on a web page. Take this blog for example -- the blog as a whole should be a node, and individual posts should be nodes, and comments on posts should be nodes. And I should be able to like (or dislike) any of the above.

I came away from the meeting feeling like Facebook had put a bit too much value in their design goal of making it super-easy to create OpenGraph nodes and, in doing so, both reinvented the wheel and made it less useful. The Semantic community has done lots of great work in defining standards for this kind of thing already -- let's put the brainpower at Facebook to work on using these standards to access the wealth of data and data consumers that exists under the Facebook umbrella!

Tuesday, August 24, 2010

Introduction

Welcome!

I've created this blog as a vehicle to provide yet another perspective on all things tech. I expect to focus on most of my areas of expertise: Mobile Computing, Speech Recognition, Software as a Service (SAAS)/Cloud Computing, and web application frameworks (particularly Grails, the framework for my current project). Hopefully I will have something of interest to you at some point. :-)

A brief biography: I'm a 38 year-old married father of two. I graduated from UT Austin with a EE degree in 1995. While at UT I had a variety of part-time jobs in areas including authoring automated psychoacoustic experiments, sonar software development, financial trading algorithms, and IEEE-1394 (Firewire) firmware programming. After graduating, my wife (who I met and married at UT) and I moved to Osaka, Japan, where I joined Matsushita Electric Works. While there, I worked on embedded software for building automation systems. We moved back to the US in 1997, where I was employed by AMD as a Systems Software Engineer, developing device drivers and OS ports for their embedded micro-controllers.

In January of 2000, I joined BeVocal, a startup founded by a friend and former Matsushita co-worker. BeVocal was focused on providing automated speech application solutions, and I did some of everything while I was there: speech application development, building of our VXML interpreter and telephony platform (which today hosts 100's of millions of calls per month), architecture, management of the team responsible for this platform and our BeVocal Cafe development environment, and bootstrapping of our first mobile application product (today known as "Nuance Mobile Care"). BeVocal was bought by Nuance in 2007, and my most recent work there was centered around management of our first Android port, and technical product integration of various mobile technologies that Nuance had acquired. Nuance and I parted ways this past June.

So that brings us to now! I am a co-founder at a startup called Infopixie, which aims to revolutionize how you get content from the web. I've had to jump head-first into the deep end and learn quickly about various "Web 3.0" technologies to gather content, learn about you and what you're interested in viewing, and provide you with a super easy way to view and manage your content. We have a tough problem to solve, but I really think we are moving in the right direction. I look forward to sharing more about Infopixie with you in the near future. (Let me know if you're interested in being a beta tester!)

If you have any topics you're interested in hearing more about, let me know. I look forward to chatting with you blog readers out there!