Source code for satpy.composites.abi

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Copyright (c) 2015-2017 Satpy developers
#
# This file is part of satpy.
#
# satpy is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# satpy is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# satpy.  If not, see <http://www.gnu.org/licenses/>.
"""Composite classes for the ABI instrument."""

import logging

from satpy.composites import GenericCompositor

LOG = logging.getLogger(__name__)


[docs] class SimulatedGreen(GenericCompositor): """A single-band dataset resembling a Green (0.55 µm) band. This compositor creates a single band product by combining three other bands in various amounts. The general formula with dependencies (d) and fractions (f) is:: result = d1 * f1 + d2 * f2 + d3 * f3 See the `fractions` keyword argument for more information. Common used fractions for ABI data with C01, C02, and C03 inputs include: - SatPy default (historical): (0.465, 0.465, 0.07) - `CIMSS (Kaba) <https://agupubs.onlinelibrary.wiley.com/doi/10.1029/2018EA000379>`_: (0.45, 0.45, 0.10) - `EDC <http://edc.occ-data.org/goes16/python/>`_: (0.45706946, 0.48358168, 0.06038137) """ def __init__(self, name, fractions=(0.465, 0.465, 0.07), **kwargs): # noqa: D417 """Initialize fractions for input channels. Args: name (str): Name of this composite fractions (iterable): Fractions of each input band to include in the result. """ self.fractions = fractions super(SimulatedGreen, self).__init__(name, **kwargs) def __call__(self, projectables, optional_datasets=None, **attrs): """Generate the single band composite.""" c01, c02, c03 = self.match_data_arrays(projectables) res = c01 * self.fractions[0] + c02 * self.fractions[1] + c03 * self.fractions[2] res.attrs = c03.attrs.copy() return super(SimulatedGreen, self).__call__((res,), **attrs)