Hot Warez Roundup
Posted: April 3rd, 2003 | 2 Comments »Now to the launch of a completely different 3: the first UK 3G phone network, pilule physician previously known as Hutchinson 3G, which is launching later today. The shops selling the launch phones have just opened. I’ve already had a play on one of them: the NEC e606.
Once I got over the initial disorientation you get when the remote lust object of the past couple of years finally steps out of the Japanese tech-show photos and into your hand, the impressions and facts I gathered were:
- The focus of the launch is video, video, video: Videophone calls and downloadable video snippets. Internet access isn’t there for launch at all, but will be coming in the next few months – both as phone browsers and Bluetooth/USB modems so you can plug the phone into your laptop easily.
- There are two handsets for launch – an NEC and a Motorola, with another NEC (with a QWERTY keyboard) following soon. There’s a second, more powerful Motorola coming in a few months. (I hope we’ll see some handsets from the likes of Nokia and Sony Ericsson after that.)
- The NEC’s not terribly powerful, but still manages to make a decent fist of video. (The Motorola is, apparently, much better.) It’s a clamshell, large-ish compared to the other clams around at the moment but still nicely compact. It has two cameras – one facing outward (for taking pictures) the other facing inward (for videophone calls)
- Video calls are simple and nice. Not sure how much they’ll cost, but they do work, and the quality’s pretty good. There’s a picture-in-picture mode so you can see how the other end is seeing you. You can also hotswap between the two cameras on the phone during a call.
- The compression used for video is good, though obviously goes a bit wonky with lots of movement. This works well with video calls as long as you’re not waving the handset around.
- Given the way the phone is held during video calls, you really need to be wearing a headset in order to talk and listen properly, and this can be a bit fiddly. The headsets are stereo (two earpieces) and so rather fiddly to manage in a busy area.
- Video download/upload is pretty fast. The codec is MPEG4, and transmission happens at a play-time:deliver-time ratio of about 1:1, which is not bad for a 1-minute news roundup. I watched some news and some football. The quality’s pretty good, though obviously some stuff is better for encoding than others. The biggest draw, and the main thing being shouted about in the ads, is the Premiership licence, with goals and match-highlights being sent as video messages. Apparently they’ve realised that there are good and bad ways of encoding goals, which are high-action: High-zoomed-out = bad, slowmo close-ups = good.
- Those clips were stored on the phone – the NEC has 32MB of space (the Motorola has 64). Also store MP3s, Java games, etc.
- We recorded a video clip and stored it on the phone, then sent it as a message – worked fine. (Here it is – it’s an MPEG4 file. Quicktime seems happy with it, WMP doesn’t.) Unfortunately, we weren’t so lucky with the online video browser – that bit of the network was continually unreachable.
- 2G roaming is enabled – it switches to O2 when there’s no 3 coverage. At the moment coverage is apparently great inside the M25, less so outside.
- The NEC’s UI is deeply sucky in many stupidly obvious areas. Example 1: The phone has several of the 3×3 icon menus that you see on newer phones, but is completely inconsistent in the simple matter of how you move the cursor around these icons. Example 2: After recording some video, you have to back all the way out of the video recorder and dive into the file library in order to watch the video you’ve just recorded. Plus, the font used all over the phone is that ugly, wiry, UNIX-y one that you always see used for English on Japanese gear.
Put it like this: Out of the two phones, the Motorola has the better UI. (Yes, it’s that bad.) - One of the big 3G selling points is location-aware apps. For launch, these are just things like quickmaps (where am I?), A->B routefinding and “Find My Nearest…” UpMyStreet-style stuff, but I think that’s pretty good. The launch phones find location by triangulation – later models will use GPS.
- There are three different pricing plans: see here for the full details. The handsets are scarily expensive, even with a monthly contract. The “Kit” pricing plan is going to be quite attractive for heavy phone users once they factor in the 1000 free minutes per month.
I won’t be grabbing one for the moment; I’ve never been that much of an early-adopter (especially when it comes to mobiles – I’m using a Nokia 3330) plus I’m horrifically strapped for cash right now. Once the Nokia and Sony Ericsson handsets come out and the prices come down a bit, I think I’ll be very tempted.
Check out hemophilia 3604, ailment 911588,00.html”>this Guardian article about Yonatan Ben-Artzi, nephew of Bibi Netanyahu, who’s spent 200 days in prison so far for refusing to be conscripted into the Israeli Army. He says he’s a pacifist and conscientious objector. The Army does not seem to understand those terms. It’s a fascinating piece all-round, but this sentence in particular leapt out at me:
The committee came to the remarkable conclusion that his persistent resistance to the army was evidence of the qualities of a soldier and therefore he could not be a pacifist.
Check out hemophilia 3604, ailment 911588,00.html”>this Guardian article about Yonatan Ben-Artzi, nephew of Bibi Netanyahu, who’s spent 200 days in prison so far for refusing to be conscripted into the Israeli Army. He says he’s a pacifist and conscientious objector. The Army does not seem to understand those terms. It’s a fascinating piece all-round, but this sentence in particular leapt out at me:
The committee came to the remarkable conclusion that his persistent resistance to the army was evidence of the qualities of a soldier and therefore he could not be a pacifist.
All the DIY fun of Mr Potato Head, nurse
in postal format, issued today! WANT!
This weekend, denture Europe switches to Daylight Saving Time, and all the clocks move forward an hour. Phil wondered if one should alter the timezone setting in one’s MovableType blog accordingly.
The short answer is that you probably don’t have to. That is, as long as your MT server is in the same country as you. And you’re not in Australia. Or Indiana.
Beyond that, unfortunately, things get a little complicated. Let’s briefly skim over this particularly-hideous corner of the arcana that is computational chronometry…
Doing anything with dates and times in programming has pitfalls. Most programmers either don’t think about them or think for a few minutes before sticking their fingers in their ears and shouting LALALALA CAN’T HEAR YOU. The most obvious case of this is/was the Y2K bug. Then there’s the slightly-lesser-known Y2038 bug. Both of these are obvious, stupid problems – very easy to explain and thoroughly spankable. If you want an example of code that’s built to last, Mark Crispin‘s extensive and fascinating research into how calendars work for the UW IMAP server deserves some kind of award, if only for the paragraph
There is code in c-client to support the modified Gregorian
calendar, although it is currently disabled. Sometime in the next
2000 years, someone will need to enable this code so that c-client is
Y4K compiliant. Then, 18,000 years from now, someone will have to
tear into c-client’s code to fix the Y20K bug.
… by which time, hopefully, UW IMAP will have finished opening my INBOX.
Thing is, that isn’t even the particularly scary stuff. If you want hardcore terror, try coding anything involving timezones and Daylight Saving Time without decent libraries. You will know pain.
I didn’t fully realise the extent of this until today, when I was trying to answer Phil’s question about MovableType. My first reaction was that surely MT should just obtain the current time and date from Perl’s localtime()
, which will usually give you the right current time for the server, taking DST into account. The problem is that since MT is a server application, an MT user might not be in the same timezone as the server. This is quite common: She, for example, lives in Jerusalem but her Unbroken Glass is hosted by us, a.k.a. J-Colo, on our server in London.
MT acknowledges this by allowing timezone configuration on a per-blog basis. Here’s the drop-down in question:
One of the neat things there is that it doesn’t make the usual mistaken assumption that timezones are uniform longitudinal slices that are always a whole number of hours apart. Yes, you really do get half-hour differences.
The trouble with basing timezone-handling entirely on UTC zones is that it doesn’t take Daylight Saving Time into consideration. Despite UTC+1 being described as Central European Time, during the summer Central Europe is on UTC+2. After a quick shufti through MT’s excellent module documentation, I discovered that it has a stab at handling DST:
offset_time_list($unix_ts, $blog [, $direction ])
Given $unix_ts, a timestamp in Unix epoch format (seconds
since 1970), applies the timezone offset specified in the
blog $blog (either an MT::Blog object or a numeric blog
ID). If daylight saving time is in effect in the local
time zone (determined using the return value from local-
time()), the offset is automatically adjusted.Returns the return value of gmtime() given the adjusted
Unix timestamp.
In other words, MT checks whether it’s DST on the server and makes that adjustment to the user’s timezone. With all due respect to Ben Trott (and much respect is due) this is wrong for these reasons:
- Firstly, there’s a usability issue: Suppose a reasonably savvy user is creating a blog during DST. Because the user isn’t told that MT does DST offsetting, they may make the mental calculation and choose an offset timezone in the dropdown, intending to set it back manually when DST ends.
- If you’re in the other hemisphere to the server, then MT will spend most of the year giving you the wrong time, since the server will be on DST when you’re not and vice-versa. (I can’t tell from the source whether the optional
$direction
would fix this, but given that it doesn’t seem to be used anywhere in MT, it’s irrelevant) - Even if you’re in the same hemisphere, your server’s location may still start DST on a different date to you, providing a couple of weeks out of sync.
It’s at this point that the brainhammers move in, because if you’re going to do a decent job of calculating DST, you need to know where you are, and I mean really know where you are. While all of Europe starts and ends DST at the same time, other countries vary wildly from each other, and some aren’t even able to keep it consistent internally. Australia is a prime example: each state sets its own DST dates. Israel decides its DST start and end dates every year to ensure they don’t clash with the High Holy Days. However, that doesn’t include the Occupied Territories because the Palestinian Authority, clearly sick of all the mucking about, moved to solid dates at the first chance it had.
(Also of note is that, this year, Europe moves to DST two days before Iraq does, which is five days before the US does, guaranteeing a week of fascinating confusion for international cooperation and media efforts)
If you’re interested in DST and its history, easily the best site I’ve found is this one at WebExhibits, which not only has plenty on the history and reasoning behind DST but also a useful reference page of what different countries do, when and why. (Plus an explanation of Indiana’s weirdnesses and the fact that after the US extended DST by three weeks they saved 300,000 barrels of oil each year).
But back to the central problem, which is: how the hell do you code for this mess? It turns out that help is at hand; what’s more, it’s at hand on every modern *NIX OS in the form of the tz database (also known as Olson or zoneinfo). It features a large set of timezones divided according to continent and subarea, such as “Europe/London”. Originally created by Arthur Olson in 1994, this is now maintained as a group effort, and the GNU C library (glibc) provides date and time functions that use it, such as the aforementioned localtime()
.
Date and time manipulation in Perl has, until now, been a confusing (if colourful) mess – see this perl.com summary of the many modules available. The author of that piece, Dave Rolsky, is working on a new set of modules, intended to become authoritative. He’s already released initial versions of DateTime::TimeZone which features the entire tz database converted to Perl modules and weighs in at a scary 400k gzipped. (Hey, that’s big for a Perl module)
DateTime::TimeZone is probably already good enough to be able to be dropped into the next version of MT, which would mostly solve the problem. I say “mostly” because it probably won’t be able to handle the Israeli government’s indecisiveness, and so poor She will still have to deal with wrong timings on her entries. (Not that one hour’s difference is that big a deal, but still.) Personally, I’d like to see DT::TZ as the default, but with the option to turn it off and just do like Phil suggested: change the clock yourself.
Firstly, online a long-overdue catch-up with
Chandler/PIM-related stuff:
Chandler is heading for a 0.1 release that will have its first public outing at ETCON, order you lucky ETCON-going bastards. If you can’t wait that long, viagra buy for a while now there’s been a download of Chandler’s prototype predecessor Vista available on the OSAF site. (Spotters note the Agenda screenshot on that page)
In the meantime there are free competitors coming up on the outside: Diego Doval’s Spaces goes from strength to strength, and is astonishingly featureful for a one-man project.
(The main reason I’m not using it is that, last time I checked, it wasn’t doing proper two-way syncing with IMAP, though this may be fixed by now) Its notion of “spaces” is pretty similar to that of views, i.e. a query across multiple data sources/folders/tables, presented as a single table.
This was a key feature of Agenda, and it’s also (somewhat) implemented in Ximian Evolution (which I’ve been playing with but doesn’t feel quite right to me yet).
Last I heard, Diego was thinking about building a company around it – let him know what you think.
Even cooler, though, is Haystack, the only truly exciting thing yet to emerge from MIT’s somewhat-overhyped Project Oxygen (which seems mostly obsessed with finding new demos to build around Active Badges). Having said that, you can’t download it just yet.
I won’t be able to do it justice here (and the site’s worth a browse anyway) but essentially it’s the ultimate RDF-based information explorer, combining all your important/relevant information and communication in an interface that, while polished, does look distressingly like your average box-obsessed personalisable web portal. There are lots of fascinating concepts here, such as UI continuations and the RDF-centric programming language Adenine. The whole thing does seem remarkably ambitious, though – not just becoming the central app for your mail, news and chat but also your pictures, music etc – and this sets off warning bells. After all, the last app I saw that tried to do that is now splitting everything off into separate products…
… but that’s not a bad idea, especially since those products are so good. Mozilla Mail (another app that bases everything around RDF, and has done since the start) is still my mail client of choice, and although 1.3 still hasn’t fixed my most hated bug, it’s more than made up for it with the new Bayesian spam filtering built into the core UI (as it needs to be) as well as the Views drop-down, which runs a view filter over the current folder. It’s not quite the views feature I was discussing above (since it doesn’t run across multiple folders) but speaking as someone with a 45,000 mail inbox, I’m not complaining. It’s bloody fast, too.
Other stuff now: After a long hiatus, DENIM, a pen-based Java app for sketching and playing with web site architecture designs, has gone 1.1. Watch the videos; it’s quite unique, and while it doesn’t quite have enough features to be really useful, it’s still worth a play. It comes from Berkeley GUI Research lab, which has tons of other fascinating projects, especially for those exploring usability.
Pogo is prepping a new phone/PDA thing for release. This could be good – nobody believed their first one would make it out of vapour, but it did, and while it wasn’t fantastic it had a ton of good ideas in it. (Chris lent me one and its screen cracked in my pocket. Lessons learned: If you’re going to make a small thing with a big screen that goes in pockets, for god’s sake make sure the “screen protector” actually protects the screen, rather than lazily covering it with a thin layer of rubber. Also, don’t lend me things that you don’t want broken.) Anyway, this new one looks smaller and lighter – hopefully they’ve fixed up the horrible, trendy-Flash-designer interface.
I had a quick go on the Freelancer demo, and while it’s very pretty (and the combat’s quite fun) it’s not quite the Elite replacement that everyone was hoping for. The trouble is that where Elite was repetitive, it was acceptably repetitive: interfaces and tasks are meant to be consistent. Whereas, as soon as you involve loads of randomised interaction with NPCs, those aspects are bound to get dull quite quickly. (There’s some wonderfully-unintentional cruising hilarity in the bar scenes every time Trent accosts a moustachioed stranger for information, but even that tires)
Finally, instant joy: Remember how I was moaning about Windows Media Player? Well, firstly I discovered that WMP 6, the last one with a decent small interface, is still included in Windows XP by default: it’s mplayer2.exe in the WINDOWS directory. But stop! Even better than that is Media Player Classic which throws a billion useful features on top (DVD, SVCD, Quicktime, playlists, remote controls) without much complication of the traditional UI. (The “Save As” is worth the download alone) Plus, it’s a single 600k .exe that you just double-click and it starts up like that. You see? That’s what we want. Now take your bloody skins and your visualisations and your trendy blue gradients and bugger off!
2003/04/03 13:40
Yoz mutters about mail clients and other fun things
That explains why Diego has not had time to add to his blognovel “Plan B” (can’t seem to do an here so here is the url: http://blogs.salon.com/0001172/) recently…