The HTC One M9 Review: Part 2
by Joshua Ho on April 6, 2015 10:00 AM EST- Posted in
- Smartphones
- HTC
- Qualcomm
- Mobile
- Snapdragon 810
- One M9
Camera Architecture
The One M9’s camera is probably one of the biggest departures for HTC in the past few years. Starting with the One M7, HTC took a rather bold path by avoiding the megapixel wars that were dominating the smartphone industry on the camera. Instead, they went back up the ladder to a 2 micron pixel size which gave us a four megapixel camera. From a design standpoint, this represents a bold trade-off as consumers have traditionally focused upon megapixel count as the primary indicator of camera quality. However, to really understand why HTC chose to use a larger pixel size we have to understand what the trade-off meant.
In short, a CMOS image sensor is fundamentally constrained by a sensor size for a given form factor. The size of each pixel establishes an upper bound on critical characteristics like the sensitivity of the pixel (how likely the pixel will count a photon) and the full well capacity of each pixel (how many photons a pixel can hold before saturating). Therefore, for the same sensor size, increasing resolution comes at a cost. This cost is a reduction in dynamic range, and a reduction in sensitivity on a per-pixel basis. Given that most people were unlikely to even view a photo at the full 4MP resolution of the HTC One’s camera, this seemed like a pretty reasonable trade-off. The problem with all of this was that the One M7’s camera sensor didn’t seem to be as technologically advanced as its rivals. As a result, the dynamic range of the sensor wasn’t quite as high as one would hope. The other problem was that the Bayer layout of the sensor reduced the realistic resolution of the photo from 4MP to 2MP. HTC’s design choice wasn’t necessarily wrong, as Apple followed HTC by moving to a 1.5 micron pixel size for the iPhone 5s. However, with 8MP the resolution issue wasn’t there and with a custom Sony sensor it seemed that they managed to avoid the problems that HTC had.
With the One M9, HTC seems to have left the Ultrapixel concept behind, as the rear camera has a Toshiba T4KA7 sensor with 1.12 micron pixels. With a 1/2.4” sensor format, this gives us 20.1 megapixels, or around five times as many pixels as the Ultrapixel sensor that we saw in the One M8 and One M7. It would be easy to assume that HTC made this decision simply because they caved to marketing pressure, but this really doesn’t present a realistic picture of HTC’s situation. Fundamentally, it’s clear that HTC is not in a position where they can get a custom camera sensor of extremely high quality like Apple. The other issue is that it’s patently clear that good post-processing, oversampling techniques, OIS, and other techniques can significantly reduce the impact of a small pixel size. This can be seen in phones like the Galaxy Note 4, LG G3, and Lumia 930 as they all manage to deliver competitive low light image quality when compared against something like the iPhone 6. A larger sensor can also significantly offset all of the issues that come with a smaller pixel size. For reference, by simply increasing sensor size from the One M8 to One M9 we get a 40% increase in sensitivity when ignoring other factors.
With this in mind, we’re led to the context of the One M9’s camera system, which represents HTC’s return to a more traditional camera system. The basic specs of the camera system can be seen in the table below.
HTC One Cameras | ||||
HTC One M8 | HTC One M9 | |||
Front Camera | 5.0MP | 4.0MP | ||
Front Camera - Sensor | Samsung S5K5E2 (1.12µm, 1/5") |
OmniVision OV4688 (2.0 µm, 1/3") |
||
Front Camera - Focal Length | 1.83mm | 3.82mm | ||
Front Camera - Max Aperture | F/2.0 | F/2.0 | ||
Rear Camera | 4.0MP | 20.1MP | ||
Rear Camera - Sensor | OmniVision OV4688 (2.0 µm, 1/3") |
Toshiba T4KA7 (1.12 µm, 1/2.4") |
||
Rear Camera - Focal Length | 3.82mm (28mm eff) | 4.73mm (27.8mm eff) | ||
Rear Camera - Max Aperture | F/2.0 | F/2.2 | ||
Secondary Rear Camera - Sensor | OV2722 (1.4µm, 1/5.8") |
- |
As we can see, it seems that the optics stack has changed dramatically for this generation. The focal length of the camera is 27.8mm effective when multiplied by the crop factor. I’m sure that there are many that would claim to prefer a wider field of view for their camera, for an all-purpose camera I suspect the focal length should be closer to 30mm if possible. The aperture has also regressed somewhat from f/2.0 to f/2.2, which is likely necessary to reduce aberration, as the 4MP resolution of the One M7 and One M8 which hid optical aberrations to some extent with their lower resolution. The sensor choice is a bit surprising though, as the T4KA7 lacks some key features like PDAF which would allow for significantly faster autofocus. For a future device, it would definitely be preferable to see a longer focal length and wider aperture. It's also a bit disappointing that HTC didn't integrate OIS for this generation, as it's really a bit of a necessity for low light performance at this point.
Camera UX
At the end of the day, the quality of images and video that a camera can put out is often the most important aspect of the camera. However, there’s a lot that needs to happen before that can happen. The camera UI itself needs to be fast, fluid, intuitive, and powerful. A poorly designed UI can be a huge friction point, and it’s pretty much the easiest way to get me to hate using a phone. One of the classic mistakes here is using a 16:9 preview for a 4:3 image, which can seem to be a trivial problem but trying to frame something like an ISO chart properly rapidly shows the problems with this issue. The other aspects that can be easy to ignore include focus speed and capture speed, both of which are critical to capture a shot quickly.
If nothing else, HTC packages a custom camera application that is probably the best that I’ve used on any Android device. For those that are unfamiliar with HTC’s camera application, the Sense camera application keeps some critical camera controls in the right place. Flash, still images, video, and the gallery are all present with one touch, and the additional settings are split into either different cameras or additional settings.
The additional settings drawer holds additional scene settings, auto ISO max settings, exposure compensation settings, and white balance settings.
Within this drawer, there’s another settings drawer that allows for deep customization of the camera settings. It’s possible to switch between widescreen and regular crops of the camera sensor, in addition resolution adjustments. HTC also includes some settings to adjust post-processing when it comes to contrast, saturation, and artificial sharpening.
HTC also includes a full-manual camera mode, which allows adjustment of the exposure compensation, exact white balance temperature, manual ISO settings, shutter speed from 1/8000 seconds to 2 seconds, and manual focus control. All of these are controlled using sliders which can get somewhat messy, but it’s still well above anything other Android OEMs include with their standard camera applications. HTC has also fixed issues that came with this feature in the One M8, so there’s no longer a live preview for extremely long exposure times as a frame every 2-4 seconds is pretty much unusable.
Unfortunately, the rest of the experience isn’t as good as what we saw with the One M8. For one reason or another, the camera preview has a relatively low frame rate and resolution. The poor frame rate isn’t a function of shutter speed, as this is noticeable even in daytime when shutter speeds are well above 1/60 seconds for a 60 FPS refresh rate. The resolution of the preview is also a bit concerning as well, as it can be a bit hard to tell whether the camera is properly focused or not. I’m not sure what’s behind this change, as the ISP on the Snapdragon 810 should be more than capable enough to handle a 20MP camera if it’s designed to support a 55MP camera.
The final aspect of the camera experience is focus speed and capture latency, which are crucial to ensure that it’s possible to capture a fleeting moment before it’s lost. It’s pretty safe to say that it’s quite frustrating to try and take a quick photo and end up waiting on the phone to acquire focus, then wait even more for the phone to take the photo and save it. In order to properly test this, we use our standard ISO chart with strong lighting to ensure base ISO and a fast shutter speed, which should represent the ideal case for focusing and capture latency.
As one can see, the One M9 has a pretty stunning regression in autofocus speed and overall capture latency when compared to the One M8. However, it’s possible to understand this when in the context of the changes to the camera subsystem. There are two possible changes that could affect autofocus speed, which are the deletion of the Duocam and ImageChip 2 system. It’s hard to say the impact that each has had, but given that the One M8 had fast autofocus whether or not the second camera was covered it seems likely that the loss of the ImageChip 2 ISP is the bigger issue here. The change to capture latency isn’t nearly as significant, and seems to be somewhat reasonable given that the camera bandwidth requirements quadrupled from the One M8 to the One M9. The real issue here is the focus latency, which needs serious improvement. A sensor with phase-detection auto-focus will probably help a great deal here, in addition to improvements in the contrast auto-focus mechanism.
127 Comments
View All Comments
blanarahul - Tuesday, April 7, 2015 - link
This will be a big problem going forward. Look at Mali T760MP6 on Exynos 5433. Going from 600 MHz to 700 MHz requires a tremendous amount of power. The GHz race could only work till 28 NM it seems. The only solution to improve performance/watt is to go wider.TylerGrunter - Tuesday, April 7, 2015 - link
I can't completely agree with your statement. The issue is that to go to 20nm they should have used FinFet to reduce the current leakage at high frequencies. They didn't (neither GF, Samsung or TSMC) and that has been the consequence: 20nm doesn't scale well at high frequencies.Intel has managed to clock cores till 3.5 GHz already in 14nm FinFet, so with FinFet there shouldn't have the same issue.
By the way: I suspect NVidia had the same issue with the Denver cores and therefore they decided to go with A57 at 20nm.
But I agree that in most of the cases they should go wider (or increase IPC in some other way) in mobile. Even the A57 has only 3 paths.
Frenetic Pony - Tuesday, April 7, 2015 - link
Sure, but apparently finfet is harder for everyone that's not Intel. But Samsung, GloFo, and TSMC all now have Finfet up and running. At 3 years behind Intel for a similar enough feature density, and considering how hard Intel found shrinking their feature size once again, one wonders how long it will take these other 3 to get to a new process node after this. > 2 years is my guess.Alternate materials with less voltage leak and higher electron mobility are really, really needed and I don't understand why more isn't invested into them, other than uninformed executives making the decisions for future investment rather than engineers. 10nm (as in 2 actual feature size shrinks from 22/20nm) is doable with optical tools. But beyond that there are multiple new tools and techniques that need to fight vastly increasing complications and quality needed. The end of Moore's law is indeed within sight.
frenchy_2001 - Tuesday, April 7, 2015 - link
10nm is actually really hard.Either you do quad patterning (write 4 times slightly offset), which is less than trivial (you cannot make each step too wide and you will chip at it to prepare before the next) or you jump to extreme UV, and no one is there yet.
Intel has been spending a lot of time and money in solving those problems for years and they are STILL not solved...
KiretoX - Monday, April 6, 2015 - link
Page 2 table, M9 read camera... OV4688... not Toshiba?Andrei Frumusanu - Monday, April 6, 2015 - link
Fixed the table, thank you.Darkito - Monday, April 6, 2015 - link
RIP HTCnathanddrews - Monday, April 6, 2015 - link
Rip in peace, HTC.blanarahul - Tuesday, April 7, 2015 - link
Dafuq?!Armourcore9brker - Monday, April 6, 2015 - link
You should try setting the camera the way that was done in this XDA thread: http://forum.xda-developers.com/showpost.php?p=598...It seems like setting the ISO too high is causing a lot of the problems.