Friday, 16 March 2012


Now with added wireless

Unlike the jeenodes, arduinos don't usually come with an RFM12b wireless transmitter. But jeelabs sell a handy module.

The USB host port on the Mega ADK communicates using the SPI bus. So does the wireless module, but fortunately the bus can be shared. The three main bus signals (MOSI, MISO, SCK) can be connected to different clients, only the Slave Select (SS) needs to be separate. On top of that, the wireless module requires an interrupt line.

On the Mega board, I used pins 52, 51, 50  for SCK, SDI (MOSI) and SDO (MISO); pin 48 for SS (just because it was next to 50 and 52), and 19 for IRQ - plus of course 5V and GND.

I had to modify the jeelabs RF12 library a bit. The library expects to use either the default interrupt 0 (on pin 2), or a pin-change based interrupt on any other pin. On the Mega 2560 and ADK, four additional interrupt lines can be used. I didn't want to use IRQ 0 in case it is required for the USB host, so I used one of the additional interrupts - IRQ 4 on pin 19. To do that, I had to change the call to attach() and detach() to take an IRQ number other than 0. Pin 48 is on Port L.

Throughout RF12.cpp, I've renamed RFM_IRQ into RFM_IRQ_PIN, and then

#if defined(__AVR_ATmega2560__) || defined(__AVR_ATmega1280__)

#define RFM_IRQ 4
#define RFM_IRQ_PIN     19 // was 2
#define SS_DDR      DDRL
#define SS_PORT     PORTL
#define SS_BIT      1

#define SPI_SS      53    // PB0, pin 19
#define SPI_MOSI    51    // PB2, pin 21
#define SPI_MISO    50    // PB3, pin 22
#define SPI_SCK     52    // PB1, pin 20

 ...

#else
    if ((nodeid & NODE_ID) != 0)
        attachInterrupt(RFM_IRQ, rf12_interrupt, LOW);
    else
        detachInterrupt(RFM_IRQ);
#endif


This is successfully running the RF12demo and the pingPong demo. I still have to test how this works when both USB and wireless are active - once I can send commands from the tablet to a node connected via wireless, I've got the backbone working.



Thursday, 15 March 2012

Bridged !

Finally, the tablet and the (new) kitchen node are talking. I say new kitchen node, as I've had to switch to a Arduino Mega ADK. It's not connected through ADK (we've already established that the tablet doesn't support that), but through something called Microbridge. Microbridge is a client to Android's ADB debugging interface - it can do a subset of the things the normal ADB client can do, including tunnelling TCP streams.

It didn't all go smoothly, both the Microbridge library and the example sketches need modifications before they work. I'll describe the changes that need to be done, and will link a zip of the modified files.

  • wiring.h The cpp files include wiring.h. This has been superseded by Android.h
  • Mega ADK hardware description:  max3421e.h has a section of definitions protected by #ifdef ADK_REF_BOARD. The contents of this section is correct for the board, but is not compiled. I don't know what the correct symbol for the board is, I just got rid of the #ifdef and corresponding #endif.
  • The board initialization in max3421e.cpp is not working correctly, it should look like this (change in the last line, see also this post):
     SPI.begin();
     pinMode(PIN_MAX_INT, INPUT);
     pinMode(PIN_MAX_GPX, INPUT);
     pinMode(PIN_MAX_SS, OUTPUT);
     DDRJ |= _BV (PJ2);
     
  • The examples use serial -> print, it should be serial -> write. Otherwise you get just random numbers.
  • The WriteFile example doesn't work for me, as the location used for creating the file  (/sdcard/hello) is mounted write-only. Since this example doesn't read back the result, you won't see an error message.
  •  The LogCat demo appears to be working fine (with the print/write change). You may have to unplug/replug your connection to the tablet to make sure it's in debug mode.
  • The Shell example has two problems. First, it checks the status of the connection before writing, but does not allow for ADB_RECEIVING. So it will incorrectly complain about the shell not being open.
  • The other Shell problem is that it does not send a carriage-return symbol at the end of a transmission. So you can type 'ls' into the serial monitor, but that never gets executed.
I still have to try the proper TCP transmission, but things look good so far.

Update: I've put a tar file of the modified microbridge library here. There's still something wrong with the LogCat example: you need to re-plug USB to get the tablet into USB debug mode, but that somehow immediately get cancelled again. If you first run the shell example and then the logcat example, it works. 

Monday, 12 March 2012

Boiler Control

The laundry node won't just be a passive note-taker, it will also control the boiler.

Our boiler has a basic programmable timer built in, with a limited number of timing slots (which are cumbersome to change). That should be much easier with a tablet based gui, with schedules uploaded to the jeenode. The boiler provides contacts that are in series with the timer switch (by default bridged), meant for an external thermostat.  It's easy to just add a relay into the circuit, turn the built-in timer to 'always on', and have the node control the on-off times (just in case, I will add a manual switch parallel to the arduino-controlled relay, so that we can always fall back to the build-in control).

We can do more than just provide a better control of the schedules: optimized start up. Instead of pre-programming the startup time of the boiler in the morning, we can sense the external temperature over night, and then delay starting the heating to the last possible moment. The longer the house remains cool over night, the less heat we lose. There' a possible downside to this though: it could increase our consumption. After cold nights, we sometimes find it too cold for our taste in the kitchen - we've under-heated. With optimal startup, the kitchen should always be reasonably warm when we need it, but that might mean coming on earlier than we'd program it to.

Ideally, I'd want to control the temperature setting, but that would require a more invasive change to the boiler. It has a potentiometer for setting the heating circuit temperature. I'd have to either somehow connect a motor to turn the potentiometer, or replace the potentiometer with something like a switched resistor ladder. Varying the temperature throughout the day should improve the efficiency of the boiler, but that's something that may have to wait.

Update I've realized that I can find out something else: the flow through the heating circuit depends only on the state of the thermostats in the house. If most of them are closed, the pump will be able to pump less water. If very little water flows (only through the bathroom), I can consider turning off the heating (at least for a while).

Sunday, 11 March 2012

Virtual Gasmeter

I mentioned yesterday that I've ordered two water flow meters. Despite measuring water flow, their main use will be to help me attribute our gas consumption.

First, the water flow meters will be cut into both the heating circuit and the domestic hot water output. Pairs of temperature sensors will go onto the incoming and outgoing pipes of both circuits. By measuring flow and temperature difference, I can work out exactly how much power the boiler is actually putting out. At the same time, I will measure the overall gas consumption at the house gas meter (luckily mine has an impulse at the lowest gear).

Most of the time (during winter) the gas will be used to heat the house - with brief periods for hot water, and for cooking in the evening. I know when we're using gas for hot water, because the flow in the heating circuit stops, and starts in the hot water circuit. But what about cooking?

That took some thinking (I considered a camera above the hob, or sensors on the cooker controls), but then I realized that I can learn a model of the efficiency of the boiler, probably dependent on outside temperature, maybe also return flow temperature. That model can be calibrated with data from times when I know I am not cooking (i.e. most of the day). Knowing the power output at any time, I can compare the gas consumption predicted by the model with that measured at the meter point - any additional gas used will have gone into cooking.

That way I can use inexpensive water meters to create virtual gas meters. And know exactly how much of our gas consumption went onto heating, hot water, and cooking.

(Virtual sensors and data driven modelling is my research area).

Saturday, 10 March 2012

Shipping Charges

I want to move the project, so I've ordered more bits and pieces today.

First, since it doesn't look as if the tablet can be convinced to act in host mode, I need a USB host-capable kitchen node. There's a great new device out that could do this very well, and very cheaply - the Raspberry Pi has USB host, SPI, I2C and GPIO ports enough for what I need. But it looks as if even existing orders won't be fulfilled before April, current ones much later. I don't want to wait (though I might order one anyway). I can't use USB host shields (the SPI bus is needed for the wireless), so the only option is the Arduino Mega ADK. Overkill for what I need (with over 50 digital and 16 analog ports) expensive (certainly compared to a jeenode or a Pi, and even the tablet), and I still have to add an RMF21B wireless board; but it's a way forward. That's coming from the only UK shop I could find that actually has one in stock.

Then there's the wireless module, that comes from Jeelabs (as Seeed never did do the breakout board) in Holland.

I need some water flow sensors (also Seeed Studio) but the only place that has the 3/4 inch version that fits our heating circuit is a place in France.

And finally yet another (UK) place for some basic wires, resistors, LEDs, plugs etc.

I feel like I am paying more on postage than on parts...

Friday, 9 March 2012

How green is your paper?

Last Monday, I went to Focus on Imaging at the NEC. It's great to have one of Europe's largest photo industry shows right at my doorstep.

Lots of great new kit (Canon's new flagship 5dMIII, new Nikons (but no Nikon charity raffle this year), the beautiful Fuji X-Pro 1), good talks, beautiful models, even minor celebrities (James and Ola from Strictly). And what excited me most? Paper.

Yes, the wonderful range of inkjet photo paper from a number of manufacturers. There's so much beautiful paper out there, both matt and glossy. I own an Epson 2880 printer, and I love printing and framing my own pictures. There is something special about making the physical artefact, at least a tiny bit back to the film and darkroom days of photography (I used to have a B&W darkroom as a teenager).

The next day we went to Stirchley Market where we sold a decent number of my postcards. That started me thinking: could I print the postcards myself?

At the moment, we have the photos printed by CEWE in Germany, and mount them onto recycled card stock . Commercial photo printers still use a chemical process onto modern photo paper (plastic), and produce chemical waste. Printing myself, apart from being a rewarding process, could be a lot more environmentally friendly. It might also be less labour intensive, and hopefully not much more expensive?

So, I started to find out about the environmental background of different papers. I asked the guys at www.on-linepaper.co.uk, and Simon Redgrove was very helpful, suggesting I look at Innova. I did, and asked them and some other suppliers about their environmental policy. This is what I found out so far - and it looks surprisingly positive:

Hahnemühle have a clear environmental policy (though I'd like that to be a bit more explicit) and support ecological projects. I love Hahnemühle's Bamboo paper - as the name implies, it's made from Bamboo, so potentially a green source. But it's a matt paper, so not ideal for postcards, and quite expensive.

Innova have a very clear environmental policy. They confirmed by email that all their stock is FSC sourced, though because the coating they put on the paper, the paper itself does not carry the FSC logo.

Similarly, St. Cuthberts Mill (also makers of Somerset papers) have a very clear environmental statement, claiming their stock is from 'sustainable sources'.

To my surprise, Permajet also claim that all their raw material is FSC certified. There's nothing about that on their web site, but they've promised to send me a statement from their mill. Permajet's paper is more budget-friendly, so I am really hoping they can document that claim (also, I want to switch to their continuous ink system).

Rag (cotton) paper is an interesting case - cotton production often has a negative impact (water use, pesticides, GM crop), but the material used is the outer husks, which are a by-product of the cotton industry. For that reason, this very good review of photographic paper argues that cotton paper is the best choice as long as you don't have certified FSC stock.

I haven't had a reply yet from Fotospeed, and there are a few more manufacturers I might contact.

In terms of costs, it turns out that the whole enterprise is a lot more difficult. Ink cost is just about OK when using a CIS (about 17p per A5 print, compared to 68p with Epson inks...). The paper however can quickly cost 1£ or more for an A4 sheet (to fold to A5). It looks like the only way to do it is to print onto 4x6 inkjet paper (about 12p) and stick that onto the recycled card stock...

Sunday, 4 March 2012

Call that progress?

A friendly user from the tabletrepublic forum pointed out that I was using the wrong version of the google accessory API: the com.android.future.usb.accessory API is only used on pre-gingerbread versions of the OS. Anyone else should use android.hardware.usb instead.

With that fixed, the app can be loaded onto the tablet. The device correctly switches to accessory mode, and usbManager even logs that as an event in logcat. But as in my host mode attempts, mUsbManager.getAccessoryList() always returns an empty list. The intent I registered is never called either.

Still not there.

Watching logcat while the tablet is running is quite scary, btw: so many exceptions thrown and signals not caught...

Saturday, 3 March 2012

Time for plan C?

Plan B was to run the tablet in client mode, using the Android Accessory API. As it turns out, that API is also not supported by Ainol. There is a /dev/usb_accessory, which might imply that kernel support is present. But library support isn't, when I upload some test code, I get I get requires unavailable shared library com.android.future.usb.accessory. 


It also turns out that using one of the USB host shields with the Jeenode wouldn't be ideal. The reason is that the shields communicate with the host using SPI. There is a hardware SPI bus on the Jeenode, but it's already used by the radio module, and sharing is tricky. It's possible to implement SPI on some of the general purpose pins in software, but I'd rather not go that route.

So, time to rethink. What's plan C? Replace the tablet? My chances would be slightly better with an ARM based device, but it's difficult to know what APIs are implemented without testing. As it is, the Ainol Paladin is pretty awful for this purpose.


Thursday, 1 March 2012

USB blues

As it turns out, power is not the only problem I have with the tablet.

First, a bit about the tablet. It's an Ainol Novo Paladin - currently the cheapest tablet running ICS, with a capacitive screen, and not using a VIA CPU.  It's nice enough, and after upgrading it to 4.0.3 with an unofficial build, and getting rid of all the pre-installed Chinese apps, you're left with a responsive tablet with many of the basic apps working. This includes youtube, but not for example a working BBC iplayer.

It's Achilles Heel is the processor - unlike nearly all android systems out there, it's not an ARM  based processor, but a MIPS processor. While pure java apps work OK (and something I wrote for a phone in 2.2 worked immediately on the tablet, save a few scaling issues), any app that uses native compiled code won't work. And that excludes a lot of the apps on the Android market. That wouldn't be a problem, I thought, as I was going to write my own code, in java.

First I had to get a working adaptor cable. The tablet has a mini-B type OTG socket. 'Normal' USB connectors always have one type of connector for the host ('A' type, e.g. the flat one in full-sized plugs) and one for the client ('B' type, the square plug) - to make sure that it's not possible to create host-host or client-client connection. For USB OTG, the same socket on the device can be used as host or client, so the shape of the socket needs to accept plugs intended for either clients or hosts. To tell the device to switch (think of connecting two phones, one will need to become host), there must be something different in one of the two plugs. The difference is the 'X' or 'ID' pin (pin 4) - for clients, it is left floating; on the host side this pin is connected to ground. And, as I already found out, to tell the device that it is host, but allowed to charge of VBUS, that pin is connected to ground through a 124k resistor (but don't take my word on this, read the spec, and make sure your device actually implements this).

So you can't just make your own OTG cable by cutting off a connector from an old USB cable and soldering it onto another one, as the ID pin will be left unconnected. Instead, I bought a solderable Mini-USB plug (the only one I could find in the UK). But what you can't see in the photo is that the ID pin is trimmed off - instead of a solder pad, it only has a stub less than 1mm square! The nice people at hobbytronics confirmed that yes, all the plugs are like that.

But it is possible to solder a wire to it, with a bit of care (and two attempts in my case). The tablet reacts as expected - with the other end of the wire unconnected, it remains in client mode; with the wire touching ground, the tablet goes into host mode and powers the device (e.g. a keyboard works). Connected devices also show in /proc/bus/USB/devices.

That's where it stops. Unfortunately, it appears that Ainol did not bother to support Android's USB host  API. When I call UsbManager.getDeviceList(), the result is always empty. I am not the only one with this problem, apparently some tablets do, some don't, implement USB host.

What alternatives are there? FTDI, the makers of the serial/USB chip on my jeenodes, actually provide a nice Android library. Looks ideal, but it uses a native library, and that's only available for ARM. Compiling an FTDI driver into the kernel won't work for a similar reason - there is no source release for ICS that works for MIPS.

It now looks as if I need to change my hardware. Either sell the tablet and find one that does support the host mode API (and runs ARM), or turn the jeenode into a USB host instead. The USB host mini shield  seems the cheapest way to do that; the Arduino Mega ADK is a lot more expensive and would need an RFM12b module added. With the tablet running as client, I should be able to use the Android Accessory Protocol mode - running as client would also solve the power problem. That's assuming the AAP API is implemented, but I can (and will) test that.