Level II apps

You can't plot your location easily on the low-res maps and sometimes it is nice to see your position relative to the storm in the <5 seconds it takes to click over to the app. If you're near a storm a spending time calculating that you have 186kts GtG shear, well you're probably missing the tornado.

I'm just trying to stir up the pot a little bit though because it surprises me that of all the data you could want high-res radar data is what you're after. I'd consider it the equivalent of Henry Ford's "faster horses"
 
I've already made requests for actual usable data in RS but that's been "coming soon" for ages ;) I figure if there's someone out there ready to make an L2 app (PS there is :) ) then they'd also have the good stuff too.
 
Interesting. Who is working on this app or is it too early to provide details? I wish them much success.
 
While my app is not the one Rob was referring to I did release version 3.4 of "wX" ( Android only via post in this forum ) last Fall with level 2 support for ref/vel at lowest tilt. The entire L2 data file is downloaded to the device and performance is better then I expected but numerous performance tweaks are being done. I'll post some details in the next few days along with some examples. To answer one of the questions above the number of radials is 720 vs 360 for L3 base ref and the # of bins of over 1800 vs I think 460 - basically 8 times the # of total bins.

Josh
 
While my app is not the one Rob was referring to I did release version 3.4 of "wX" ( Android only via post in this forum ) last Fall with level 2 support for ref/vel at lowest tilt. The entire L2 data file is downloaded to the device and performance is better then I expected but numerous performance tweaks are being done. I'll post some details in the next few days along with some examples. To answer one of the questions above the number of radials is 720 vs 360 for L3 base ref and the # of bins of over 1800 vs I think 460 - basically 8 times the # of total bins.

Josh


First, as far as I know the only place to actually obtain level 2 data ( as a member of the general public ) is from the Iowa Mesonet website. NWS does not appear to provide such data to the general public. If someone knows otherwise please let me know as it would be nice to have a backup in place.

With regards to performance the first item is not one you would normally expect but it makes a tangible difference. The files are stored in directories that have many files so to actually get the directory listing takes multiple seconds. Instead use the marker file in each directory and parse out the last entry. Additionally check the size of the file to make sure it’s not a transfer in progress.

The Android specific ( which could be used in general on other platforms ) optimizations are as follows. The dataset for level 2 is enormous and before I used the optimizations below it would take 1-3 minutes to render. Now it’s anywhere from 3-10 seconds. One item in particular that I didn’t think would improve performance that much ended up cutting the total render time in half. ( I don’t recall which one it was )


- Use OpenGL instead of the native canvas
- Use C code via JNI as much as possible even for color map translations
- Use preallocated ByteBuffers in Java but then populate in JNI C ( bytebuffers directly allocated avoids Java garbage collection and variable creation which is expensive in Java )
- Use OpenGL functions that then use these ByteBuffers.
- Reuse the same data structures throughout the life of the radar activity ( effectively some very large chunks of memory are being allocated outside the scope of Java )
- For bin level and color use 8 bit data values as much as possible to reduce memory consumption. I can’t recall the exact amount but even with 8 bit you could use as much as 40-50MB of memory to store the entire scene. Java doesn’t support unsigned data type so some additional considerations are needed
- For the L2 data blob itself it’s comprised of a number of chunks which are compressed. Via trial and error I found the reflectivity/velocity lowest tilt are pretty much at the beginning so you can download the entire blob but only decompress ( they are bzip2 compressed ) the first 8-10 chunks ( or something like that ). This gives a substantial performance increase.
Implement the decompression directly in C via JNI

The attached images show N0Q vs L2 reflectivity from the perspective of my app ,one zoomed in very close and the other an example of a well known storm from the past week. While L2 is not the default to display it’s nice to have it as an option. FYI - this resolution is quite small for this cell phone as the device was introduced in late 2011.

Screenshot_2015-03-25-19-40-55.png Screenshot_2015-03-25-19-45-16.png Screenshot_2015-03-28-06-14-37.png Screenshot_2015-03-28-06-14-51.png
 
I assume that folks are aware that AllisonHouse is a provider of level II data?? Not free (like Iowa) but much more robust and stable as opposed to Iowa. Iowa has on days in anticipation of major events,stated that their web site WILL go down due to the number of users.
 
I use a Windows phone. It's a smaller market share and so is often overlooked by app makers in this iAndroid dominated world. Such is the case when it comes to radar apps - zero, zip, nada. No level 2 or 3; just general apps from the usual suspects like TWC (et al) and a few local news stations' public radar feeds, slow and old and very coarse data.

Question: Have any of you tried running the GR programs on your home computer and accessing them through your phone using a virtual desktop app or somesuch?
 
Back
Top