Flux Capacitor fabricated at HP

Posted by jeff on May 5th, 2008

The latest buzz is that a fourth fundamental circuit element has been fabricated. Dubbed the Memristor, it's a two-terminal device that acts like a resistor with a time-varying magnetic flux derivative with a memory effect. When you charge it up, you change the flux. That's right, a flux capacitor, and some others agree. The actual function is a characteristic of how much charge your flux capacitor can handle.

So now the only questions is, how are you going to use your flux capacitor? The inventor of memristors suggests building large artificial neural networks. Any ideas for what we should call those?

Almost everyone stayed awake!

Posted by jeff on Apr 2nd, 2008

Testing the futuristic whiteboardThank you to everyone who attended the tech talk on Monday. We were really happy with the interest and the turnout. Some of my preparation was seriously last minute! Three small features were added to the whiteboard literally an hour and a half before the talk.

I have posted the slides with slight post-talk enhancements (they now contain download links to much of the demo material and source code).

Is this really work? Our tech talk at the University of Michigan

Posted by vikas on Mar 25th, 2008

Jeff will be giving a tech talk on March 31st at the University of Michigan. Here's a preview of one of the awesome technologies that he'll be showing:

Download
(Music: L'espoir fait vivre by Bézèd'h, Skyline: Sh0cked on flickr, Beach: tata_aka_T on flickr)

We're looking for a few brilliant and creative minds to interview with us for a summer internship position. If you're interested, come to the talk or email us@fluxcapacity.net.

Here's what's on the agenda:

  • Wiimote + Laptop + Projector + Semitransparent Glass = Whiteboard from the Future
  • When regular speed just doesn't get you in the mood anymore - Ultra-fast numerical operations in C# using dynamic MSIL (bytecode) generation
  • Getting other people's computers to work for you

Here is the info for the tech talk:
When: March 31st at 5:30 pm
Where: 1014 Dow, North Campus, U of M College of Engineering
Food: yes
RSVP: here please, although not required it will help us get enough food

Hope to see you there!

Silverlight gains a key feature

Posted by jeff on Nov 12th, 2007

Great news for Silverlight adopters:  It looks like Silverlight 1.1 will have a SaveFileDialog.

"The good news is that we are planning on adding a SaveFileDialog() before the final release of Silverlight 1.1.", from Scott Guthrie's blog.

We were crossing our fingers for this feature.  See our previous post (Silverlight's niche, and its missing piece) on the subject.

With this small addition, you can write a web application that opens,  edits, and saves a file, without necessitating server intervention.  This opens up the possibility of replacing a variety of utilities with web-based counterparts which can enjoy active development.

Here are a few such applications which could make the jump to the browser (actual names concealed to protect these innocent applications):

Packing it up and moving to the browser?

Can you think of others?  Could you trust a web application to help with these tasks?

How to create REST/POX web services with WCF

Posted by adamjh on Nov 6th, 2007

After a horribly unfulfilling day of hacking at .Net, Perl, and Ruby SOAP implementations... trying to get them to talk nicely to each other... I went to sleep last night with the realization that attempting to achieve interoperability through SOAP would be a never-ending war.

So, I woke up this morning with the desire to make some of our .Net web services RESTful.  One of the great things about Windows Communication Foundation (WCF), the subset of the .Net Framework that provides web service capabilities, is the ability to switch between SOAP/REST and POX/JSON configurations without changing most of your underlying code.

Unfortunately, with .Net 3.5 and Visual Studio 2008 still in beta (for at least a few more weeks anyway), I couldn't find any good documentation/tutorials/howtos on how to do this.  So, after a lot of trial and error, here are the steps to successfully create a RESTful web service with Plain Old XML endpoints, starting with the sample WCF Service Application template that ships with Visual Studio:

1. Create a new WCF Service Application

In Visual Studio, create a new Visual C# project using the "WCF Service Application" template.

2. Add a RESTful service endpoint

In your application's configuration file (Web.config or App.config), add the following endpointBehaviors section right above the existing serviceBehaviors section.  It should now look something like this:

    <behaviors>
      <
endpointBehaviors>
        <
behavior name="webBehavior">
          <
webHttp />
        </
behavior>
      </
endpointBehaviors>
      <
serviceBehaviors>

Now add the following "rest" endpoint to your existing service section so that it looks like:

      <service name="RESTService.Service1" behaviorConfiguration="RESTService.Service1Behavior">
        <!--
 Service Endpoints -->
        <
endpoint address="" binding="wsHttpBinding" contract="RESTService.IService1"/>
        <
endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange"/>
        <
endpoint address="rest" behaviorConfiguration="webBehavior" binding="webHttpBinding"
         bindingConfiguration="" contract="RESTService.IService1" />
      </
service>

3. Reference System.ServiceModel.Web 

Add a reference to the .Net System.ServiceModel.Web assembly.  You can do this by going to Project->Add Reference, and selecting "System.ServiceModel.Web" from the .NET tab.

At the top of your service interface file (i.e. IService1.cs), add:

using System.ServiceModel.Web;

4. Add a WebGet attribute

The default sample GetData() method in your service interface file should look like:

        [OperationContract]
        string GetData(int intParam);

We'll make this RESTful and accessible through HTTP GET by adding a WebGet attribute:

        [OperationContractWebGet]
        string GetData(int intParam);

Testing it out

At this point, you should be able to build and run your program, and access your new RESTful web service at the following URL:

http://localhost:[port]/Service1.svc/rest/GetData?intParam=1337 

You should get the following output:

<string xmlns="http://schemas.microsoft.com/2003/10/Serialization/">You entered: 1337</string>

Note: [port] will be chosen at random when you build and run your program from within Visual Studio.  When you run for the first time, you will see a notification with the port in the system tray.  You can also hover over the ASP.NET Development Server icon in the system tray at any time to find the port number.

Using HTTP POST and URI Templates

If you want to submit information to your service using HTTP POST or another HTTP method, simply replace the WebGet attribute with the WebInvoke attribute, whichdefaults to POST and has an optional Method parameter (for PUT, DELETE, and other less common methods).

If you want to use a different URI scheme, WCF makes it really easy to do so.  For example, try:

        [OperationContractWebGet(UriTemplate = "data/{intParam}")]
        string GetData(string intParam);

And now try accessing your service at:

http://localhost:[port]/Service1.svc/rest/data/5 

Notes: We had to change the intParam from type int to type string, because URI Templates expect string parameters.  Inside of the GetData() method, we could convert the parameter back to an int with a simple call to int.Parse(intParam).  It's also possible to clean up the "Service1.svc" and "rest" URI sections by changing the service host and endpoint addresses.

Hope this helps anyone out there trying to get started creating a simple REST/POX web service with WCF.  This should be significantly better documented in the near future as Visual Studio 2008 RTMs.  At that point, some of the snippets above may need to change slightly depending on any changes that have been made to the framework or the sample applications since Beta 2 -- if you notice any issues or find this useful, please post a comment!

Also, for a lot more background on web services in .Net, check out Steve Maine's blog.  I saw him speak earlier this year at MIX, and he and his team are doing some really great work at Microsoft in this area.

Next »