-
Notifications
You must be signed in to change notification settings - Fork 171
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Stats has incomplete output under certain circumstances #3870
Comments
Note: The program caminfo will also provide DN statistics but not the same exact ones as stats (in keyword reporting, not values). I have never understood why this is the case. When caminfo stats comes across an image that does not have valid pixels it reports something like this:
I honestly don't know what the flat/csv output might look like since I don't use it. I'm not loving the values reported for Mean, Min, Max, etc., but it's better than not reporting any information. Just as a comparison, this is what stats reports (pvl style) for an image with valid dns:
Sure would be nice to have all of the above reported from one program. Anyway, just something to consider if "N/A" is not appropriate. |
Labeling this as a bug because it causes issues when appending to a CSV. For the output when nothing is available, we can replace the really weird numbers with just none, n/a, null, or something else. |
Cool. I'm not sure what is appropriate for the empties, but does it make sense to avoid NULL since that means something in ISIS? I'm not sure because I think we use NULL for geometry output a point intersected has information. Whatever makes sense for DN data since that's what this program reports. |
ISIS version(s) affected: 3.10.2 and prior
Description
The program stats does not fill all available fields in an output flat or pvl file format if it can not calculate basic DN statistics (min, max, mean, etc.) for an image. This is typically because the input image is 100% special pixels.
This is a problem when multiple (say many, many thousands) of images are read in and output is saved either by way of batchlist or concatenating individual output csv files in particular. It is impossible to work with csv output as input to a database table when there are 20+ columns expected for each row but some rows only end up with half that.
Additionally, the header row in the output csv file is affected by this problem. When running in batch mode and appending to an existing output flatfile, if the first image stats works on has valid DNs, then there are 20+ column names. If the first image in the list has no valid DN's then there are only headings for the 10 or so things it does report.
How to reproduce
Data under /work/users/lweller/Isis3Tests/Stats/
There are two images to demonstrate the problem:
N1459928352_1.cal.cub has valid DNs
N1733673166_7.cal.cub contains only special pixel values
Run either individually selecting format=csv and pvl or run then in batch mode as in the examples below. The order of the images in the list is swapped between list1.lis and list2.lis so you can see the problem with the headers in the output flatfile. The order has no effect for the output pvl so there is only one run for that.
Possible Solution
If a statistical value can not be calculated for an image, there needs to be a place holder in output csv (especially) and pvl files. Maybe "N/A".
Additional context
Clearly there are problems if images are all NULL, etc. - that's what I need the statistics for. I processing many thousands of images and I need to find problems after every processing step and this is about the only way I can think of for so much data. Having this information in a database is essential for what I am doing. I'm not sure I can even work around this problem.
The text was updated successfully, but these errors were encountered: