Kevin Carmody: machines, media & miscellanea

Elsewhere: Mastodon, Github, Email

dConstruct 2010 - Brendan Dawes - Boil, Simmer, Reduce

Another dConstruct2010 post, this time: Brendan Dawes - Boil, Simmer, Reduce

Brendan didn’t really have as structured a talk, and one wonders if perhaps he relied more on gimmicks in his slides than the message he was trying to convey. The method he calls ‘Boil, Simmer, Reduce’ is basically his three part plan in creating a product. Frankly it seems a very logical, if not slightly fluffy minded way to work.

Boil This is basically filling your head with stuff. So it’s just about throwing anything and everything in to the ideas pot. When you embark on a development process you are already indirectly thinking about it all the time, whether you are watching a film, reading a fictional book or just contemplating the meaning of life. The premise is just to be grabbing ideas from all over the place and throwing them all in.

He also pointed out when discussing shots from films he likes that symmetry in itself makes things pretty.

Simmer This is looking at all considerations of what you want. It is important that you’re not considering technical restrictions, but rather getting down to the nub of what you’d like to do. As with the Boil stage, there are no rules, you can really just do whatever you like.

Around this point Brendan suggested that good design can breed good behaviour. He spoke of work he did for a tourist information office using Microsoft Surface as a map display. There were discs which they would place on the surface which would represent hotels, and by placing that on the map it would create a ring around that item with dots showing where the hotels are in that surrounding area. By turning the disc it would amplify the area of interest. This was in Manchester and it was quite a rough area of the centre of town - “a high proportion of scallies”. The place was concerned that the discs would get stolen. But it was a beautiful space that they created through design, and nothing was stolen. He argued that this proved his belief that “good design can bring good behaviour”.

Reduce “A design is finished when there is nothing left to take away”. Take the iPhone. It’s such a simple design, one button, an absolute minimum and it’s the sort of thing where anything can be placed on it. It can be anything you want it to be.

You should justify everything shown on a screen. This doesn’t necessarily mean that everything must serve a purposeful action. His favourite thing about the iPhone was that when you scroll up and get to the top, it creates a little bit of space with nothing underneath which simply springs back when you let go. This doesn’t really serve a purpose, bar perhaps a small mental indicator. It is just a little piece of aesthetic satisfaction. It’s just nice. That in itself can justify the feature.

He talked a bit about how he made something for the iPhone which was born out of a need. He wanted to watch a film on a train journey and couldn’t get his iPhone to sit in a good position, so he made a simple piece of cardboard that evening that would just clip onto the side. They thought it was sell-able and went through a few iterations. There was one which was so close to being right but it just wasn’t quite there. They then decided to apply Da Vinci’s Golden Ratio to the position of the cut in the rectangle. That was it. Fixed.

He also mentioned how he thinks the pencil is absolutely wonderful in design. A few of reasons he mentioned were:

1) It has a big arrow pointing to which end you use. 2) Built-in progress bar. 3) You can cut it up, and make many more of the same with it.

New ideas like this still apply to the old and best designed products.

Barcamp Not For Profit Oxford

On Saturday 20th Nov I spent the best part of the day at Barcamp Non-Profits (NFP) at the Oxford University Club. This was my first Barcamp, so I was interested to see how the event and it’s organisation was to unfold. For the uninitiated a Barcamp, often called an unconference, is as the name would suggest an ad hoc organised conference. A timetable of slots is offered and people simply add their name to a box in order to host a talk.

Barcamp Non-Profit timetable

I went to four talks on four very topics, which is perhaps a little surprising considering the focus of the day: Non Profits and Tech engagement

Social Monitoring

This was a two part talk with the focus being on monitoring information within social media. This could take the form of following discussion on a topic relevant to a charity’s engagement, or could equally be applied to monitoring a brand activity. I noted two tools in the first half which I thought could be of use. The first was Social Mention, which is best used for tracking social sentiment on the various social networks (Twitter, et al). The second was Board Tracker, which can be used for checking various forums for keyword mentions. There was also discussion of using the advanced mode of Google search. The second half was a brief discussion of a theoretical Twitter filter that would allow someone to summarise the important points of conversation using an quasi-AI approach. The interested parties of which broke of into a group to discuss the implementation of the project.

FLiP

This was a talk given by my boss Dave Fletcher. I was involved in the projects inception at the Jailbrake weekend hosted by Social Innovation Camp, so I was very interested to see how the project had progressed. I was pleased to hear that even after talks with various authorities and forthcoming pilot runs, the project had retained its original good ideas; to get friends to help you identify your key skills in a structured and playful format which will hopefully aid you in gaining employment. This is such a promising project and I feel really proud for even the small part that I played in its creation.

Giving What We Can

Well this talk absolutely blew me away. It was one of those ones that starts interesting and makes you chuckle and finishes with you feeling shocked at what you’ve learnt. The presenter, Toby Ord, has actually appeared in various mainstream media publications discussing his project, but as he readily pointed out, it isn’t a message designed for the 140char social conversation. I think it would be difficult for me to do him justice. This is a man who has such belief in the difference he can make to so many peoples lives that he is pledging to donate a significant portion of his income for the rest of his life. His argument is convincing and I sincerely hope you will visit his site, givingwhatwecan.org and take the time to read what he has to say.

Music, The Ultimate Non Profit

The last talk I went to was actually more for fun than engagement, but considering my rock background I really can’t be blamed :) This was Ben Walker of Twitter song fame discussing his life as a niche geek semi-celebrity. Fun and quirky.

</embed>

All in all, I had really fun and interesting time. I will certainly be going to another Barcamp at my next chance. Barcamp Non-Profits will be coming back, perhaps in spring and probably in London next time. You can find out more by going to barcampnonprofits.com or by following them on Twitter @barcampnfp. If you get the chance make sure you go.

dConstruct 2010 - Marty Neumeier - The Designful Company

The theme of dConstruct 2010 was Design & Creativity.

Marty Neumeier - The Designful Company

As I’m sure you can imagine, I only made some quick notes as I was listening to the talk, so what you will find here is an amalgamation of the talk and my own thoughts. Please do not consider this as their words or even mine.

I don’t know much about any of the dConstruct speakers - Marty from first appearance was a middle aged gentleman, smart with suit jacket, jeans and shoes.  This seemed to be a common style amongst the new media gang. Fashion aside, Marty’s talk was a discussion on branding and getting a good product within a brand. To this end he reference many tech business luminaries, though like most people there he was an Apple-afficianado. For example, he was fond of a particular Steve Jobs anecdote. ‘After a marked increase in sales, Jobs was asked “how do you intend to keep this up?” To which he replied: “we intend to keep innovating”’. Marty had a theme which he both uses as his opener and closer, very neatly done too, and it is simply this: “If you wanna innovate, you gotta design”.

Marty’s assertion was that Harvard business school teaches by case study, solving problems by looking how they have been solved previously. This is counter to successful tech businesses and brands, as is testament with Jobs’ statement of the importance of innovation.

So he talked about what really gets a product there is where you need to be designing, on that edge between radical and useful, those differences between what’s good and different. He talks about that traditional style brand-development where to go for something different is a risk, and many a CEO wouldn’t take that risk. The problem is if you don’t take that risk, there is a good chance of the brand dropping into obscurity. Consider the ubiquity of swoosh logos and then globe logos and how their commonness means the brand becomes unmemorable.

So, what are some of the most successful brands and how does one get there? Marty presents a path to follow in brand development where you have the vision at one end of the scale, and the product at the other end of the scale. He suggests that to be successful you’ve got to get from one end of that scale to the other. The path to follow has three stages: knowing, making and doing. It is to this end that you need a clear visionary that can manage these stages. One needs a leader who can picture the goal, has the resources available to build the product and impetus to actually put this together without diluting the vision or compromising on the product development.

Marty also talked about how business is speeding up…  I’ll be honest, I’m doubtful, I feel this is a cliche statement that many people make based on regurgitation. Still, he made a fair point and one that is difficult to dispute, but it could do with some kind of citation. “There are now more financial transactions in one day than the whole of 1965”.

So, what do consumers want? Well, we’ve always said these things: Pick two; good, cheap or fast. What he pointed out though, is that consumers have a new demand, they want free, perfect, now. So if you want your product to be successful you’ve got to give it everything. Let’s be honest, this is something we expect when one considers products like Google docs.  He then pointed out that just to be free, perfect and now isn’t necessarily enough! In an ever-cluttered market place you have to be really different, not just a little bit different, but really different. He talked about how we organise information in our mind using categories and compartmentalisation. So what you’re ideally looking for in a product is to get it in one of those compartments by itself.  So take the example of a smart phone - you want to have your product there by itself, like the iPhone, which for some time everyone thought of as the only smart phone. A successful brand is a walled category.

Historically, to make your product a successful one you would have started with factories. By having factories you can product more than anyone else, you can supply for the demand, you’d be at an advantage. When others realised this and everyone built factories, the next step was to get the most capital, allowing you to buy out the competition. After capital was patents. Patents were a means of securing your market. Of course they can only work for so long. So the final stage is where we are at now, brands. This saves a certain amount of process because in people’s own minds they will compartmentalise and protect your brand for you as a consumer. So, to summarise, we are talking about how in the past it was very much physical - factories and a physical present which keeps your product dominant in the market, whereas now it’s a mental thing within the mind of the consumer.

If a brand is good and different, it’s a gut feeling. Your brand is what the consumer says it is and for you to stand out, that’s where you have to be really different. Example - if we have Nike, do we need Reebok? Do we need Wimpy if we have McDonald’s?  A brand has to be truly radical and good, which is indeed a big risk.

I think in all the Apple-loving I heard on this day there is a tech brand that is more ubiquitous than iProducts will ever be: Linux. How different is that? Totally radical, and it’s everywhere. Just my 2p.

Marty presented a scale with which to measure brand success using the variables of good versus different on the z and y axes. He believed a brand generally fell into one of four sectors:

1) good, not different - common, does well in tests, and at first sales, but never really dominates its market. 2) good and different - this is the sweet spot. Often does poorly in tests, which means if often won’t get to market, slow in market, but customers will in time equate the weirdness to good : and eventually it will take a dominant position in the market. Example: Aeron chairs. (btw, I love Aeron chairs :) 3) not good and different - won’t do well in tests, and won’t be successful, people will equate weird to bad. 4) not good and not different - you just don’t want to be here, do you? But, this one often does well in tests because it’s not different, so it’s familiar to people. But it doesn’t challenge.  A surprising amount of products sit here, like Gillette fusion razors. Five blades. Five. Whoop-de-doop. Not exactly going to dominate the market.

As your brand visionary leader man, there are four key things you need: 1) empathy 2) intuition 3) experience 4) judgement

Let’s finish how Marty did. If you wanna innovate, you gotta design.

Fixing Eclipse ctrl+click Problem

Sometimes, for no clear reason, Eclipse’s ctrl+click function to find a methods source fails. This bugs the hell out of me, but is simple enough to fix. Unfortunately it doesn’t happen often enough for me to remember how to fix. And having to search each time with ‘just right’ keywords is also annoying. Anyway, here it is:

Close Eclipse.

Delete:  /path/to/workplace/.metadata/.plugins/org.eclipse.jdt.core

Open eclipse and let it rebuild its indexes. Job done.

All the latest updates

I’ve had many jobs. My full CV is unprintable in a comfortable digest. Though all were useful in their own way, it was still a means to an end. Rock superstardom… so four years ago I decided to retool in what was then a time devouring hobby. So far, things have been going pretty well. I got a decent degree and have had two awesome jobs in a row, the second of which I still happily work at (whiteoctober).

I’ve been keeping my head down for some time now. I’ve really been wanting to get good at what I’m doing before I start to think of other things. But I’m happy to say that recently I’m starting to ‘get it’ with many of the techs that I’m using. I know I still have sooo much to learn, but it’s a good feeling to be making progress.

Oh yeah, I use Ubuntu for both work and play now. Good times :)

Hmm, what else is new… I move in a couple of weeks, to a place in Headington. At the moment there are five of us living in a four bedroom house in East Oxford. It’s fun and communal and all, but I’m really looking forward to moving in with just myself and Emily. You should check her blog by the way: emilychiang.wordpress.com.

Actually, I think that’s it for now. Take care.

PHP Script for RSS auto-discovery and OPML file generation

Hey All,

I recently got a reasonable size list of blog URLs. What I wanted was to import all these into a feed reader (via OPML). There seemed to be a lack of conversion scripts for batch URL->find RSS link->feed reader import file (I may be wrong, please let me know if I am :), so I made one in PHP. I guess this is like an automatic-blogroller. I have just used this as a command line script, I’m not recommending you use this in ‘the wild’ as one might say, I have made little concession to security as I had a trusted list of URLs.

There are basically three steps to this

  1. Take an input file of newline seperated URLs, in my case blogs.
  2. Find (auto-discover) associated RSS feed of each blog URL
  3. Output an OPML file that you can use to import into a feed reader What it does:
  • Takes a well formed list of newline separated URLs of blogs and turns it into an OPML
  • If the URL source doesn’t contain a <link> to an RSS feed in the head it doesn’t add it to the OPML
  • Detects the <title> and adds that to the OPML text field, or uses the URL if <title> isn’t present What it doesn’t:

  • Check the RSS feed is validated XML
  • Any other checking really :)
  • Come with any sort of warranty/guarantee Some of the key functions are from Keith Devens work. Thanks. Without any further ado, here is the script:
<?php
/*
 * @author @skinofstars Kevin Carmody
 * GPLv3 - http://www.gnu.org/copyleft/gpl.html
 *
 * this is really a command line app with no flags
 * for turning a bunch ofurls into an OPML file
 *
 * 1.takes input file of newline seperated urls, normally blogs
 * 2.finds (autodiscovery) associated rss of each url
 * 3.outputs an OPML file for you to use in a feed reader
 */

// file config

$inputFile = "/path/to/URLlist.txt";
$outputFile = "/path/to/blogroll.opml";

// OPML config

$opmlTitle = "Some Select Blogs";
$opmlOwnerName = "Kevin Carmody";
$opmlOwnerEmail = "kevin@skinofstars.com";

/** no need to edit after this :) **/
$inHandle = @fopen($inputFile, "r");//read-only

$outHandle = @fopen($outputFile, "a");//append


if ($inHandle &amp;&amp; $outHandle) {
	$headerOut = opmlHeader($opmlTitle,$opmlOwnerName,$opmlOwnerEmail);
	fwrite($outHandle,$headerOut);

	while (!feof($inHandle)) {
		$buffer = fgets($inHandle, 4096);
		$source = getFile($buffer);
		$rssURL = getRSSLocation($source, $buffer);
		$rssTitle = htmlentities(getTitleAlt($source));
		if($rssURL){
			if($rssTitle){
				$entryOut = opmlEntry($rssURL,$rssTitle);
				fwrite($outHandle,$entryOut);
			} else {
				$entryOut = opmlEntry($rssURL,$rssURL);
				fwrite($outHandle,$entryOut);
			}
			//echo ".";//uncomment to print a dot to screen on each success, nice for seeing progress

		} else {
			echo "Fail on: ".$buffer;
		}
	}
	$footerOut = opmlFooter();
	fwrite($outHandle,$footerOut);

	fclose($inHandle);
	fclose($outHandle);
} else {
	if(!$inHandle){
		echo 'not got a handle on input file: '.$inputFile."\n";
		die;
	}
	if(!$outHandle){
		echo 'not got a got handle on output file: '.$outputFile."\n";
		die;
	}
}

echo "\nAll done :)\n";

/**
 * basic opml header
 * @param string $opmlTitle
 * @param string $opmlOwnerName
 * @param string $opmlOwnerEmail
 * @return string
 */
function opmlHeader($opmlTitle,$opmlOwnerName,$opmlOwnerEmail){
	$oheader = "&lt;?xml version=\"1.0\" encoding=\"ISO-8859-1\"?&gt;\n"
	."&lt;opml version=\"1.1\"&gt;\n"
	."	&lt;head&gt;\n"
	."		&lt;title&gt;".$opmlTitle."&lt;/title&gt;\n"
	."		&lt;dateCreated&gt;".date("r")."&lt;/dateCreated&gt;\n"
	."		&lt;ownerName&gt;".$opmlOwnerName."&lt;/ownerName&gt;\n"
	."		&lt;ownerEmail&gt;".$opmlOwnerEmail."&lt;/ownerEmail&gt;\n"
	."		&lt;/head&gt;\n"
	."	&lt;body&gt;\n";
	return $oheader;
}

/**
 * just returns a test footer
 * @return string
 */
function opmlFooter(){
	$ofooter = "  &lt;/body&gt;\n"
	."&lt;/opml&gt;";
	return $ofooter;
}

/**
 * creates an XML entry for the OPML file
 * @param string $feedURL
 * @param string $feedTitle
 * @return string
 */
function opmlEntry($feedURL,$feedTitle){
	$outline = "    &lt;outline text=\"".$feedTitle."\" type=\"rss\" xmlUrl=\"".$feedURL."\"/&gt;\n";
	return $outline;
}

/**
 * returns the page title extracted from source
 * @param string $html
 * @return string
 */
function getTitleAlt($html) {
	if (preg_match('/&lt;title&gt;(.*?)&lt;\/title&gt;/is',$html,$found)) {
		$title = $found[1];
		return $title;
	} else {
		return;
	}
}

/**
 * http://keithdevens.com/weblog/archive/2002/Jun/03/RSSAuto-DiscoveryPHP
 * public domain
 */
function getFile($location){
	$ch = curl_init($location);
	curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
	curl_setopt($ch, CURLOPT_HTTPHEADER, array('Connection: close'));
	curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
	curl_setopt($ch, CURLOPT_TIMEOUT, 15);
	$response = curl_exec($ch);
	curl_close($ch);
	return $response;
}

/**
 * http://keithdevens.com/weblog/archive/2002/Jun/03/RSSAuto-DiscoveryPHP
 * public domain
 */
function getRSSLocation($html, $location){
	if(!$html or !$location){
		return false;
	}else{
		#search through the HTML, save all &lt;link&gt; tags

		# and store each link's attributes in an associative array

		preg_match_all('/&lt;link\s+(.*?)\s*\/?&gt;/si', $html, $matches);
		$links = $matches[1];
		$final_links = array();
		$link_count = count($links);
		for($n=0; $n&lt;$link_count; $n++){
			$attributes = preg_split('/\s+/s', $links[$n]);
			foreach($attributes as $attribute){
				$att = preg_split('/\s*=\s*/s', $attribute, 2);
				if(isset($att[1])){
					$att[1] = preg_replace('/([\'"]?)(.*)\1/', '$2', $att[1]);
					$final_link[strtolower($att[0])] = $att[1];
				}
			}
			$final_links[$n] = $final_link;
		}
		#now figure out which one points to the RSS file

		for($n=0; $n&lt;$link_count; $n++){
			if(strtolower($final_links[$n]['rel']) == 'alternate'){
				if(strtolower($final_links[$n]['type']) == 'application/rss+xml'){
					$href = $final_links[$n]['href'];
				}
				if(!$href and strtolower($final_links[$n]['type']) == 'text/xml'){
					#kludge to make the first version of this still work

					$href = $final_links[$n]['href'];
				}
				if($href){
					if(strstr($href, "http://") !== false){ #if it's absolute

						$full_url = $href;
					}else{ #otherwise, 'absolutize' it

						$url_parts = parse_url($location);
						#only made it work for http:// links. Any problem with this?

						$full_url = "http://$url_parts[host]";
						if(isset($url_parts['port'])){
							$full_url .= ":$url_parts[port]";
						}
						if($href{0} != '/'){ #it's a relative link on the domain

							$full_url .= dirname($url_parts['path']);
							if(substr($full_url, -1) != '/'){
								#if the last character isn't a '/', add it

								$full_url .= '/';
							}
						}
						$full_url .= $href;
					}
					return $full_url;
				}
			}
		}
		return false;
	}
}

Though this was really a one time hit for me it may well be useful to others. Please let me know if you can think of ways to improve it and I will update accordingly.

Thanks, Kevin

Moving hosted SVN, the trials and the tribulations

Over the last few weeks Mike Robinson and I have discussed and decided an SVN restructuring for improving our build and deployment processes. I would encourage you to read a bit more about that (and various other geekness) at his blog.

So I’ve spent this week moving our company hosted SVN from Beanstalk to Springloops. I feel I’ve been swinging between hell and zen, but the learning has been awesome. As a summary of what I’ve found I thought I’d give a quick walk through how I did it.

Most of this stuff was the usual dump/load cycle, but there are a couple of things which needed some extra attention.

Firstly, both Beanstalk and Springloops have the ability to export and import SVN dumps via easy-to-use web interfaces. This really could be as easy as download, upload. Try that first.

We had a couple of problems though. Previously we had a mishmash of company repos and project repos; these had to be merged and sorted. We also had different usernames on each system(!) which meant that during an import previous commits were not matched to current system users.  The author attribute needed to be updated for all previous revisions.

This was all done on OS X, but should be applicable to any Unix-like with the appropriate libraries, etc.  So we’ve got our dump from Beanstalk, now we just need to create a local repository to do our work on (always work on a backup!!).

$ svnadmin create --pre-1.4-compatible newrepo

We use the pre 1.4 compatible flag to overcome files system changes within SVN between versions. These changes can potentially cause errors (svn: Expected FS format ’2’; found format ’3’) when propset-ting revision histories, in my case, author/committer names.

Next job, import your dump file.

$ svnadmin load newrepo < dumpfile

If you’re looking to do the merging, as I was, then you want to make yourself a directory in your repository (usual ‘svn mkdir’ commands) and then load it in the following fashion:

$ svnadmin load newrepo --parent-dir myfolder < seconddumpfile

Ok, we’ve done our merging, now we’re going to update our author histories.  Now the SVN manual gives you information on doing this one version at a time with a propset.  It also talks about other recursive actions such as deleting files, which isn’t our concern.  For changing authors, I found a tidy script called svn-author-tweak.py from CollabNet.

If you want to give your repository a check before you upload it, just checkout to a local test.

$ svn co file:///path/to/newrepo /path/to/test/repo

Once that’s done, dump the file.

$ svnadmin dump newrepo > my.dumpfile

Upload

???

Profit

Has it really been that long?

Hello all, it’s been a while. The Skinofstars site has been languishing in disuse for some time now. Like I’m sure many others, I’ve found the transition to micoblogging is all too easy. Sometimes though, one wants to write something a little longer and long gaps are not helpful when you finally think of something. So I guess I’m just posting to get rid of some writers block really.

For the six months since my last post (my, that is a long time!) I’ve been working at Studio Lift in Reading. There are five of us; two designers, two coders and a multi-talented boss. We fill our days making like this and like this (bad linking! :) using Movable Type. This is the same blogging platform that is used by the BBC, The Guardian, ReadWriteWeb and various others. It comes in both Commercial and Open Source offerings and is perhaps one of the most venerable of blogging systems.

Does that mean I’m going to talk tech now?… sure (jump?). Movable Type (mt) has just released its 5th version. This places more emphasis on managing multiple blogs within a site structure. Very useful if you’ve ever tried to manage multiple blog instances (how many blogs do you think The Guardian has?). There is also a new emphasis on social communication (see Motion).

The system is written in Perl but because the publishing is static files you can drop pretty much any scripting language in without any problems. My current language of choice for server-side is PHP. You hook your language in with mt using their own markup derived syntax, and to be honest for a simple blog you never have to touch another language. Let’s look at an example which will iterate over a collection of the last five entries:

<mt:Entries lastn=”5”> <h2><mt:EntryTitle /></h2> <p><mt:EntryBody /></p> </mt:Entries>

There is documentation, with my favourite page being the tag reference, but otherwise there certainly isn’t the same breadth of documentation as you would find with something like Wordpress. Perhaps the strong ties with the commercial side of the software, it was increasingly license prudish at the Open Source blogging party, has been a hindrance to a warm and fuzzy community embrace. Still, some big media hitters use it so they’ve certainly got something right.

Well, as I said, I work in Reading and my crappy car’s wiper motor has broken so I’ve got to get up early and catch a bus. It’s been nice to talk to you again. Thanks for putting up with my tech chatter, I expect that you’ll get variation soon enough as we head towards the General Election :)

Night Night.

http://www.williamfiennes.com/

A Website Apart

Hey all, just a quick one today. I just had a job interview and I was asked the question “which design websites do I frequent”? I ummed and erred a little before mentioning Digg and Slashdot. Not very design focused I know (except maybe Digg’s design section). I also said that I trawl the blogs for Ideas, which is true. I neglected to mention one of my favourite sites though, one which each and every one of you should have in your Feed Reader: A List Apart. I love that site and I felt a little ashamed for forgetting it, so as penance I am reminding you all to check it out.

Final Degree Results

Well if you’re not going to blog about your degree results, what are you going to blog about? Firstly, I want to say that I’m happy to do it in the three year time period. I know that is what is normally expected, but I know so many people that are having to take extra semesters or even years that I’m happy to have just got on with it so I’m able to move on to other things. Anyway, let’s cut to the chase;

I got a First Class Honours BSc in Multimedia Systems and Communication, Media and Culture.

Shocked I was. Smiling, but shocked. I knew that it was mathematically possible, but I was really just aiming to get a good 2:1. Perhaps that be seen as aiming low, but I didn’t come to university to flog myself every night for a grade. Yes I wanted to do well, but what I really wanted was to spend the time thinking and learning more generally. I wanted to learn many things and being at university, in a learning environment, I could spend time discovering so many other things. For example, I developed a somewhat nasty habit of wanting to learn Linux stuff. Not just the technical system management but also how open source as an idea can be used in so many aspects of life… Anyway, the point is that I wasn’t targeting a First, my target was to do everything well, just good and solid with treats thrown in here and there and still time to live a little.

I saw the grades themselves first before I knew the final result and I knew it was looking good. Nothing was below B+ and I had a nice collection of As. I was pleased to see my dissertation had got an A, I knew the coding was pretty good but I felt my sociological investigation of open source development had been a little weak. I’d also got 100% on my final web design module, which is unheard of (I suspect the tutor may have had some explaining to do there!) so I felt good for the 2:1. I checked my percentage and saw 68.7% (the boundaries are 40%=3rd, 50%=2:2, 60%=2:1 and 70%=1st). How tantalisingly close, within 2% of a First. I did as anyone would do and promptly posted what I believed to be my result to Twitter. Feeling pleased I decided to have a look around the results pages a little when I came across the line stating your degree result, “First Class Honours”. I could do little more than point and look at my girl Emily who’d also just got her results, a 2:1 in Linguistics.

Well as it turns out, if you score four or more B+ or above in your final semester (my final year was 5 As and 3 B+s) then they lower the bar for a First to 69%. I’m guessing this is to allow for improvement over the two years. And of course we can’t have decimals points in the percentage, they need to be rounded.. up in my case. I got a First within a margin of 0.7% (they round up all)! Twitter needed an update! With exclamation marks!!!

For one thing, the narrow margin certainly means I’m not complacent in the result. I know I could have done better and probably should have done. But it certainly makes the future look a little brighter. I don’t expect prospective employers to be pulling my arm off, but when looking at future Masters I know that I will now have a greater choice. The biggest bonus though is how proud my family are, my Mum said she had a little cry. Not too bad a result for someone who left school at 16. Guess I need to hire a gown now.