2 year hiatus update

So in honor of the passage of 2 years since my last post, I thought I’d add a quick update on some changes:
Sydney Davis, 12-09-10

  • I’m now a proud father of a baby girl, Sydney, who was born on Oct 12 of this year
  • I have 2 new nephews and a niece (in order by birth: Aiden, Alex, and Babe), in addition to Davis
  • I’ve returned to school at the University of Tulsa to pursue my PhD in Computer Science
  • As part of my doctoral studies I’m doing research in Bioinformatics and Computational Biology with Dr. Brett McKinney in the Insilico Research Group

Adrienne and I are enjoying watching Sydney grow up, and have taken a ridiculous number of pics and videos.

I’ve updated the About page previously with some of the info, but figured I’d throw up a post as well — how many people regularly check About pages anyway?

I’ll try and maintain regular updates going forward… next post, Dec. 16 2012 ;-)

World Community Grid

As an update to my previous Cloud Computing post, I came across an interesting grid/distributed computing project, the World Community Grid. The WCG’s aim is to create the world’s largest public computational grid, with the goal of seeking projects that benefit humanity. IBM is the primary corporate sponsor, and, according to the site, it “has donated the hardware, software, technical services and expertise to build the infrastructure for World Community Grid and provides free hosting, maintenance and support.” The agent software used for WCG is based on BOINC, an open source platform for grid and distributed computing projects.

The first project to run on WCG resources is Human Proteome Folding. This involves calculating the precise spatial configuration of proteins, and can be used to identify the ways in which defects in protein folding can cause certain diseases. There are currently 11 projects, including Cancer research, Clean Energy, and producing genetically-optimized strains of nutritious rice.

Personally, I hope to see the WCG expand its reach. It would be interesting to see a major hardware manufacturer (looking in your direction Dell, HP, Apple) include a WCG agent in the default OS image, similar to the agreements with Google, Firefox, et. al. with regards to bundled software. Imagine if even one large vendor enabled grid software on all new machines. Of course, the owner should be informed of the existence of this software, and its benefit explained. Most people probably would never know or care, as long as the agent ran on idle CPU time. Many would likely be impressed that _their_ computer could be used to one day cure a disease such as cancer, or solve an equally pernicious problem that plagues humanity.

Contact page update

By popular request (see the comments), I’ve added a form on the Contact page. So now you have a way other than GTalk to send me a message.

It appears the Contact page isn’t as discoverable as I’d like; I may work on better placement for it in a future layout update.

When the Cloud transforms into Universal Utility Computing

The Cloud is Born

One of the most popular themes in the last couple years on the web is the much-heralded “cloud computing”. Of course, the cloud metaphor is taken from the representation of the Internet in architecture diagrams as a big fluffy cloud to which other, more discrete networks and systems are interconnected. From the Wikipedia page, Cloud computing, defined, is:

a style of computing in which IT-related capabilities are provided “as a service”, allowing users to access technology-enabled services from the Internet (“in the cloud”) without knowledge of, expertise with, or control over the technology infrastructure that supports them.

Google popularized dynamic web-based applications that behaved much like desktop apps, and essentially ushered in the era of what we fondly (sometimes snidely) call “Web 2.0″. In the short span of 3 or 4 years (I’m counting since 2005, when the web community at large became aware of Ajax and similar technology), dynamic web applications have become the de facto UI for end-user interactive software offerings — if it makes sense to use the ubiquitous browser as the frontend, then why not? Instead of forcing users to install, configure, and learn yet another new desktop app, give them an interface with which they’re already comfortable and familiar. As an added benefit, the browser interface is supported on nearly every operating system and platform used today (proprietary plugins and extensions notwithstanding).

Since then, the “cloud” has been touted as the next generation of the web, and as a concept encompasses a few key areas:

  • storage – collect user settings/preferences, documents and media
  • computing cycles – harness the power of a thousand-node grid of servers for complex problems or CPU-intensive workloads
  • network transparency – mask low-level details such as IP addresses and other info as much as possible

Who’s Who and Challenges

Large vendors with existing market plays involving huge server farms and data centers are eagerly jumping on the bandwagon — like IBM, Google, Amazon, Sun, etc. Software vendors are touting their existing and upcoming apps as “cloud” initiatives. The previously mentioned firms, as well as Salesforce, Zimbra (now owned by Yahoo), Zoho, and a multitude of other startups are all rushing to lay claim to a piece of land in the Cloud Gold Rush. Even Microsoft, notoriously late to the web party, instead relying on its stalwart cash cows of Windows and Office, has made its own bid in the cloud wars with Mesh and announcements of a web version of Office.

Cloud computing promises to change much of how we as developers, designers, and architects currently design and build web applications. For one, concurrency is big issue that need to be addressed if the apps of the next decade are going to scale on this cloud infrastructure. Languages, platforms, and tools need to provide solutions for creating apps that scale efficiently on multiple cores, processors, and even systems. Architects will have to design solutions that are massively scalable and take advantage of the properties of the cloud. UI specialists and designers will work with browser-based frontends, as well as newer mobile phone interfaces and Internet-enabled devices (such as Nokia’s Maemo Internet tablet).

Beyond the Cloud

I envision a future beyond the current cloud computing craze, perhaps in 5 – 10 years, where computing is a utility service just like power and telephone service are today. Several companies, including Amazon and Sun, are already offering some utility-style services, and many distributed computing projects tackling specific problems run on volunteer end-user systems today, but I’m thinking of something much broader. Instead of vendor-specific mini-clouds or utility services, we should aim for what I’ll term universal utility computing (UUC), built on open protocols and standards.

Essentially, the idea is to ensure every node in the cloud is an active member. By “active”, I mean the resources of every device are available for use by others. Computing cycles can be used (when idle, or up to a certain configurable threshold percentage of total CPU), storage, etc. It’s similar in nature to a grid and distributed computing, but utilizing a general, Internet-wide approach.

So how would such a system work? For starters, a UUC protocol would be required, and agent software written for various operating systems. The protocol would specify the sequence of communication between nodes, allowing true peer-to-peer messaging. The agent would ideally sit in the kernel space, interacting with the built-in scheduler, hardware abstraction layer, and storage subsystem.

Once a device has been “UUC-enabled”, it could begin to participate in the utility cloud. Every system in the cloud would share its resources for utility computing. Applications would then have the ability to harness as much computing power as required. Nodes that didn’t participate in the utility cloud couldn’t take advantage of utility resources.

Imagine all mobile phones on Earth utilizing a small portion of their resources in protein folding computations, or all servers processing climate forecasting data, or molecular level interactions for medical applications. Internet-enabled gaming consoles, tablets, laptops, desktops, and a plethora of devices that may be idle 90% of the time can now be used for computation. Imagine if the machines available to the average botnet hacker could be used for helpful purposes instead of spam.

Naturally, there are several challenges that must be overcome. Security and privacy, as today, would have to be addressed, employing encryption and other techniques to ensure confidentiality and integrity. Outside of individual nodes, there must be built-in mechanisms for preventing DDOS-style attacks, as well as preventing malicious users from exhausting the available utility-dedicated resources on one or several devices. There must also be a system used to prioritize workloads sent to the cloud, and a way to adjust the priority of a task. Checks and balances could be automatic, ensuring that a particular workload doesn’t use more than pre-determined slice of the available resources for a system.

Universal utility computing could be the next phase of computing, one where the Internet is a true peer-to-peer system, and all nodes participate and share resources. Instead of having expensive data centers with custom hardware and software solutions, billions of devices with idle processors can be harnessed to help solve a variety of problems affecting the enterprise, health care, the scientific community, and others.

Boxee delivers a quality media center experience

So I recently received my alpha invite to Boxee, a new service that combines a slick media center app with social networking elements. The centerpiece is a multi-platform app (currently only Linux and Mac OS X are supported, with Windows support coming) based on XBMC that provides a rich user experience.

XBMC has been around for some time, and has its roots (and namesake) from running on modded first generation XBoxes. XBMC is essentially the swiss-army knife of media center software — check out the list of supported A/V codecs and formats to get an idea. As an added bonus, it is also open source, licensed under the GPL. Boxee takes this software, which has been ported to run on commodity hardware, and adds social elements and web video streaming capabilities, and their own blend of unique features.

The typical rich media options of photos, music, videos are all there, along with the ability to consume media from a variety of sources. These may be local (local hard drive, USB removable devices), network shares, Internet audio streams and video services such as Youtube and Hulu, etc. Ah, sweet sweet, web 2.0 goodness. Boxee also has you create an account (it *is* a service, after all, not merely an app) that is used to store profile data. You can add friends, a la any other socially aware service, and see an activity stream of recently streamed music, videos, etc. Privacy settings are, of course, provided to configure the level of sharing.

I have a Mac Mini in my living room and installed the latest version of Boxee. One nice feature when running on recent Macs is Boxee fully supports the Apple Remote. In fact, Boxee replaces Front Row as the default action when invoking the OSD in OS X. I checked out the web video streaming, audio, and DVD playback features. Some observations:

  • several crashes, but this is *alpha* software, so it’s understandable/forgivable
  • Boxee automatically grabs local audio files and retrieves album artwork, arranging music by artist or album visually
  • several of the links to show episodes on Hulu were no longer available for viewing
  • the visualization for audio playback was stunning, and left me wondering why Front Row doesn’t provide at least some simple animation
  • streaming web video playback was very stuttery (Hulu, in particular)
  • torrent support (you can download torrents from within Boxee) and a link to Public [i.e. legal, public domain media] Torrents
  • configuration options abound, from video resolution to remote control timing settings

Some may argue that these (and many more, no doubt) features have been available in Windows Media Center and other software for years, but for me personally the litmus test was a Mac (mini) driven media center experience. Boxee is the home media center app that Front Row should’ve been all along. I’ve been waiting for a quality home theater experience on the Mac, and while promising, CenterStage and other projects have (so far) failed to deliver. All the more reason Boxee’s arrival is met with open arms and much rejoicing, even if it is still alpha quality.