[Git][debian-gis-team/pyspectral][upstream] New upstream version 0.9.4+ds

Antonio Valentino gitlab at salsa.debian.org
Tue Dec 31 07:27:46 GMT 2019



Antonio Valentino pushed to branch upstream at Debian GIS Project / pyspectral


Commits:
5060472c by Antonio Valentino at 2019-12-31T07:14:57Z
New upstream version 0.9.4+ds
- - - - -


6 changed files:

- CHANGELOG.md
- doc/conf.py
- doc/index.rst
- doc/rayleigh_correction.rst
- pyspectral/near_infrared_reflectance.py
- pyspectral/radiance_tb_conversion.py


Changes:

=====================================
CHANGELOG.md
=====================================
@@ -1,3 +1,23 @@
+## Version v0.9.4 (2019/12/30)
+
+
+### Pull Requests Merged
+
+#### Bugs fixed
+
+* [PR 99](https://github.com/pytroll/pyspectral/pull/99) - Fix Read The Doc pages - does not build at the moment
+
+#### Features added
+
+* [PR 97](https://github.com/pytroll/pyspectral/pull/97) - Fix NIR computations to be more lenient towards dask arrays
+
+#### Documentation changes
+
+* [PR 99](https://github.com/pytroll/pyspectral/pull/99) - Fix Read The Doc pages - does not build at the moment
+
+In this release 3 pull requests were closed.
+
+
 ## Version v0.9.3 (2019/12/06)
 
 ### Issues Closed


=====================================
doc/conf.py
=====================================
@@ -17,17 +17,8 @@ from pkg_resources import get_distribution
 
 # PYTHONPATH = docs/source
 DOC_SOURCES_DIR = os.path.dirname(os.path.abspath(__file__))
-PROJECT_ROOT_DIR = os.path.dirname(DOC_SOURCES_DIR)
 sys.path.insert(0, DOC_SOURCES_DIR)
 
-# If runs on ReadTheDocs environment
-on_rtd = os.environ.get('READTHEDOCS', None) == 'True'
-
-# Hack for lacking git-lfs support ReadTheDocs
-if on_rtd:
-    # print('Fetching files with git_lfs')
-    from git_lfs import fetch
-    fetch(PROJECT_ROOT_DIR)
 
 # If extensions (or modules to document with autodoc) are in another directory,
 # add these directories to sys.path here. If the directory is relative to the
@@ -39,7 +30,7 @@ sys.path.insert(0, os.path.abspath('../pyspectral'))
 # |version| and |release|, also used in various other places throughout the
 # built documents.
 #
-release = get_distribution('satpy').version
+release = get_distribution('pyspectral').version
 # for example take major/minor
 version = '.'.join(release.split('.')[:2])
 


=====================================
doc/index.rst
=====================================
@@ -27,7 +27,7 @@ The source code can be found on the github_ page.
 With PySpectral and SatPy_ (or previously mpop_) it is possible to make RGB colour
 composites like the SEVIRI `day solar`_ or the `day microphysical`_ RGB
 composites according to the `MSG Interpretation Guide`_ (EUMETSAT_). Also with
-SatPy_ (and mpop_) integration it is possible to make atmosphere corrected true
+SatPy_ integration it is possible to make atmosphere corrected true
 color imagery.
 
 .. _`EUMETSAT`: http://www.eumetsat.int/


=====================================
doc/rayleigh_correction.rst
=====================================
@@ -35,7 +35,7 @@ in the figure below:
    :scale: 70%
    :align: center
 
-The method is descriped in detail in a scientific paper_.
+The method is descriped in detail in a `scientific paper`_.
 
 To apply the atmospheric correction for a given satellite sensor band, the
 procedure involves the following three steps:
@@ -113,6 +113,6 @@ if you want another setup, e.g.:
 
 .. _Satpy: http://www.github.com/pytroll/satpy
 .. _zenodo: https://doi.org/10.5281/zenodo.1288441
-.. _paper: https://doi.org/10.3390/rs10040560
+.. _`scientific paper`: https://doi.org/10.3390/rs10040560
 
 


=====================================
pyspectral/near_infrared_reflectance.py
=====================================
@@ -32,9 +32,9 @@ window channel (usually around 11-12 microns).
 import os
 import numpy as np
 try:
-    from dask.array import where, logical_or
+    from dask.array import where, logical_or, asanyarray, array
 except ImportError:
-    from numpy import where, logical_or
+    from numpy import where, logical_or, asanyarray, array
 
 from pyspectral.solar import (SolarIrradianceSpectrum,
                               TOTAL_IRRADIANCE_SPECTRUM_2000ASTM)
@@ -216,14 +216,14 @@ class Calculator(RadTbConverter):
             is_masked = False
 
         if np.isscalar(tb_near_ir):
-            tb_nir = np.array([tb_near_ir, ])
+            tb_nir = array([tb_near_ir, ])
         else:
-            tb_nir = np.asanyarray(tb_near_ir)
+            tb_nir = asanyarray(tb_near_ir)
 
         if np.isscalar(tb_thermal):
-            tb_therm = np.array([tb_thermal, ])
+            tb_therm = array([tb_thermal, ])
         else:
-            tb_therm = np.asanyarray(tb_thermal)
+            tb_therm = asanyarray(tb_thermal)
 
         if tb_therm.shape != tb_nir.shape:
             errmsg = 'Dimensions do not match! {0} and {1}'.format(
@@ -239,9 +239,9 @@ class Calculator(RadTbConverter):
         else:
             co2corr = True
             if np.isscalar(tb_ir_co2):
-                tbco2 = np.array([tb_ir_co2, ])
+                tbco2 = array([tb_ir_co2, ])
             else:
-                tbco2 = np.asanyarray(tb_ir_co2)
+                tbco2 = asanyarray(tb_ir_co2)
 
         if not self.rsr:
             raise NotImplementedError("Reflectance calculations without "
@@ -260,7 +260,7 @@ class Calculator(RadTbConverter):
             LOG.info('l_nir = %s', str(l_nir))
 
         sunzmask = (sun_zenith < 0.0) | (sun_zenith > 88.0)
-        sunz = where(sunzmask, 88.0, sun_zenith)
+        sunz = sun_zenith.clip(0, 88.0)
 
         mu0 = np.cos(np.deg2rad(sunz))
         # mu0 = np.where(np.less(mu0, 0.1), 0.1, mu0)
@@ -275,11 +275,11 @@ class Calculator(RadTbConverter):
         else:
             self._rad3x_correction = 1.0
 
-        nomin = l_nir - thermal_emiss_one * self._rad3x_correction
-        denom = self._solar_radiance - thermal_emiss_one * self._rad3x_correction
+        corrected_thermal_emiss_one = thermal_emiss_one * self._rad3x_correction
+        nomin = l_nir - corrected_thermal_emiss_one
+        denom = self._solar_radiance - corrected_thermal_emiss_one
         data = nomin / denom
-        mask = (self._solar_radiance - thermal_emiss_one *
-                self._rad3x_correction) < EPSILON
+        mask = denom < EPSILON
 
         logical_or(sunzmask, mask, out=mask)
         logical_or(mask, np.isnan(tb_nir), out=mask)
@@ -294,5 +294,5 @@ class Calculator(RadTbConverter):
         else:
             res = self._r3x
         if is_masked:
-            res = np.ma.masked_array(res, mask=np.isnan(res))
+            res = np.ma.masked_invalid(res)
         return res


=====================================
pyspectral/radiance_tb_conversion.py
=====================================
@@ -172,6 +172,11 @@ class RadTbConverter(object):
             raise NotImplementedError(
                 'Platform {0} not yet supported...'.format(self.platform_name))
 
+    @staticmethod
+    def _getitem(block, lut):
+        """Index the lut, numpy style."""
+        return lut[block]
+
     def tb2radiance(self, tb_, **kwargs):
         """Get the radiance from the brightness temperature (Tb) given the band name.
 
@@ -207,10 +212,15 @@ class RadTbConverter(object):
             start = int(lut['tb'][0] * self.tb_scale)
             retv = {}
             bounds = 0, lut['radiance'].shape[0] - 1
-            index = np.clip(ntb - start, bounds[0], bounds[1])
-            retv['radiance'] = lut['radiance'][index]
-            if retv['radiance'].ravel().shape[0] == 1:
-                retv['radiance'] = retv['radiance'][0]
+            index = (ntb - start).clip(bounds[0], bounds[1])
+            try:
+                retv['radiance'] = index.map_blocks(self._getitem, lut['radiance'], dtype=lut['radiance'].dtype)
+            except AttributeError:
+                retv['radiance'] = lut['radiance'][index]
+            try:
+                retv['radiance'] = retv['radiance'].item()
+            except (ValueError, AttributeError):
+                pass
             retv['unit'] = unit
             retv['scale'] = scale
             return retv



View it on GitLab: https://salsa.debian.org/debian-gis-team/pyspectral/commit/5060472cdb571105e42cbbe69549147ecf9711f3

-- 
View it on GitLab: https://salsa.debian.org/debian-gis-team/pyspectral/commit/5060472cdb571105e42cbbe69549147ecf9711f3
You're receiving this email because of your account on salsa.debian.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-grass-devel/attachments/20191231/6a2b2af3/attachment-0001.html>


More information about the Pkg-grass-devel mailing list