<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss1full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://purl.org/rss/1.0/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:admin="http://webns.net/mvcb/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0">
<channel rdf:about="http://danbri.org/words">
	<title>danbri's foaf stories</title>
	<link>http://danbri.org/words</link>
	<description>the web, the world, us, you and them</description>
	<dc:date>2009-10-25T20:07:11Z</dc:date>
	
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<sy:updateBase>2000-01-01T12:00+00:00</sy:updateBase>
		<items>
		<rdf:Seq>
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/25/504" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/23/492" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/19/483" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/18/478" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/12/473" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/12/470" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/09/452" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/10/02/445" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/09/28/433" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/08/30/427" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/07/23/423" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/06/30/418" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/06/16/415" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/06/01/414" />
					<rdf:li rdf:resource="http://danbri.org/words/2009/05/27/412" />
				</rdf:Seq>
	</items>
<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" href="http://feeds.feedburner.com/danbri_blog" type="application/rss+xml" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com" /></channel>
<item rdf:about="http://danbri.org/words/2009/10/25/504">
	<title>Syndicating trust? Mediawiki, Wordpress and OpenID</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/w8ISzIlL_ls/504</link>
	 <dc:date>2009-10-25T20:07:11Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[RDFa]]></dc:subject>
		<dc:subject><![CDATA[Semantic Web]]></dc:subject>
		<dc:subject><![CDATA[SocialWeb]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[openid]]></dc:subject>
		<dc:subject><![CDATA[privacy]]></dc:subject>
	<description>Fancy title but simple code. A periodic update script is setting user/group membership rules on the FOAF wiki based on a list of trusted (for this purpose) OpenIDs exported from a nearby blog. If you've commented on the blog using OpenID and it was accepted, this means you can also ...</description>
	<content:encoded><![CDATA[<p>Fancy title but simple code. A periodic update script is setting user/group membership rules on the FOAF wiki based on a list of trusted (for this purpose) OpenIDs exported from a nearby blog. If you&#8217;ve commented on the blog using OpenID and it was accepted, this means you can also perform some admin actions (page deletes, moves, blocking spammers etc.) on the FOAF wiki without any additional fuss.</p>
<p>Both Wordpress blogs and Mediawiki wikis have some support for OpenID logins.</p>
<p>The FOAF wiki until recently only had one Sysop and Bureaucrat account (a bureaucrat has the same privileges as a Sysop except for the ability to create new bureaucrat accounts). So I&#8217;ve begun an <a href="http://wiki.foaf-project.org/w/DanBri/MediawikiOpenid">experiment</a> exploring idea of pre-approving certain OpenIDs for bureaucrat activities. For now, I take a list of OpenIDs from my own blog; these appear to be just the good guys, but this might be because only real humans have commented on my blog via OpenID. With a bit of tweaking I&#8217;m sure I could write SQL to select out only OpenIDs associated with posts or comments I&#8217;ve accepted as non spammy, though.</p>
<p>So now there&#8217;s a script I can run (thanks tobyink and others in #swig IRC for help) which compares an externally supplied list of OpenID URIs with those OpenIDs known to the wiki, and upgrades the status of any overlaps to be bureaucrats. Currently the &#8217;syndication&#8217; is trivial since the sites are on the same machine, and the UI is minimal; I haven&#8217;t figured out how best to convey this notion of &#8216;pre-approved upgrade&#8217; to the people I&#8217;m putting in an admin group. Quite reasonably they might object to being misrepresented as contributors; who knows.</p>
<p>But all that aside, take a look and have a think. This kind of approach has a lot going for it. We will have all kinds of lists of people, groups of people, and in many cases we&#8217;ll know their OpenIDs. So why not pool what we know? If a blog or wiki has information about an OpenID that shows it is somehow trustworthy, or at least not obviously a spammer, there&#8217;s every reason to make notations (eg. FOAF/RDFa) that allow other such sites to harvest and integrate that data&#8230;</p>
<p>See also <a href="http://dig.csail.mit.edu/breadcrumbs/node/206">Dan Connolly&#8217;s DIG blog post</a> on this, and the current <a href="http://wiki.foaf-project.org/w/Special:ListUsers/bureaucrat">list of Bureaucrats</a> on the FOAF Wiki (and associated <a href="http://wiki.foaf-project.org/w/FOAF_Wiki:Bureaucrats">documentation</a>). If your names on the list, it just means your OpenID was on a pre-approved list of folk who I trust based on their interactions with my own blog. I&#8217;d <em>love</em> to add more sources here and make it genuinely communal.</p>
<p>This is all part of the process of getting FOAF moving again. The brains of FOAF is in the <a href="http://wiki.foaf-project.org/w/IssueTracker">IssueTracker</a> page, and since the site was damaged by spammers and hackers recently I&#8217;m trying to make sure we have a happy / wholesome environment for maintaining shared documents. And that&#8217;s more than I can do as a solo admin, hence this design for opening things up&#8230;</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/w8ISzIlL_ls" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/25/504</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/23/492">
	<title>Remote remotes</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/DaRoyyrREw0/492</link>
	 <dc:date>2009-10-23T18:05:50Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[Jabber/XMPP]]></dc:subject>
		<dc:subject><![CDATA[SocialWeb]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
	<description>I've just closed the loop on last weekend's XMPP / Apple Remote hack, using Strophe.js, a library that extends XMPP into normal Web pages. I hope I'll find some way to use this in the NoTube project (eg. wired up to Web-based video playing in OpenSocial apps), but even if ...</description>
	<content:encoded><![CDATA[<p>I&#8217;ve just closed the loop on last weekend&#8217;s <a href="http://xmpp.org/">XMPP</a> / <a href="http://danbri.org/words/2009/10/19/483">Apple Remote hack</a>, using <a href="http://blog.xmpp.org/wp-content/uploads/2009/03/xmpp-web-applications-with-strophe.pdf">Strophe</a>.js, a library that extends XMPP into normal Web pages. I hope I&#8217;ll find some way to use this in the NoTube project (eg. wired up to Web-based video playing in OpenSocial apps), but even if not it has been a useful learning experience. See this <a href="http://www.flickr.com/photos/danbri/4036909817/sizes/l/">screenshot</a> of a live HTML page, receiving and displaying remotely streamed events (green blob: button clicked; grey blob: button released). It doesn&#8217;t control any video yet, but you get the idea I hope.</p>
<div id="attachment_493" class="wp-caption alignnone" style="width: 310px"><img class="size-medium wp-image-493 " title="Remote Remote" src="http://danbri.org/words/wp-content/uploads/2009/10/FirefoxScreenSnapz001-300x188.jpg" alt="Remote apple remote HTML demo" width="300" height="188" /><p class="wp-caption-text">Remote apple remote HTML demo, screenshot showing a picture of handheld apple remote with a grey blob over the play/pause button, indicating a mouse up event. Also shows debug text in html indicating ButtonUpEvent: PLPZ.</p></div>
<p>This webclient needs the JID and password details for an XMPP account, and I think these need to be from the same HTTP server the HTML is published on. It works using BOSH or other tricks, but for now I&#8217;ve not delved into those details and options. Source is in the Buttons area of the FOAF svn: <a href="http://svn.foaf-project.org/foaftown/buttons/osx/webclient">webclient</a>. I made a set of <a href="http://svn.foaf-project.org/foaftown/buttons/osx/webclient/images/">images</a>, for each button in combination with button-press (&#8217;down&#8217;), button-release (&#8217;up&#8217;). I&#8217;m running my own ejabberd and using an account &#8216;buttons@foaf.tv&#8217; on the foaf.tv domain. I also use generic XMPP IM accounts on Google Talk, which work fine although I read recently that very chatty use of such services can result in data rates being reduced.</p>
<p>To send local Apple Remote events to such a client, you need a bit of <a href="http://svn.foaf-project.org/foaftown/buttons/osx/">code</a> running on an OSX machine. I&#8217;ve done this in a mix of C and Ruby: <a href="http://svn.foaf-project.org/foaftown/buttons/osx/iremoted_buttons.c">imremoted.c</a> (<a href="http://svn.foaf-project.org/foaftown/buttons/osx/iremoted_buttons">binary</a>) to talk to the remote, and the script <a href="http://svn.foaf-project.org/foaftown/buttons/osx/buttonhole_surfer.rb">buttonhole_surfer.rb</a> to re-broadcast the events. The ruby code uses <a href="http://mojodna.net/2009/07/19/switchboard-as-a-framework.html">Switchboard</a> and by default loads account credentials from ~/.switchboardrc.</p>
<p>I&#8217;ve done a few tests with this setup. It is pretty responsive considering how much indirection is involved: but the demo UI I made could be prettier. The + and &#8211; buttons behave differently to the left and right (and menu and play/pause); only + and &#8211; send an event immediately. The others wait until the key is released, then send a pair of events. The other keys except for play/pause will also forget what&#8217;s happening unless you act quickly. This seems to be a hardware limitation. Apparently Apple are <a href="http://www.tuaw.com/2009/10/20/the-hits-just-keep-coming-now-theres-a-new-apple-remote/">about to ship an updated $20 remote</a>; I hope this aspect of the design is reconsidered, as it limits the UI options for code using these remotes.</p>
<p>I also tried it using two browsers side by side on the same laptop; and two laptops side by side. The events get broadcasted just fine. There is a lot more thinking to do re serious architecture, where passwords and credentials are stored, etc. But XMPP continues to look like a very interesting route.</p>
<p>Finally, why would anyone bother installing compiled C code, Ruby (plus XMPP libraries), their own Jabber server, and so on? Well hopefully, the work can be divided up. Not everyone installs a Jabber server. My thinking is that we can bundle a collection of TV and SPARQL XMPP functionality in a single install, such that local remotes can be used on the network, but also local software (eg. XBMC/Plex/Boxee) can also be exposed to the wider network &#8211; whether it&#8217;s XMPP .js running inside a Web page as shown here, or an iPhone or a <a href="http://en.wikipedia.org/wiki/Multi-touch">multi-touch table</a>. Each will offer different interaction possibilities, but they can chat away to each other using a common link, and common RDF vocabularies (an area we&#8217;re working on in NoTube). If some common micro-protocols over XMPP (sending clicks or sending commands or doing RDF queries) can support compelling functionality, then installing a &#8216;buttons adaptor&#8217; is something you might do once, with multiple benefits. But for now, apart from the JQbus piece, the <a href="http://svn.foaf-project.org/foaftown/jqbus/intro.html">protocols</a> are still vapourware. First I wanted to get the basic plumbing in place.</p>
<p>Update: I re-discovered a useful <a href="http://metajack.im/2008/09/08/which-bosh-server-do-you-need/">&#8216;which bosh server do you need?&#8217;</a> which reminds me that there are basically two kinds of <a href="http://en.wikipedia.org/wiki/BOSH">BOSH</a> software offering; those that are built into some existing Jabber/XMPP server (like the ejabberd installation I&#8217;m using on foaf.tv) and those that are stand-alone connection managers that proxy traffic into the wider XMPP network. In terms of the current experiment, it means the event stream can (within the XMPP universe) come from addresses other than the host running the Web app. So I should also try installing <a href="http://code.stanziq.com/punjab">Punjab</a>. Perhaps it will also let webapps served from other hosts (such as opensocial containers) talk to it via JSON tricks? So far I have only managed to serve working Buttons/Strophe HTML from the same host as my Jabber server, ie. foaf.tv. I&#8217;m not sure how feasible the cross-domain option is.</p>
<p>Update x2: Three different people have now mentioned <a href="http://opensoundcontrol.org/">opensoundcontrol</a> to me as something similar, at least on a LAN; it clearly deserves some <a href="http://www.makingthings.com/documentation/tutorial/osc/overview-and-concepts">investigation</a>&#8230;</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/DaRoyyrREw0" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/23/492</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/19/483">
	<title>Streaming Apple Events over XMPP</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/gEZfnwU5NE0/483</link>
	 <dc:date>2009-10-19T07:17:21Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Jabber/XMPP]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[tv]]></dc:subject>
	<description>I've just posted a script that will re-route the OSX Apple Remote event stream out across XMPP using the Switchboard Ruby library, streaming click-down and click-up events from the device out to any endpoint identified by a Jabber/XMPP JID (i.e. Jabber ID). In my case, I'm connecting to XMPP as ...</description>
	<content:encoded><![CDATA[<p>I&#8217;ve just posted a <a href="http://svn.foaf-project.org/foaftown/buttons/osx/buttonhole_surfer.rb">script</a> that will re-route the OSX <a href="http://danbri.org/words/2009/10/18/478">Apple Remote event stream</a> out across XMPP using the <a href="http://mojodna.net/2009/07/19/switchboard-as-a-framework.html">Switchboard Ruby library</a>, streaming click-down and click-up events from the device out to any endpoint identified by a Jabber/XMPP JID (i.e. Jabber ID). In my case, I&#8217;m connecting to XMPP as the user xmpp:buttons@foaf.tv, who is buddies with xmpp:bob.notube@gmail.com, ie. they are on each other&#8217;s Jabber rosters already. Currently I simply send a textual message with the button-press code; a real app would probably use an XMPP IQ stanza instead, which is oriented more towards machines than human readers.</p>
<p>The nice thing about this setup is that I can log in on another laptop to Gmail, run the Javascript Gmail / Google Talk chat UI, and hear a &#8216;beep&#8217; whenever the event/message arrives in my browser. This is handy for informally testing the laggyness of the connection, which in turn is critical when designing remote control protocols: how chatty should they be? How much smarts should go into the client? which bit of the system really understands what the user is doing? Informally, the XMPP events seem pretty snappy, but I&#8217;d prefer to see some real statistics to understand what a UI might risk relying on.</p>
<p>What I&#8217;d like to do now is get a <a href="http://code.stanziq.com/strophe/">Strophe Javascript client</a> running. This will attach to my Jabber server and allow these events to show up in HTML/Javascript apps&#8230;</p>
<p>Here&#8217;s sample output of the script (local copy but it looks the same remotely), in which I press and release quickly every button in turn:</p>
<blockquote>
<pre>Cornercase:osx danbri$ ./buttonhole_surfer.rb
starting event loop.

=&gt; Switchboard started.
ButtonDownEvent: PLUS (0x1d)
ButtonUpEvent: PLUS (0x1d)
ButtonDownEvent: MINU (0x1e)
ButtonUpEvent: MINU (0x1e)
ButtonDownEvent: LEFT (0x17)
ButtonUpEvent: LEFT (0x17)
ButtonDownEvent: RIGH (0x16)
ButtonUpEvent: RIGH (0x16)
ButtonDownEvent: PLPZ (0x15)
ButtonUpEvent: PLPZ (0x15)
ButtonDownEvent: MENU (0x14)
ButtonUpEvent: MENU (0x14)
^C
Shutdown initiated.
Waiting for shutdown to complete.
Shutdown initiated.
Waiting for shutdown to complete.
Cornercase:osx danbri$</pre>
</blockquote>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/gEZfnwU5NE0" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/19/483</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/18/478">
	<title>Apple Remote events – a quick howto</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/GRtIMnSkytQ/478</link>
	 <dc:date>2009-10-18T12:20:29Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Jabber/XMPP]]></dc:subject>
		<dc:subject><![CDATA[Project ideas]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[tv]]></dc:subject>
	<description>Anyone who has recently bought an Apple computer probably has one or more Apple Remotes.

I have been learning how to access them. Conclusion: iremoted does 95% of what you probably need, and the discussion over on cocoadev.com tells you more than you probably wanted to know. My experiments are written ...</description>
	<content:encoded><![CDATA[<p>Anyone who has recently bought an Apple computer probably has one or more <a href="http://en.wikipedia.org/wiki/Apple_Remote">Apple Remotes</a>.</p>
<p>I have been learning how to access them. Conclusion: <a href="http://osxbook.com/software/iremoted/">iremoted</a> does 95% of what you probably need, and the discussion over on <a href="http://www.cocoadev.com/index.pl?UsingTheAppleRemoteControl">cocoadev.com</a> tells you more than you probably wanted to know. My experiments are written up in a <a href="http://wiki.foaf-project.org/w/DanBri/AppleRemoteButtonTest1">corner of the FOAF wiki</a>, and have a large collection of related links stored under the <a href="http://delicious.com/danbri/buttons">&#8216;buttons&#8217; tag at delicious.com</a>.</p>
<p>Summary: If you run iremoted, it calls OSX APIs and gets notified whenever button presses on the Apple Remote are detected.</p>
<p>There are 6 buttons: a menu button, a play/pause main button, and four others surrounding the main button. To the left and right there are &#8216;back&#8217; and &#8216;fwd&#8217;; and above/below they are labelled &#8216;+&#8217; and &#8216;-&#8217;.</p>
<p>Interestingly from a protocol and UI design view, those last buttons behave differently. When you press and release the other 4 buttons, the 2 events are not reported until after you release; but with &#8216;+&#8217; and &#8216;-&#8217;, the initial press is reported immediately. Furthermore, only &#8216;+&#8217; and &#8216;-&#8217; do anything interesting if you press for longer than a second or so; the others result in your action being silently dropped, even when you release the button.</p>
<p>I am looking at this since I am revisiting my old <a href="http://svn.foaf-project.org/foaftown/jqbus/intro.html">Jqbus</a> FOAF experiments with XMPP and SPARQL for data access; but this time building in some notion of behaviour too, hence the new name: <a href="http://wiki.foaf-project.org/w/Buttons">Buttons</a>. The idea is to use XMPP as a universal communication environment between remote controls and remote-controllable things, initially in the world around TV. So I am exploring adaptors for existing media centres and media players (Boxee, XBMC, iTunes etc).</p>
<p>There are various levels of abstraction at which XMPP could be used as a communications pipe: it could stream clicks directly, by simply reflecting the stream of Infra Red events, translating them into IQ messages sent to JID-identified XMPP accounts. Or we could try to interpret them closer to their source, and send more meaningful events. For example, if the &#8220;+&#8221; is held for 3 seconds, do we wait until it is released before sending a &#8220;Maximize volume&#8221; message out across the &#8216;net. Other approaches (eg. as <a href="http://mail.jabber.org/pipermail/social/2009-August/000545.html">suggested</a> on the xmpp list, and in some accessibility work) include exporting bits of UI to the remote. Or in the case of really dumb remotes with no screen, at least some sort of invisible proxy/wrapper that tries to avoid sprawing every user click out across XMPP.</p>
<p>Anyway, I thought this worth a writeup. Here&#8217;s a link to my copy of iremoted, <a href="http://svn.foaf-project.org/foaftown/buttons/osx/iremoted_buttons.c">iremoted_buttons.c</a>. The main change (apart from trivial syntax edits for its output) is the use of kIOHIDOptionsTypeSeizeDevice. This is pretty important, as it stops other processes on your mac receiving the same events; eg. FrontRow taking over the laptop UI whenever &#8216;menu&#8217; is pressed, or the local volume being changed by &#8216;+&#8217; and &#8216;-&#8217;:</p>
<pre>    ioReturnValue = (*hidDeviceInterface)-&gt;open(hidDeviceInterface, kIOHIDOptionsTypeSeizeDevice);</pre>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/GRtIMnSkytQ" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/18/478</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/12/473">
	<title>Local Video for Local People</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/_7xaKDuRtTY/473</link>
	 <dc:date>2009-10-12T17:31:02Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[General]]></dc:subject>
		<dc:subject><![CDATA[Geo]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
	<description>OK it's all Google stuff, but still good to see. Go to Google Maps, My Maps, to find 'Videos from YouTube' listed. Here's where I used to live (Bristol UK) and where I live now (Amsterdam, The Netherlands). Here's a promo film of some nearby art installations from ArtZuid, who ...</description>
	<content:encoded><![CDATA[<p>OK it&#8217;s all Google stuff, but still good to see. Go to Google Maps, My Maps, to find &#8216;Videos from YouTube&#8217; listed. Here&#8217;s where I used to live (<a href="http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=bristol+uk&amp;sll=35.88905,-98.085937&amp;sspn=0.07941,0.173378&amp;ie=UTF8&amp;hq=&amp;hnear=Bristol,+Avon,+United+Kingdom&amp;ll=51.473739,-2.596807&amp;spn=0.030527,0.086689&amp;z=14&amp;iwloc=lyrftr:com.youtube.all,3148423284973801114,51.463433,-2.582281&amp;lci=com.youtube.all">Bristol</a> UK) and where I live now (<a href="http://maps.google.com/maps/mm?ie=UTF8&amp;hl=en&amp;ll=52.357466,4.892864&amp;spn=0.059863,0.173378&amp;z=13&amp;lci=com.youtube.all">Amsterdam</a>, The Netherlands). Here&#8217;s <a href="http://maps.google.com/maps/mm?ie=UTF8&amp;hl=en&amp;ll=52.350775,4.874057&amp;spn=0.003742,0.010836&amp;z=17&amp;iwloc=lyrftr:com.youtube.all,11283352528697338884,52.349995,4.872093&amp;lci=com.youtube.all">a promo film</a> of some nearby art installations from <a href="http://www.artzuid.nl/">ArtZuid</a>, who even have a <a href="http://www.artzuid.nl/index_en.php">page in English</a>. I wouldn&#8217;t have found the video or the nearby links except through the map overlay. <span style="text-decoration: line-through;">I don&#8217;t know exactly how they&#8217;re geotagging the videos, I can&#8217;t see an option under &#8216;my videos&#8217; in YouTube, so perhaps it&#8217;s automatic or viewer annotations.</span> In YouTube, you can add a map link under &#8216;My Videos&#8217; / &#8216;Edit Video&#8217;; I didn&#8217;t see that initially. I made some investigations into similar issues (videos on maps) while at Joost; see brief mention in my <a href="http://www.slideshare.net/danbri/introducing-joost-widgets-2007-talk-presentation">Fundamentos Web slides</a> from a couple of years ago.<br />
Oh, nearly forgot to mention: zooming out to get a <a href="http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=bristol+uk&amp;sll=35.88905,-98.085937&amp;sspn=0.07941,0.173378&amp;ie=UTF8&amp;lci=com.youtube.all&amp;hq=&amp;hnear=Bristol,+Avon,+United+Kingdom&amp;ll=48.777913,9.777832&amp;spn=16.547298,44.384766&amp;z=5">Europe</a> or <a href="http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=bristol+uk&amp;sll=35.88905,-98.085937&amp;sspn=0.07941,0.173378&amp;ie=UTF8&amp;lci=com.youtube.all&amp;hq=&amp;hnear=Bristol,+Avon,+United+Kingdom&amp;ll=16.972741,7.734375&amp;spn=138.957406,355.078125&amp;z=2">World</a>-wide view is quite striking too.</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/_7xaKDuRtTY" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/12/473</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/12/470">
	<title>Quick clarification on SPARQL extensions and “Lock-in”</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/eWf3bQfRshg/470</link>
	 <dc:date>2009-10-12T13:40:02Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[SPARQL]]></dc:subject>
		<dc:subject><![CDATA[Semantic Web]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
	<description>It's clear from discussion bouncing around IRC, Twitter, Skype and elsewhere that "Lock-in" isn't a phrase to use lightly.

So I post this to make myself absolutely clear. A few days ago I mentioned in IRC a concern that newcomers to SPARQL and RDF databases might not appreciate which SPARQL extensions ...</description>
	<content:encoded><![CDATA[<p>It&#8217;s clear from discussion bouncing around IRC, Twitter, Skype and elsewhere that &#8220;Lock-in&#8221; isn&#8217;t a phrase to use lightly.</p>
<p>So I post this to make myself absolutely clear. A few days ago I mentioned in IRC a concern that newcomers to SPARQL and RDF databases might not appreciate which SPARQL extensions are widely implemented, and which are the specialist offerings of the system they happen to be using. I mentioned OpenLink&#8217;s <a href="http://virtuoso.openlinksw.com/">Virtuoso</a> in particular as a SPARQL implementation that had a rich and powerful set of extensions.</p>
<p>Since it seems there is some risk I might be mis-interpreted as suggesting OpenLink are actively trying to &#8220;do a Microsoft&#8221; and trap users in some proprietary pseudo-SPARQL, I&#8217;ll state what I took to be obvious background knowledge: OpenLink is a company who owe their success to the promotion of cross-vendor database portability, they have been tireless advocates of a standards-based Semantic Web, and they&#8217;re active in proposing extensions to W3C for standardisation. So &#8211; no criticism of OpenLink intended. None at all.</p>
<p>All I think we need here, are a few utilities that help developers understand the nature of the various SPARQL dialects and the potential costs/benefits of using them. Perhaps an online validator, alongside those for RDF/XML, RDFa, Turtle etc. Such a validator might usefully list the extensions used in some query, and give pointers (perhaps into a wiki) where the status of the various extensions constructs can be discussed and documented.</p>
<p>Since SPARQL is such a young language, it lacks a lot of things that are taken from granted in the SQL world, and so using rich custom extensions when available is for many developers a sensible choice. My only concern is that it must be a choice, and one entered into consciously.</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/eWf3bQfRshg" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/12/470</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/09/452">
	<title>Linked TV (part 1): Why APIs and identifiers matter</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/moo4cGlz9VY/452</link>
	 <dc:date>2009-10-09T12:16:13Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Activism]]></dc:subject>
		<dc:subject><![CDATA[Essays]]></dc:subject>
		<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[Jabber/XMPP]]></dc:subject>
		<dc:subject><![CDATA[Project ideas]]></dc:subject>
		<dc:subject><![CDATA[RSS/Atom]]></dc:subject>
		<dc:subject><![CDATA[SocialWeb]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[Web Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[tv]]></dc:subject>
	<description>In the NoTube project, we are exploring the use of Semantic Web technology in Television and Web-TV scenarios. By making use of richer and linked descriptions of content and users, we hope to help users better find (and annotate, tag, cross-link etc.) content that is interesting to them. The growing ...</description>
	<content:encoded><![CDATA[<p>In the <a href="http://www.notube.tv/">NoTube</a> project, we are exploring the use of Semantic Web technology in Television and Web-TV scenarios. By making use of richer and linked descriptions of content and users, we hope to help users better find (and annotate, tag, cross-link etc.) content that is interesting to them. The growing amount of linked RDF data out there in the public Web provides a useful background dataset; for example we can use SKOS thesauri or DBpedia to indicate content topics or user interests.</p>
<p>I have been looking at aspects of the existing mainstream ecosystem, including so-called <a href="http://en.wikipedia.org/wiki/Media_center">media centre</a> systems, and at the various classes of app (remote controls, tv guides, media players) available on smart phones such as the iPhone. At the moment, all these applications are quite fragmented, with different pairs of remote control and player, different APIs, different metadatasystems.</p>
<p>This post gives some background thinking before jumping into super-technical details. In the next post I&#8217;ll give an overview of some of the &#8216;media centre&#8217; APIs I&#8217;ve been looking at; this is the beginnings of a survey to explore the extent to which existing players can be driven by external software through a network interface. My <a href="http://mail.jabber.org/pipermail/social/2009-August/000544.html">working hypothesis</a> is that the <a href="http://en.wikipedia.org/wiki/Extensible_Messaging_and_Presence_Protocol">XMPP protocol</a> provides the best candidate protocol environment to do this, since it allows devices to be addressed globally, even when they&#8217;re in the home; however the initial survey makes no assumptions about how these APIs might be unified.</p>
<p>Nearby: for some smartphone visuals, see my<a href="http://www.flickr.com/photos/notube"> Flickr&#8217;d collection of iPhone screen grabs</a>. I hope to revisit and annotate these later. For ongoing W3C work on an API and ontology for Media Objects, see the <a href="http://www.w3.org/TR/2009/WD-media-annot-reqs-20090604">Use Cases and Requirements document</a> over at W3C. This work is largely focussed on describing individual media objects, however it does note <a href="http://www.w3.org/TR/2009/WD-media-annot-reqs-20090604/#req-r08">a requirement</a> for  &#8220;Being able to apply the ontology / API for collections of metadata&#8221;, as well as <a href="http://www.w3.org/TR/2009/WD-media-annot-reqs-20090604/#req-r07">a requirement</a> to allow references &#8220;<em>to multimedia objects on several abstraction levels, in order to separate e.g. a movie, a DVD which contains the movie and a specific copy of the DVD. Especially for collections of multimedia objects, knowledge about such abstraction levels is helpful, as a means for accessing the objects on each level.</em>&#8221;</p>
<p>In NoTube, we are also looking at work such as the BBC <a href="http://www.bbc.co.uk/ontologies/programmes/2009-09-07.shtml">Programmes Ontology</a>, which makes such distinctions in terms of brands, series, shows, episodes etc. This is not only to group different representations of the same content (eg. a mobile-friendly downcoding of a high-definition news article); it also allows us to cluster metadata about similar items or different versions or manifestations of the same underlying content.</p>
<p>Since metadata is notoriously expensive and hard to manage, having it richly interlinked makes a lot of sense.</p>
<p>For example, if I write a comment while watching a file that I created from <a href="http://www.amazon.com/Fog-War-Eleven-Lessons-McNamara/dp/B0001L3LUE">an Amazon purchased DVD</a> of &#8220;The Fog of War&#8221;, it would be a waste (and lead to a very sparse metadata network) if my annotation was only available to other users of that exact same file within this closed home network, although the media file itself must of course stay private. The first time I saw that movie, was a screening in Bristol&#8217;s <a href="http://en.wikipedia.org/wiki/Cube_Microplex">Cube Cinema</a>. If I wrote a blog post about the movie back then, that information should also be linked to common identifiers (eg. <a href="http://www.imdb.com/title/tt0317910/">IMDB</a>, <a href="http://www.freebase.com/view/user/hal/netflix/movie/60031296">FreeBase</a>, <a href="http://en.wikipedia.org/wiki/The_Fog_of_War">Wikipedia</a>,  <a href="http://dbpedia.org/page/The_Fog_of_War">DBPedia</a>, <a href="http://www.sonyclassics.com/fogofwar/">Sony&#8217;s page</a>, the director&#8217;s <a href="http://www.errolmorris.com/film/fow.html">synopsis</a> etc.). But there&#8217;s more annotation in the Web than just my annotations: the director recently <a href="http://morris.blogs.nytimes.com/2009/07/07/mcnamara-in-context/">wrote a blog post</a> about the main subject of the film, Robert McNamara. The director, Errol Morris, also publishes a <a href="http://www.errolmorris.com/film/fow_transcript.html">transcript</a> of the movie, and his homepage links to his Twitter <a href=" http://twitter.com/errolmorris">microblog</a>. If the content is available eg. through a system like Joost or Hulu, or broadcast on TV, or screened at a local cinema, most metadata about it will still be relevant, even if it was created in a different context.</p>
<p>For Web-heads, this online data-linking story is business as usual; for the broadcast TV industry, it&#8217;s something of a new world.</p>
<p>The Web can be more than a way of driving content to viewing portals, it can be more than a threat to content owners, it can change the way we think about what all these moving pictures are telling us. Douglas Adams described this very well 20 years ago, and if you&#8217;ve not seen his <a href="http://en.wikipedia.org/wiki/Hyperland">Hyperland</a> documentary on pre-Web hypertext, I do urge you to go find a way to see it.</p>
<p>So, let&#8217;s stick with my example movie, and work outwards from an assumption we have one reasonable identifier for the film that connects us to a Web of linked data about it. Errol Morris&#8217;s (excellent) film <a href="http://en.wikipedia.org/wiki/The_Fog_of_War">The Fog of War</a>. How could a simple piece of software (running on a smart phone or home media centre) figure out that he is the director? Well, if we believe Wikipedia infoboxes and we find and believe <a href="http://dbpedia.org/page/The_Fog_of_War">DBpedia&#8217;s derived page about the film</a>, the information is there in a machine-friendly form: it says that that &#8216;director&#8217; property of the film is <a href="http://dbpedia.org/page/Errol_Morris">Errol Morris</a>. And following that link, in turn we can see a claim that Errol Morris has a &#8216;website&#8217; at <a href="http://www.errolmorris.com/">www.errolmorris.com</a>.</p>
<p>So, working outwards from the content, we find the director, and the director&#8217;s website url. What can we do with that? Well we could try loading pages from the site directly, and interpreting them. But the chances are currently low that we&#8217;ll find any machine-oriented, automation-friendly markup there. And indeed, if we look at the source of his page, there isn&#8217;t a lot there to help machines. Here is the markup for the twitter link mentioned earlier:</p>
<pre>&lt;<span>a</span><span> href</span><span>="</span><a href="view-source:http://twitter.com/ErrolMorris">http://twitter.com/ErrolMorris</a><span>" </span><span>target</span>=<span>"_blank"</span>&gt;</pre>
<p>If the page had included just a few extra characters, the microformat markup &#8220;<strong>rel=&#8217;me&#8217;</strong>&#8220;, or had a FOAF file, we could automatically have discovered that he had a microblog. He also has another blog on the New York Times site, and both of these have feeds (<a href="http://twitter.com/statuses/user_timeline/14248315.rss">Twitter RSS</a>; <a href="http://morris.blogs.nytimes.com/feed">NYTimes RSS</a>). Blogs and microblogs provide a way of establishing a more vivid and immediate connection between viewers and content creators; but finding the relevant feed for a given media object is non-trivial. So let&#8217;s walk through some of the issues and technologies.</p>
<p>0.  Content identification</p>
<p>For any of this &#8216;Linked TV&#8217; scenario to make any sense, we need to get our hands on a solid widely-known identifier for the content. This is our entry pass into Douglas Adams&#8217; &#8216;<em>hyperland&#8217;</em>, and is harder than it might seem. Typically all we have to identify a piece of content is information about a file, and maybe a textual label or two. There are a variety of automatic and semi-automatic approaches here, and growing support for rich disambiguation in freely available tools (eg. Boxee).</p>
<p>1. Reliability of linked data</p>
<p>Given a wikipedia or imdb url, we can find a lot of linked RDF data. In the example here, we use dbpedia to find the director&#8217;s homepage. Is this risky? Could the page be edited mischievously? Yes! Are there scenarios in which such Webby uncertainty is inappropriate in a TV context? Yes. Can we expect to see commercial and <a href="http://en.wikipedia.org/wiki/MusicBrainz">Musicbrainz-style</a> collaborative enrichment and QA of linked datasets? I think so.</p>
<p>2. Social Graph discovery</p>
<p>OK, so we&#8217;ve found the director&#8217;s homepage. Maybe we could have found actors, presenters or writers too, given different content. This is great, but we don&#8217;t have much there that makes sense in a TV user interface. How do we find the twitter microblog programmatically? or his New York Times blog? How can we be sure of those links?</p>
<p>This is partially a matter of waiting, and partially a chicken-and-egg situation. If we build TV tools and lightweight standards which work better if content creator sites have a little extra markup (eg. rel=&#8217;me&#8217;), some content creators will add it to their homepages and blogs, and some hosting / tool vendors will add it automatically anyway. But what can we do today? Let&#8217;s look at <a href="http://socialgraph.apis.google.com/">Google&#8217;s Social Graph API</a>.</p>
<p>The <a href="http://socialgraph.apis.google.com/">SGAPI</a> allows us to take advantage of Google&#8217;s global Web index, and ask questions about people, their profiles, account pages, and connections.</p>
<p>We can ask for example, <a href="http://socialgraph.apis.google.com/lookup?q=http%3A%2F%2Fwww.errolmorris.com%2F&amp;fme=1&amp;edo=1&amp;pretty=1&amp;callback=">which accounts are claimed by http://www.errolmorris.com/</a>. Today this gives no results, since the link in that page to the matching twitter page contains no semantic markup.</p>
<p>We can also ask, <a href="http://socialgraph.apis.google.com/lookup?q=http%3A%2F%2Ftwitter.com%2Ferrolmorris&amp;fme=1&amp;pretty=1&amp;callback=">which accounts are claimed by http://twitter.com/ErrolMorris</a> &#8230; and this finds some interesting information, since (unlike errormorris.com) Twitter is a site that is understood by the Google Social Graph API. We find a location (Boston MA), some photo and feed urls, but also a link from ErrolMorris on twitter to his homepage, www.errolmorris.com.</p>
<p>This last point is important: Google Social Graph API is structured in terms of claims. This gives it a lot more robustness against spammers and mischief. SGAPI notices that the markup on the Twitter page says, in effect, &#8220;this is my homepage over here&#8221; (in microformat-speak, &#8216;this is (also) me&#8217;). Here it is in full, &#8230; the link <em>from</em> Errol Morris on Twitter, linking <em>to</em> his homepage:</p>
<pre id="line325">&lt;<span>a</span><span> href</span><span>="</span><a href="view-source:http://www.errolmorris.com/">http://www.errolmorris.com</a><span>" </span><span>class</span>=<span>"url" </span><span>rel</span>=<span>"<strong>me</strong> nofollow" </span><span>target</span>=<span>"_blank"</span>&gt;</pre>
<p>But the Google SGAPI notices that the homepage doesn&#8217;t <em>explicitly </em>reciprocate the claim. There is no machine markup in the homepage to indicate that the owner of the page is saying that the twitter page &#8220;is me&#8221;. It might just be a link to a friend, for example.</p>
<p>Nevertheless, we can use the SGAPI in less trusting mode (&#8217;show inbound links&#8217;), and take advantage of Google&#8217;s massive Web index to ask: <a href="http://socialgraph.apis.google.com/lookup?q=http%3A%2F%2Ftwitter.com%2Ferrolmorris&amp;fme=1&amp;edi=1&amp;pretty=1&amp;callback=">which pages claim to have the same owner as www.errolmorris.com</a>?</p>
<p>This gives us a story about how we can find a lot of useful contextual information, given a basic starting point. The Google service I show here is just one of several that could be exploited in &#8216;linked tv&#8217; scenarios.</p>
<p>For finding other identifiers, we might use sameas.org. Here&#8217;s what I get <a href="http://sameas.org/html?uri=http%3A%2F%2Fdbpedia.org%2Fresource%2FThe_Fog_of_War&amp;x=20&amp;y=16">when I ask it</a> for other URIs for the fog of war film, using a dbpedia uri as entry point:</p>
<ol>
<li><a title="http://dbpedia.org/resource/The_Fog_of_War" href="http://dbpedia.org/resource/The_Fog_of_War">http://dbpedia.org/resource/The_Fog_of_War</a></li>
<li><span> </span><a title="http://dbpedia.org/resource/11_Lessons_from_the_Life_of_Robert_S._Mcnamara" href="http://dbpedia.org/resource/11_Lessons_from_the_Life_of_Robert_S._Mcnamara">http://dbpedia.org/resource/11_Lessons_from_the_Life_of_Robert_S._Mcnamara</a><span> </span></li>
<li><span> </span><a title="http://mpii.de/yago/resource/The_Fog_of_War" href="http://mpii.de/yago/resource/The_Fog_of_War">http://mpii.de/yago/resource/The_Fog_of_War</a></li>
<li><a title="http://rdf.freebase.com/ns/guid.9202a8c04000641f80000000004e1a97" href="http://rdf.freebase.com/ns/guid.9202a8c04000641f80000000004e1a97">http://rdf.freebase.com/ns/guid.9202a8c04000641f80000000004e1a97</a></li>
</ol>
<p>For &#8217;social graph&#8217; data, we might also check <a href="http://sindice.com">sindice.com</a> or <a href="http://foaf.qdos.com">foaf.qdos.com</a>.</p>
<p>Topic description</p>
<p>A quick word on topics and wikipedia: by using content identifiers that link to Wikipedia and DBpedia, we have the potential for extremely rich, fine grained topical annotations.</p>
<p>Wikipedia&#8217;s <a href="http://en.wikipedia.org/wiki/The_Fog_of_War">page</a> about the movie notes that it covers the Cuban Missile Crisis. This association is now machine-visible, since I personally improved the relevant Wikipedia entry to explicitly link to the <a href="http://en.wikipedia.org/wiki/Cuban_Missile_Crisis">Cuban Missile Crisis</a> page on Wikipedia. This allows us to use wikipedia:Cuban_Missile_Crisis as a topic indicator, not just against the entire film but against particular segments of the movie that are about that topic. It is easy to get a list of such links from the Wikipedia markup, eg. [[Ford Motor Company]], [[Vietnam War]] are also already there. If we have a TV presentation system that has a unique id for the content (and ideally content-version, since content often varies), and we know an offset in seconds, then rich topical tags could be applied to sections of the film, without the need for textual data entry. An iphone or similar device could allow users to pause, annotate/tag/bookmark and continue their viewing, with no need for a keyboard.</p>
<p>That smart-phone story there is worth investigating, but let&#8217;s first start closer to the screen: what kinds of set top box, media centre or gadget might be able to index, navigate and play content in a way that makes interesting use of &#8216;linked tv&#8217; techniques such as these? Which brings me to APIs for &#8216;<a href="http://en.wikipedia.org/wiki/Media_center">media centre</a>&#8216; systems, finally.</p>
<p>If we want to recommend interesting content to users, show them relevant links, annotations, related materials (not necessarily more video &#8211; text, audio, even a spreadsheet with statistics might be appropriate), suggestions from friends, upcoming broadcasts or archived materials, then we need an environment that is scripting friendly and capable of interacting with users in a rich and compelling manner. The simplest path here is to start with what&#8217;s out there already, and look at commonalities in API and data model, to see how far existing software can be &#8216;remote controlled&#8217; from external scripts (and, eventually, from actual hand-held remote controls, eg. smartphones). I&#8217;ll go into some detail on that in the followup post.</p>
<p>The main point I want to (<a href="http://openp2p.com/lpt/a/554">re-</a>)emphasise here, is that once we make get to the stage of having well known identifiers for content, it facilitates a very rich marketplace for TV-related metadata, with emphasis on the word &#8220;-<em>related</em>&#8220;. And that this is necessarily very open-ended, since TV content can be about absolutely anything. I gave some examples drawing on Wikipedia/DBpedia for content metadata, and on homepages, twitter and Google&#8217;s Social Graph API to show how additional highly relevant information can be pulled from the Web, once we get a basic starting point. Finding ways of presenting such extra information to users, and giving them appropriate navigation and interaction options, is far from easy. Fortunately it is easier to share, syndicate and merge TV <em>meta</em>-content, than TV content. We are already seeing systems such as the <a href="http://xbmc.org/">XBMC</a>-based <a href="http://www.boxee.com">Boxee</a> which will normalise content identifiers in a way that <a href="http://boxee.pbworks.com/why-boxee-is-good-for-content-owners">encourages</a> legal uses over illegal. Intellectual properties issues around TV content means that actual playable content is often not broadly shareable. However the same need not be true of user-supplied metadata, since this can be about a specific media file, but also it can be about the things the content is about. I expect to see TV meta-content shared in a global linked system, even while the underlying video and audio remain relatively hidden away; rich user-supplied TV metadata isn&#8217;t just about the TV show, it equally can tell us about the world and the viewer, and deserves to be widely available through open standards.</p>
<p>To go back to my original example, <a href="http://en.wikipedia.org/wiki/Errol_Morris">Errol Morris&#8217;s</a> film about <a href="http://en.wikipedia.org/wiki/Robert_McNamara">Robert McNamara</a>, <a href="http://en.wikipedia.org/wiki/The_Fog_of_War">The Fog of War</a>&#8230; there&#8217;s a world of metadata options <a href="http://youtube-global.blogspot.com/2009/09/five-stars-dominate-ratings.html">beyond five-star ratings</a> that can enrich such content, beyond worrying about numerical ranking in statistical recommender systems. Existing work there, eg. around the <a href="http://en.wikipedia.org/wiki/Netflix_Prize">Netflix prize</a>, would be hard to beat. Statistical recommendations work well over a regular dataset where everything has a well known identifier. We can see RDF and linked data techniques serving a pre-processing role for such analysis, by linking together otherwise fragmented pieces of information about content, allowing classic techniques to be applied over a wider dataset.</p>
<p>However, I see the true &#8216;linked TV&#8217; potential to be primarily in another direction: in creating more meaningful conversations around content, and helping users find other information that gives a complementary perspective on the materials, and on cross-referencing <em>everything</em> with <em>everything</em> so that unexpected new paths can be found. Morris&#8217; film can teach us a lot about McNamara, but also about the wider world and recent history &#8230; about the <a href="http://en.wikipedia.org/wiki/Ford_Motor_Company">Ford Motor Company</a>, the <a href="http://en.wikipedia.org/wiki/Vietnam_War">Vietnam War</a>, the <a href="http://en.wikipedia.org/wiki/Cuban_Missile_Crisis">Cuban Missile Crisis</a>, the <a href="http://en.wikipedia.org/wiki/Strategic_bombing_during_World_War_II#United_States_strategic_bombing_of_Japan">firebombing</a> <a href="http://en.wikipedia.org/wiki/Bombing_of_Tokyo">of Tokyo</a> under the command of <a href="http://en.wikipedia.org/wiki/Curtis_LeMay">Curtis LeMay</a>. Not all easy or pleasant topics to try to understand, and each with thousands of other relevant sources (video or otherwise) out there, different perspectives to cross-reference, different accounts to reconcile.</p>
<p>If television is an environment in which we can be <a href="http://www.bbc.co.uk/info/purpose/">informed, educated and entertained</a> (by broadcasters, content creators, and increasingly, by everyone else too), we need to think through what this means for better metadata. Today we are lucky if we can find a good way of even <em>identifying</em> a piece of content. But tomorrow, we should have TV that comes out of the box with &#8220;<em>Do You Want To Know More</em>?&#8221; switched &#8216;<strong>on</strong>&#8216; by default.</p>
<p>When Obama gives a talk (see his <a href="http://www.whitehouse.gov/blog/NewBeginning/">June 2009 speech in Cairo</a>) he mentioned the following, at around 33 minutes and 30 seconds:</p>
<blockquote><p>For many years, Iran has defined itself in part by its opposition to my country, and there is in fact a tumultuous history between us.  <em>In the middle of the Cold War, the United States played a role in the overthrow of a democratically elected Iranian government</em>.</p></blockquote>
<p>This last point is well covered by historians, but was likely to be new information for many viewers in the USA and UK, if not for those in Iran. What can we do to improve that, by bringing Web and TV closer together?</p>
<p>While the <a href="http://www.whitehouse.gov/videos/2009/June/20090604_Cairo_University.mp4">raw video</a>, <a href="http://www.whitehouse.gov/videos/2009/June/20090604_Cairo_University.mp3">audio</a>, and <a href="http://www.whitehouse.gov/the_press_office/Remarks-by-the-President-at-Cairo-University-6-04-09/">transcript</a> are  available on the Whitehouse site, we don&#8217;t yet have enough for &#8220;do you want to know more?&#8221;. W3C&#8217;s <a href="http://www.w3.org/AudioVideo/TT/">TimedText</a> work might provide a basis for associating the transcript with the video as subtitles. This is not enough for someone who <em>wants to know more</em>, in following up this unusual acknowledgement of superpower interference.</p>
<p>An Internet-literate, laptop-owning Web user might try to find out more in an active manner. Although they are in a minority amongst TV viewers, there are still thousands of such people, and they know how to go to google.com and do searches. Can we harness their energy to improve the TV metadata environment for everyone? If you search Google for &#8216;US overthrow iranian government&#8217; you find a good starting point for learning more, a Wikipedia page &#8220;<a href="http://en.wikipedia.org/wiki/1953_Iranian_coup_d%27%C3%A9ta">1953 Iranian coup d&#8217;état</a>&#8220;. Although that page has content which Wikipedia flags as controversial, it has a world-visible <a href="http://en.wikipedia.org/wiki/Talk:1953_Iranian_coup_d%27%C3%A9tat">talk page</a> in which contributors from around the world can debate the detail of the topic. So how can this Web content be bridged with the world of TV?</p>
<p>TV viewers are commonly concerned characterised in terms of a pyramid:</p>
<ul>
<li>a passive majority, content to watch without interaction</li>
<li>a smaller group who will interact and navigate, but who rarely create new content</li>
<li>an even smaller group of activist users, who will explore, annotate, interact and create using all the tools available</li>
</ul>
<p>The production and consumption of &#8216;do you want to know more?&#8217; annotation won&#8217;t equally distributed. All viewers can benefit from, for example, a link from the Obama Cairo speech video to background information on the 1953 Iran coup. Some viewers might benefit indirectly, because their more inquisitive friends and family will have explored the linked materials and will <em>talk</em> to them about it. Others might read the wikipedia page and linked pages directly; if not on their television, then later on a laptop or PC.</p>
<p>Still others (a minority, but such minorities can be influential) might engage further with the material, become intrigued by the differences of opinion and seek more perspectives from the wider Web. Now 1953 is not ancient history; it falls within the living memory of countless people, in Iran, the UK and the world at large. A challenge for Linked TV is to find ways to integrate those memories and views into the TV environment, such that any viewer could pause the playing of the <a href="http://www.whitehouse.gov/blog/NewBeginning/">Obama Cairo speech</a> video because they <em>want to know more</em> about what he just said. Regardless of whether they are watching on whitehouse.gov, YouTube, Joost, a live re-broadcast, a radio-extract, a player embedded in a social network site (facebook, orkut, hyves, &#8230;), or running on a mobile phone. The current problem Iranians have with getting full and high-bandwidth Web access are another obstacle, of course, but eventually we can expect relevant video or audio memories from Iran (with subtitles and translations) to be 1 or 2 clicks away from Obama&#8217;s video, regardless of the software and environment playing the video. Much of that material is already out there <em>somewhere</em>, the challenge is to find it, link it and present it appropriately.</p>
<p>The core piece of metadata, a link from a section of the <a href="http://www.whitehouse.gov/videos/2009/June/20090604_Cairo_University.mp4">video</a> (ie. the offset, 33mins, 30 secs) of his speech to a URL for the topic it describes, could be created by whitehouse.gov staff, or it could be created by activist users. We pretty much know how to do this. A time-offset and a wikipedia URL do that job well enough for now. But what we have so far failed to achieve is a world-wide data ecosystem in which this kind of TV-enriching metadata is plentiful, widely used, and comprehensive enough that we can grow to expect to have fact-checkable TV, cross-referencable TV, hypertext TV. Instead of throwing physical things at the TV when we disagree with what we hear, it should become commonplace to be able to press pause and then or later publish your perspective (an audio rant, a fact-check crosslink, a blog post) in a way that will become accessible by other viewers of that material in the future.</p>
<p>To achieve this, we can&#8217;t afford needless fragmentation</p>
<ul>
<li>of meta-content about different versions of the same basic content</li>
<li>between geographical regions based on geo-rights to play the material</li>
<li>between desktop, media-centre, mobile, set top box, broadcast and on-demand scenarios</li>
<li>between radio and TV</li>
<li>between files and streams</li>
<li>between file formats</li>
<li>between populations (&#8217;net censorship and crude blocking technology)</li>
</ul>
<p>If these huge obstacles can be overcome, it might become reasonable to expect to find useful information attached to most of what we see on next-generation TV, regardless of delivery system. My hunch is the right place to prototype is around opensource and hackable media centre systems, and the right low-level communications system is XMPP. I&#8217;ll go into this more in the next post. Apologies for the length of this one. Comments welcomed by blog email or whatever!</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/moo4cGlz9VY" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/09/452</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/10/02/445">
	<title>Getting started with Mozilla Jetpack for Thunderbird (on OSX)</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/DZpfsPdEWqk/445</link>
	 <dc:date>2009-10-02T11:35:21Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
	<description>A few weeks ago, I started to experiment with Mozilla's new Jetpack extension model when it became available for Thunderbird. Revisiting the idea today, I realise I'd forgotten the basic setup details, so am recording them here for future reference.

I found I had to download the source from the Mercurial ...</description>
	<content:encoded><![CDATA[<p>A few weeks ago, I started to experiment with Mozilla&#8217;s new <a href="http://jetpack.mozillalabs.com/">Jetpack</a> extension model when it became available for Thunderbird. Revisiting the idea today, I realise I&#8217;d forgotten the basic setup details, so am recording them here for future reference.</p>
<p>I found I had to download the source from the Mercurial Web interface, rather than use pre-prepared XPI installers. This may have improved by the time you read this. I also learned (from Standard9 in #jetpack IRC) that I need <a href="http://hg.mozilla.org/users/bugmail_asutherland.org/opc-jetpack/">asuth&#8217;s repository</a>, rather than the main one. Again, things move quickly, don&#8217;t assume this is true forever.</p>
<p>Here is what worked for me, on OSX.</p>
<p>1. Grab a .zip from the Jetpack repo, and unpack it locally on a machine that has Thunderbird installed.</p>
<p>2. Edit extensions/install.rdf and make sure the em:maxVersion in the Thunderbird section matches your version of Thunderbird. In mine I updated it to say &lt;em:maxVersion&gt;3.0b4&lt;/em:maxVersion&gt; (instead of 3.0b4pre).</p>
<p>3.  See the README in the jetpack filetree for installation. With Thunderbird closed, I ran &#8220;python manage.py install &#8211;app=thunderbird&#8221; and I found Jetpack installed fine.</p>
<p>4. Run Thunderbird, you should see an about:jetpack tab, and corresponding options in the Tools menu.</p>
<p>This was enough to get started. See <a href="http://www.visophyte.org/blog/2009/07/23/thunderbird-jetpack-messagedisplay-overridemessagedisplay-fun/comment-page-1">discussion on visophyte.org</a> for some example code.</p>
<p>After installation, you can use the about:jetpack windows to load, reload and delete Jetpacks from URL.</p>
<p>So, why would you bother doing all this? Jetpack provides a simple way of extending an email client using Web technology.</p>
<p>In my current (unfinished!) <a href="http://pastebin.com/f34bbdcdb">experiment</a>, for example, I&#8217;m looking at making a sidebar the shows information (photo, blog etc.) about the sender of the currently-viewed email. And I figured that if I blogged this HOWTO, someone more familiar with ajax, jquery etc might care to help with wiring this up to the <a href="http://code.google.com/apis/socialgraph/">Google Social Graph JSON API</a>, so we can use FOAF and XFN to provide more contextual information around incoming mail&#8230;</p>
<p>Assuming you are running Thunderbird 3b4</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/DZpfsPdEWqk" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/10/02/445</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/09/28/433">
	<title>Mirrors and Prisms: robust site-specific browsers</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/f30Nb8oeZE0/433</link>
	 <dc:date>2009-09-28T19:40:20Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Activism]]></dc:subject>
		<dc:subject><![CDATA[coding]]></dc:subject>
	<description>Mozilla (amongst others, see Chris Messina's writeup of the trend, also Matt's) have been exploring site-specific browsers through their Prism project. These combine aspects of the Web and Desktop environments, allowing you to have a desktop app tuned for browsing just one specific Web site. Prism is an application which, ...</description>
	<content:encoded><![CDATA[<p>Mozilla (amongst others, see Chris Messina&#8217;s <a href="http://factoryjoe.com/blog/2007/12/28/fluid-prism-mozpad-and-site-specific-browsers/">writeup</a> of the trend, <a href="http://browsing.justdiscourse.com/2008/01/14/browser-trends-site-specific-browsers/">also Matt&#8217;s</a>) have been exploring <a href="http://en.wikipedia.org/wiki/Site-specific_browser">site-specific browsers</a> through their <a href="http://prism.mozilla.com/">Prism</a> project. These combine aspects of the Web and Desktop environments, allowing you to have a desktop app tuned for browsing just one specific Web site. Prism is an application which, when run, will generate new per-site desktop applications. Currently it does not yet have a fancy packaging/installer, so users will need to install Prism plus the site files separately.</p>
<p>I have started to look at Prism as a basis for accessing robust, mirrored sites, so that a single point of failure (or censorship) might be avoided. With a lot help from <a href="http://browsing.justdiscourse.com/">Matt</a> and others in <a href="irc://irc.mozilla.org/prism">#prism</a> IRC chat, I have something almost working. The idea is simple: hack Prism so that the running browser code intercepts clicks and (based on some as-yet-undefined logic and preferences) gets the page from a list of mirrors, which might also be fetched dynamically from the &#8216;net.</p>
<p>I should also mention that one motivation here is for anti-censorship tools, to give users an easy way to access sites which might be blocked by their IP address or URL otherwise. I looked at FoxyProxy as an option but for site-specific robustness, running a full proxy server seems a bit heavy, compared to simply duplicating a set of files. Here&#8217;s what the main Prism app looks like:</p>
<div id="attachment_434" class="wp-caption alignnone" style="width: 216px"><img class="size-medium wp-image-434" title="prism-gutenberg" src="http://danbri.org/words/wp-content/uploads/2009/09/prism-gutenberg-206x300.png" alt="prism-gutenberg" width="206" height="300" /><p class="wp-caption-text">Screenshot showing Prism config settings for a site-specific browser.</p></div>
<p>Once you have Prism installed, you can hack a file named <a href="http://mxr.mozilla.org/mozillasvn/source/projects/webrunner/chrome/content/webrunner.js#571">webrunner.js</a> to intervene when links are clicked. In OSX, this can be found as /Applications/Prism.app/Contents/Resources/chrome/webrunner/content/webrunner.js.</p>
<p>Edit this: <strong>_domActivate : function(aEvent)</strong></p>
<p>I added the following block to the start of this function:</p>
<p>var link = aEvent.target;<br />
if (link instanceof HTMLAnchorElement &amp;&amp; !WebRunner._isLinkExternal(link)) {<br />
aEvent.preventDefault();<br />
WebRunner._getBrowser().loadURI(&#8221;http://example.org/mirrors/&#8221;+link.href,null,null);<br />
}</p>
<p>The idea here being that we intercept clicks, and rewrite them to point to equivalent http:// URIs elsewhere in the Web. As far as this goes, it works as advertised. But what I have is far from working&#8230; it would need some code in there to find the right mirror URLs to fetch from. Perhaps a list might be fetched on startup or first time a link is followed. It could also do with some work on packaging, so that this hacked version of Prism plus some actual site-specific browser config can be made into an easy-install Windows .exe or OSX .app. For a Windows installer, I am told that <a href="http://en.wikipedia.org/wiki/Nullsoft_Scriptable_Install_System">NSIS</a> is a good place to start. You could also imagine a version that hid the mirrored URLs from user&#8217;s view. Since Prism has a built-in option to completely hide the URL navigation bar, I didn&#8217;t investigate this idea yet.</p>
<p>OK I think I&#8217;ve written up everything I learned from the helpful folks in IRC. I hope this repays some karma. If anyone cares to explore this further, or wants to help target student projects on exploring it, please get in touch.</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/f30Nb8oeZE0" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/09/28/433</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/08/30/427">
	<title>Wolfram Alpha Interview</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/GrraWmXKPlo/427</link>
	 <dc:date>2009-08-30T15:43:52Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Semantic Web]]></dc:subject>
		<dc:subject><![CDATA[china]]></dc:subject>
		<dc:subject><![CDATA[interview]]></dc:subject>
		<dc:subject><![CDATA[wolfram]]></dc:subject>
	<description>An interview with Xiang Wang of Wolfram Research in China, by Han Xu (Collin Hsu) of W3China fame.

Interesting excerpt:
Q: Since Wolfram|Alpha is dubbed 'smarter' than traditional search engines, I wonder how much AI techniques are actually employed in the system? How is inference done? What is the provenance of each ...</description>
	<content:encoded><![CDATA[<p>An <a href="http://www.infoq.com/news/2009/07/Interview-Wolfram-Alpha">interview</a> with Xiang Wang of Wolfram Research in China, by Han Xu (Collin Hsu) of <a href="http://www.w3china.org/index.htm">W3China</a> fame.</p>
<p>Interesting excerpt:</p>
<blockquote><p>Q: Since Wolfram|Alpha is dubbed &#8217;smarter&#8217; than traditional search engines, I wonder how much AI techniques are actually employed in the system? How is inference done? What is the provenance of each fact/claim? And what if there is a disagreement? For example, how it would represent information about Israel/Palestine area?</p>
<p>A: It&#8217;s much more an engineered artifact than a humanlike artificial intelligence. Some of what it does &#8211; especially in language understanding &#8211; may be similar to what humans do. But its primary objective is to do directed computations, not to act as a general intelligence. Wolfram|Alpha uses established scientific or other models as the basis for its computations. Whenever it does new computations, it&#8217;s effectively deriving new facts. About the controversial data you asked about, we deal in different ways with numerical data and particular issues. For numerical data, Wolfram| Alpha curators typically assign a range of values that are then carried through computations. For issues such as the interpretation of particular names or terms, like Israel/Palestine area issue mentioned in your question, Wolfram|Alpha typically prompts users to choose the assumption they want. We spend considerable effort on automated testing, expert review, and checking external data that we use to ensure the results. But with trillions of pieces of data, it&#8217;s inevitable that there are still errors out there. If you ever see a problem, please report it.</p></blockquote>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/GrraWmXKPlo" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/08/30/427</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/07/23/423">
	<title>What kind of Semantic Web researcher are you?</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/hJ35DzPFGxQ/423</link>
	 <dc:date>2009-07-23T08:41:04Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[Project ideas]]></dc:subject>
		<dc:subject><![CDATA[SocialWeb]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[privacy]]></dc:subject>
		<dc:subject><![CDATA[burglarbill]]></dc:subject>
	<description>It's hard to keep secrets in today's increasingly interconnected, networked world. Social network megasites, mobile phones, webcams and  inter-site syndication can broadcast and amplify the slightest fragment of information. Data linking and interpretation tools can put these fragments together, to paint a detailed picture of your life, both online and ...</description>
	<content:encoded><![CDATA[<p>It&#8217;s hard to keep secrets in today&#8217;s increasingly interconnected, networked world. Social network megasites, mobile phones, webcams and  inter-site syndication can broadcast and amplify the slightest fragment of information. Data linking and interpretation tools can put these fragments together, to paint a detailed picture of your life, both online and off.</p>
<p>This online richness creates offline risk. For example, if you&#8217;re going away on holiday, there are hundreds of ways in which potential thieves could learn that your home is vacant and therefore a target for crime: shared calendars, twittered comments from friends or family, flickr&#8217;d photographs. Any of these could reveal that your home and possessions sit unwatched, unguarded, presenting an easy target for criminals.</p>
<p>Q: What research challenge does this present to the Semantic Web community? How can we address the concern that Semantic and Social Web technology have more to offer Burglar Bill than to his victims?</p>
<p>A1: We need better technology for limiting the flow of data, proving a right to legitimate access to information, cross-site protocols for deleting leaked or retracted data that flows between sites, and calculating trust metrics for parties requesting data access.</p>
<p>A2: We need to find ways to reconnect people with their neighbours and neighbourhoods, so that homes don&#8217;t sit unwatched when their occupants are away.</p>
<p><em>ps. Dear Bill, I have my iphone, laptop, piggy bank and camera with me&#8230;</em></p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/hJ35DzPFGxQ" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/07/23/423</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/06/30/418">
	<title>NoTube scenario: Facebooks groups and TV recommendation</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/Smk3cwbp_88/418</link>
	 <dc:date>2009-06-30T04:17:42Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[General]]></dc:subject>
	<description>Short version: If the Web knows I like a TV show, why can't my TV be more useful?

So I have just joined a Facebook group, "Spaced Appreciation Society":

Basic Info
Type:     Common Interest - Pets &amp; Animals
Description: If you've ever watched (and therefore loved) the TV series Spaced, ...</description>
	<content:encoded><![CDATA[<p>Short version: <em>If the Web knows I like a TV show, why can&#8217;t my TV be more useful?</em></p>
<p>So I have just joined a Facebook group, &#8220;<a href="http://www.facebook.com/group.php?gid=2220877916">Spaced Appreciation Society</a>&#8220;:</p>
<p>Basic Info<br />
Type:     Common Interest &#8211; Pets &amp; Animals<br />
Description: If you&#8217;ve ever watched (and therefore loved) the TV series Spaced, then come and pay homage to the great Simon Pegg and Jess Stevenson. &#8220;You f&#8217;ing plum&#8221;<br />
Contact Details<br />
Website:     <a href="http://www.spaced-out.org.uk/">http://www.spaced-out.org.uk/</a><br />
Location:     Meteor Street</p>
<p>That URL is (as with many of these groups) from a site whose primary topic is the thing the group&#8217;s about. In this case, about a TV show. It&#8217;s even in the public page for that group:</p>
<p>&lt;tr&gt;&lt;td class=&#8221;label&#8221;&gt;<strong>Website</strong>:&lt;/td&gt;<br />
&lt;td class=&#8221;data&#8221;&gt;&lt;div class=&#8221;datawrap&#8221;&gt;&lt;a href=&#8221;<strong>http://www.spaced-out.org.uk/</strong>&#8221; onmousedown=&#8221;return wait_for_load(this, event, function() { UntrustedLink.bootstrap($(this), &amp;quot;&amp;quot;, event) });&#8221; target=&#8221;_blank&#8221; rel=&#8221;nofollow&#8221;&gt;<strong>http://www.spaced-out.org.uk/</strong>&lt;/a&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;</p>
<p>If I search Google (Yahoo BOSS might be wiser, they have APIs) with:</p>
<p>link:http://www.spaced-out.org.uk/ site:wikipedia.org</p>
<p>It finds me:</p>
<p><a href="http://en.wikipedia.org/wiki/Spaced">http://en.wikipedia.org/wiki/Spaced</a></p>
<p>Although &#8220;link:http://www.spaced-out.org.uk/ site:dbpedia.org&#8221; doesn&#8217;t find anything, some URL rewriting gets me to:</p>
<p><a href="http://dbpedia.org/page/Spaced">http://dbpedia.org/page/Spaced</a></p>
<blockquote><p>&#8220;Spaced is a British television situation comedy written by and starring Simon Pegg and Jessica Stevenson, and directed by Edgar Wright. It is noted for its rapid-fire editing, frequent dropping of pop-culture references, and occasional displays of surrealism. Two series of seven episodes were broadcast in 1999 and 2001 on Channel 4.&#8221;</p></blockquote>
<blockquote><p>dbpedia-owl:author<br />
* dbpedia:Jessica_Hynes<br />
* dbpedia:Simon_Pegg</p>
<p>dbpedia-owl:completionDate<br />
* 2001-04-13 (xsd:date)</p>
<p>dbpedia-owl:director<br />
* dbpedia:Edgar_Wright</p>
<p>dbpedia-owl:episodenumber<br />
* 14</p>
<p>dbpedia-owl:executiveproducer<br />
* dbpedia:Humphrey_Barclay</p>
<p>dbpedia-owl:genre<br />
* dbpedia:Situation_comedy</p>
<p>dbpedia-owl:language<br />
* dbpedia:English_language</p>
<p>dbpedia-owl:network<br />
* dbpedia:Channel_4</p>
<p>dbpedia-owl:producer<br />
* dbpedia:Gareth_Edwards<br />
* dbpedia:Nira_Park</p>
<p>dbpedia-owl:releaseDate<br />
* 1999-09-24 (xsd:date)</p>
<p>dbpedia-owl:runtime<br />
* 24</p>
<p>dbpedia-owl:starring<br />
* dbpedia:Jessica_Hynes<br />
* dbpedia:Simon_Pegg</p></blockquote>
<p>There are also links from here to Cyc (but an incorrect match) and to Freebase (to <a href="http://www.freebase.com/view/en/spaced">http://www.freebase.com/view/en/spaced</a>).</p>
<p>Unfortunately, the Wikipedia &#8220;external links&#8221; section, with the URL for http://www.spaced-out.org.uk/ (marked &#8220;offical, fan-operated site&#8221; is not part of the DBpedia RDF export. I guess as it is not in an infobox. Extracting these external-link URLs at least for the TV, Actor and Movie related sections of Wikipedia might be worthwhile. And DBpedia would be useful for identifying the relevant subset to re-extract.</p>
<p>This idea of using such URLs as keys into Wikipedia/dbpedia data would also work with Identi.ca groups and others. In fact the matching might be easier in Identi.ca &#8211; I&#8217;m not sure how the Facebook APIs expose this stuff.</p>
<p>Anyway, if a show is about to be broadcast that includes eg. an interview with dbpedia:Jessica_Hynes or dbpedia:Simon_Pegg I&#8217;d like to hear about it.</p>
<p>So&#8230; is there any way I can use BBC&#8217;s /programmes to get upcoming information about who will be on the radio or telly, in a way that could be matched against dbpedia URIs?</p>
<p>Edit: I should&#8217;ve mentioned that Facebook in particular also has a more explicit &#8220;is a fan of&#8221; construct, with Products, Celebs, TV shows and Stores as types of thing you can be a fan of. Furthermore these show up on your public page, eg. here&#8217;s <a href="http://www.facebook.com/danbri">mine</a>. I&#8217;m certainly interested in using that data, but also in a model that uses  general groups, since it is applicable to other sites that allow a group to indicate itself with a topical URL.</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/Smk3cwbp_88" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/06/30/418</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/06/16/415">
	<title>Twitter Iran RT chaos</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/O6uD27bXQUU/415</link>
	 <dc:date>2009-06-16T15:28:10Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Activism]]></dc:subject>
		<dc:subject><![CDATA[Conspiracy Theory]]></dc:subject>
		<dc:subject><![CDATA[FOAF]]></dc:subject>
		<dc:subject><![CDATA[Politics]]></dc:subject>
		<dc:subject><![CDATA[Project ideas]]></dc:subject>
		<dc:subject><![CDATA[SKOS]]></dc:subject>
		<dc:subject><![CDATA[The Web at War]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[openid]]></dc:subject>
		<dc:subject><![CDATA[privacy]]></dc:subject>
		<dc:subject><![CDATA[identica]]></dc:subject>
		<dc:subject><![CDATA[iran]]></dc:subject>
		<dc:subject><![CDATA[iranelection]]></dc:subject>
		<dc:subject><![CDATA[journalism]]></dc:subject>
		<dc:subject><![CDATA[tehran]]></dc:subject>
		<dc:subject><![CDATA[twitter]]></dc:subject>
		<dc:subject><![CDATA[witness]]></dc:subject>
	<description>From Twitter in the last few minutes, a chaos of echo'd posts about army moves. Just a few excerpts here by copy/paste, mostly without the all-important timestamps. Without tools to trace reports to their source, to claims about their source from credible intermediaries, or evidence, this isn't directly useful. Even ...</description>
	<content:encoded><![CDATA[<p>From Twitter in the last few minutes, a chaos of echo&#8217;d posts about army moves. Just a few excerpts here by copy/paste, mostly without the all-important timestamps. Without tools to trace reports to their source, to claims about their source from credible intermediaries, or evidence, this isn&#8217;t directly useful. Even grassroots journalists needs evidence. I wonder how <a href="http://hub.witness.org/">Witness</a> and <a href="http://identi.ca">Identi.ca</a> fit into all this. I was thinking today about an &#8220;(person) X claims (person) Y knows about (topic) Z&#8221; notation, perhaps built from FOAF+SKOS. But looking at this &#8220;Army moving in&#8230;&#8221; claim, I think something couched in terms of positive claims (along lines of the old OpenID showcase site <a href="http://jyte.com">Jyte</a>) might be more appropriate.</p>
<p>The following is from my copy/paste from Twitter a few minutes ago. It gives a flavour of the chaos. Note also that observations from very popular users (<a href="http://twitter.com/stephenfry/status/2190127914">such as stephenfry</a>) can echo around for hours, often chased by attempts at clarification from others.</p>
<p>(&#8221;RT&#8221; is Twitter notation for re-tweet, meaning that the following content is redistributed, often in abbreviated or summarised form)</p>
<p>plotbunnytiff: RT @suffolkinace: RT From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
r0ckH0pp3r: RT .@AliAkbar: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection<br />
jax3417: RT @ktyladie: RT @GennX: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection #iran<br />
ktladie: RT @GennX: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection #iran<br />
MellissaTweets: RT @AliAkbar: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection<br />
GennX: RT @MelissaTweets: RT @AliAkbar: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection</p>
<p>The above all arrived at around the same time, and cite two prior &#8220;sources&#8221;:</p>
<p>suffolkinnace: RT From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection   18 minutes ago from web</p>
<p>Who is this? Nobody knows of course, but there&#8217;s a twitter bio:</p>
<p>http://twitter.com/suffolkinace # Bio Some-to-be Royal Military Policeman in the British Army. Also a massive Xbox geek and part-time comedian</p>
<p>The other &#8220;source&#8221; seems to be http://twitter.com/AliAkbar<br />
AliAkbar: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection<br />
about 1 hour ago from web<br />
url http://republicmodern.com</p>
<p>This leads us to   <a href="http://republicmodern.com/about">http://republicmodern.com/about</a> where we&#8217;re told<br />
&#8220;Ali Akbar is the founder and president of Republic Modern Media. A conservative blogger, he is a contributor to Right Wing News, Hip Hop Republican, and co-host of The American Resolve online radio show. He was also the editor-in-chief of Blogs for McCain.&#8221;</p>
<p>I should also mention that a convention emerged in the last day two replace the names of specific local Twitter users in Tehran with a generic &#8220;from Iran&#8221;, to avoid getting anyone into trouble. Which makes plenty of sense, but without any in the middle vouching for sources makes it even harder to know which reports to take seriously.<br />
More&#8230; back to twitter search, what&#8217;s happened since I started this post?</p>
<p>http://twitter.com/#search?q=iranelection%20army</p>
<p>badmsm: RT @dpbkmb @judyrey: RT From Iran: CONFIRMED!! Army moving into Tehran against protesters! PLZ RT! URGENT! #IranElection #gr88<br />
SimaoC: RT @parizot: CONFIRMÉ! L&#8217;armée se dirige vers Téhéran contre les manifestants! #IranElection #gr88<br />
SpanishClash: RT @mytweetnickname: RT From Iran:ARMY movement NOT confirmed in last 2:15, plz RT this until confrmed #IranElection #gr88<br />
artzoom: RT @matyasgabor @humberto2210: RT CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! #IranElection #iranrevolution<br />
sjohnson301: RT @RonnyPohl From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection #iran9<br />
dauni: RT @withoutfield: RT: @tspe: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
interdigi: RT @ivanpinozas From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
PersianJustice: Once again, stop RT army movements until source INSIDE Iran verifies! Paramilitary is the threat anyway. #iranelection #gr88<br />
Klungtveit Anyone: What&#8217;s the origin of reports of &#8220;army moving in&#8221; on protesters? #iranelection<br />
Eruethemar: RT @brianlltdhq: RT @lumpuckaroo: Only IRG moving, not national ARMY&#8230; this is confirmed for real #IranElection #gr88<br />
SAbbasRaza: RT @bymelissa: RT @alexlobov: RT From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
timnilsson: RT @Iridium24: CONFIRMED!! Army moving into Tehran against protesters! PLEASE RT! URGENT! #IranElection<br />
edmontalvo: RT @jasona: RT @Marble68: RT From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
stevelabate: RT army moving into Tehran against protesters. Please RT. #iranelection<br />
ivanpinozas: From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection<br />
bschh: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection (via @dlayphoto)<br />
dlayphoto: RT From Iran: CONFIRMED!! Army moving into Tehran against protestors! PLEASE RT! URGENT! #IranElection</p>
<p>In short &#8230; chaos!</p>
<p>Is this just a social / information problem, or can different tooling and technology help filter out what on earth is happening?</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/O6uD27bXQUU" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/06/16/415</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/06/01/414">
	<title>Wordpressing from iphone</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/i0D_bFjTLQM/414</link>
	 <dc:date>2009-06-01T12:49:21Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[General]]></dc:subject>
		<dc:subject><![CDATA[iphone]]></dc:subject>
	<description>Is this thing on? </description>
	<content:encoded><![CDATA[<p>Is this thing on?</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/i0D_bFjTLQM" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/06/01/414</feedburner:origLink></item>
<item rdf:about="http://danbri.org/words/2009/05/27/412">
	<title>goo go opensocial</title>
	<link>http://feedproxy.google.com/~r/danbri_blog/~3/j9RYhIG_yWo/412</link>
	 <dc:date>2009-05-27T06:22:59Z</dc:date>
	<dc:creator>danbri</dc:creator>
			<dc:subject><![CDATA[Japan and Japanese]]></dc:subject>
		<dc:subject><![CDATA[OpenSocial]]></dc:subject>
		<dc:subject><![CDATA[SocialWeb]]></dc:subject>
		<dc:subject><![CDATA[Technology]]></dc:subject>
		<dc:subject><![CDATA[ggg]]></dc:subject>
		<dc:subject><![CDATA[gadgets]]></dc:subject>
		<dc:subject><![CDATA[go]]></dc:subject>
		<dc:subject><![CDATA[widgets]]></dc:subject>
	<description>The Japanese portal / search engine goo, have gone live with their Shindig-based OpenSocial container. See example user page, goo labs site, developer's kitchen and documentation (in Japanese). See also announcement from Eiji Kitamura on the shindig (Apache opensocial) list. </description>
	<content:encoded><![CDATA[<p>The Japanese portal / search engine <a href="http://goo.ne.jp/">goo</a>, have gone live with their Shindig-based OpenSocial container. See <a href="http://home.goo.ne.jp/user/agektmr">example user page</a>, <a href="http://labs.goo.ne.jp/">goo labs</a> site, <a href="http://developer.home.goo.ne.jp/">developer&#8217;s kitchen</a> and <a href="http://developer.home.goo.ne.jp/document/goo_Social_Platform%E3%81%A8%E3%81%AF">documentation</a> (in Japanese). See also <a href="http://markmail.org/message/4v4xx4wtnhrhd3bw">announcement</a> from Eiji Kitamura on the shindig (Apache opensocial) list.</p>
<img src="http://feeds.feedburner.com/~r/danbri_blog/~4/j9RYhIG_yWo" height="1" width="1"/>]]></content:encoded>
	<feedburner:origLink>http://danbri.org/words/2009/05/27/412</feedburner:origLink></item>
</rdf:RDF>
