2019-12-06 14:13:10 +08:00
|
|
|
|
# Author: João Gustavo A. Amorim
|
|
|
|
|
# Author email: joaogustavoamorim@gmail.com
|
|
|
|
|
# Coding date: jan 2019
|
|
|
|
|
# python/black: True
|
|
|
|
|
|
|
|
|
|
# Imports
|
|
|
|
|
import numpy as np
|
|
|
|
|
|
2020-05-22 14:10:11 +08:00
|
|
|
|
|
2019-12-06 14:13:10 +08:00
|
|
|
|
# Class implemented to calculus the index
|
|
|
|
|
class IndexCalculation:
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
# Class Summary
|
|
|
|
|
This algorithm consists in calculating vegetation indices, these
|
|
|
|
|
indices can be used for precision agriculture for example (or remote
|
|
|
|
|
sensing). There are functions to define the data and to calculate the
|
|
|
|
|
implemented indices.
|
|
|
|
|
|
|
|
|
|
# Vegetation index
|
|
|
|
|
https://en.wikipedia.org/wiki/Vegetation_Index
|
|
|
|
|
A Vegetation Index (VI) is a spectral transformation of two or more bands
|
|
|
|
|
designed to enhance the contribution of vegetation properties and allow
|
|
|
|
|
reliable spatial and temporal inter-comparisons of terrestrial
|
|
|
|
|
photosynthetic activity and canopy structural variations
|
|
|
|
|
|
|
|
|
|
# Information about channels (Wavelength range for each)
|
|
|
|
|
* nir - near-infrared
|
|
|
|
|
https://www.malvernpanalytical.com/br/products/technology/near-infrared-spectroscopy
|
|
|
|
|
Wavelength Range 700 nm to 2500 nm
|
|
|
|
|
* Red Edge
|
|
|
|
|
https://en.wikipedia.org/wiki/Red_edge
|
|
|
|
|
Wavelength Range 680 nm to 730 nm
|
|
|
|
|
* red
|
|
|
|
|
https://en.wikipedia.org/wiki/Color
|
|
|
|
|
Wavelength Range 635 nm to 700 nm
|
|
|
|
|
* blue
|
|
|
|
|
https://en.wikipedia.org/wiki/Color
|
|
|
|
|
Wavelength Range 450 nm to 490 nm
|
|
|
|
|
* green
|
|
|
|
|
https://en.wikipedia.org/wiki/Color
|
|
|
|
|
Wavelength Range 520 nm to 560 nm
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Implemented index list
|
|
|
|
|
#"abbreviationOfIndexName" -- list of channels used
|
|
|
|
|
|
|
|
|
|
#"ARVI2" -- red, nir
|
|
|
|
|
#"CCCI" -- red, redEdge, nir
|
|
|
|
|
#"CVI" -- red, green, nir
|
|
|
|
|
#"GLI" -- red, green, blue
|
|
|
|
|
#"NDVI" -- red, nir
|
|
|
|
|
#"BNDVI" -- blue, nir
|
|
|
|
|
#"redEdgeNDVI" -- red, redEdge
|
|
|
|
|
#"GNDVI" -- green, nir
|
|
|
|
|
#"GBNDVI" -- green, blue, nir
|
|
|
|
|
#"GRNDVI" -- red, green, nir
|
|
|
|
|
#"RBNDVI" -- red, blue, nir
|
|
|
|
|
#"PNDVI" -- red, green, blue, nir
|
|
|
|
|
#"ATSAVI" -- red, nir
|
|
|
|
|
#"BWDRVI" -- blue, nir
|
|
|
|
|
#"CIgreen" -- green, nir
|
|
|
|
|
#"CIrededge" -- redEdge, nir
|
|
|
|
|
#"CI" -- red, blue
|
|
|
|
|
#"CTVI" -- red, nir
|
|
|
|
|
#"GDVI" -- green, nir
|
|
|
|
|
#"EVI" -- red, blue, nir
|
|
|
|
|
#"GEMI" -- red, nir
|
|
|
|
|
#"GOSAVI" -- green, nir
|
|
|
|
|
#"GSAVI" -- green, nir
|
|
|
|
|
#"Hue" -- red, green, blue
|
|
|
|
|
#"IVI" -- red, nir
|
|
|
|
|
#"IPVI" -- red, nir
|
|
|
|
|
#"I" -- red, green, blue
|
|
|
|
|
#"RVI" -- red, nir
|
|
|
|
|
#"MRVI" -- red, nir
|
|
|
|
|
#"MSAVI" -- red, nir
|
|
|
|
|
#"NormG" -- red, green, nir
|
|
|
|
|
#"NormNIR" -- red, green, nir
|
|
|
|
|
#"NormR" -- red, green, nir
|
|
|
|
|
#"NGRDI" -- red, green
|
|
|
|
|
#"RI" -- red, green
|
|
|
|
|
#"S" -- red, green, blue
|
|
|
|
|
#"IF" -- red, green, blue
|
|
|
|
|
#"DVI" -- red, nir
|
|
|
|
|
#"TVI" -- red, nir
|
|
|
|
|
#"NDRE" -- redEdge, nir
|
|
|
|
|
|
|
|
|
|
#list of all index implemented
|
|
|
|
|
#allIndex = ["ARVI2", "CCCI", "CVI", "GLI", "NDVI", "BNDVI", "redEdgeNDVI",
|
|
|
|
|
"GNDVI", "GBNDVI", "GRNDVI", "RBNDVI", "PNDVI", "ATSAVI",
|
|
|
|
|
"BWDRVI", "CIgreen", "CIrededge", "CI", "CTVI", "GDVI", "EVI",
|
|
|
|
|
"GEMI", "GOSAVI", "GSAVI", "Hue", "IVI", "IPVI", "I", "RVI",
|
|
|
|
|
"MRVI", "MSAVI", "NormG", "NormNIR", "NormR", "NGRDI", "RI",
|
|
|
|
|
"S", "IF", "DVI", "TVI", "NDRE"]
|
|
|
|
|
|
|
|
|
|
#list of index with not blue channel
|
|
|
|
|
#notBlueIndex = ["ARVI2", "CCCI", "CVI", "NDVI", "redEdgeNDVI", "GNDVI",
|
|
|
|
|
"GRNDVI", "ATSAVI", "CIgreen", "CIrededge", "CTVI", "GDVI",
|
|
|
|
|
"GEMI", "GOSAVI", "GSAVI", "IVI", "IPVI", "RVI", "MRVI",
|
|
|
|
|
"MSAVI", "NormG", "NormNIR", "NormR", "NGRDI", "RI", "DVI",
|
|
|
|
|
"TVI", "NDRE"]
|
|
|
|
|
|
|
|
|
|
#list of index just with RGB channels
|
|
|
|
|
#RGBIndex = ["GLI", "CI", "Hue", "I", "NGRDI", "RI", "S", "IF"]
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
def __init__(self, red=None, green=None, blue=None, redEdge=None, nir=None):
|
|
|
|
|
# print("Numpy version: " + np.__version__)
|
|
|
|
|
self.setMatrices(red=red, green=green, blue=blue, redEdge=redEdge, nir=nir)
|
|
|
|
|
|
|
|
|
|
def setMatrices(self, red=None, green=None, blue=None, redEdge=None, nir=None):
|
|
|
|
|
if red is not None:
|
|
|
|
|
self.red = red
|
|
|
|
|
if green is not None:
|
|
|
|
|
self.green = green
|
|
|
|
|
if blue is not None:
|
|
|
|
|
self.blue = blue
|
|
|
|
|
if redEdge is not None:
|
|
|
|
|
self.redEdge = redEdge
|
|
|
|
|
if nir is not None:
|
|
|
|
|
self.nir = nir
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
def calculation(
|
|
|
|
|
self, index="", red=None, green=None, blue=None, redEdge=None, nir=None
|
|
|
|
|
):
|
|
|
|
|
"""
|
2020-05-22 14:10:11 +08:00
|
|
|
|
performs the calculation of the index with the values instantiated in the class
|
|
|
|
|
:str index: abbreviation of index name to perform
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
self.setMatrices(red=red, green=green, blue=blue, redEdge=redEdge, nir=nir)
|
|
|
|
|
funcs = {
|
|
|
|
|
"ARVI2": self.ARVI2,
|
|
|
|
|
"CCCI": self.CCCI,
|
|
|
|
|
"CVI": self.CVI,
|
|
|
|
|
"GLI": self.GLI,
|
|
|
|
|
"NDVI": self.NDVI,
|
|
|
|
|
"BNDVI": self.BNDVI,
|
|
|
|
|
"redEdgeNDVI": self.redEdgeNDVI,
|
|
|
|
|
"GNDVI": self.GNDVI,
|
|
|
|
|
"GBNDVI": self.GBNDVI,
|
|
|
|
|
"GRNDVI": self.GRNDVI,
|
|
|
|
|
"RBNDVI": self.RBNDVI,
|
|
|
|
|
"PNDVI": self.PNDVI,
|
|
|
|
|
"ATSAVI": self.ATSAVI,
|
|
|
|
|
"BWDRVI": self.BWDRVI,
|
|
|
|
|
"CIgreen": self.CIgreen,
|
|
|
|
|
"CIrededge": self.CIrededge,
|
|
|
|
|
"CI": self.CI,
|
|
|
|
|
"CTVI": self.CTVI,
|
|
|
|
|
"GDVI": self.GDVI,
|
|
|
|
|
"EVI": self.EVI,
|
|
|
|
|
"GEMI": self.GEMI,
|
|
|
|
|
"GOSAVI": self.GOSAVI,
|
|
|
|
|
"GSAVI": self.GSAVI,
|
|
|
|
|
"Hue": self.Hue,
|
|
|
|
|
"IVI": self.IVI,
|
|
|
|
|
"IPVI": self.IPVI,
|
|
|
|
|
"I": self.I,
|
|
|
|
|
"RVI": self.RVI,
|
|
|
|
|
"MRVI": self.MRVI,
|
|
|
|
|
"MSAVI": self.MSAVI,
|
|
|
|
|
"NormG": self.NormG,
|
|
|
|
|
"NormNIR": self.NormNIR,
|
|
|
|
|
"NormR": self.NormR,
|
|
|
|
|
"NGRDI": self.NGRDI,
|
|
|
|
|
"RI": self.RI,
|
|
|
|
|
"S": self.S,
|
|
|
|
|
"IF": self.IF,
|
|
|
|
|
"DVI": self.DVI,
|
|
|
|
|
"TVI": self.TVI,
|
|
|
|
|
"NDRE": self.NDRE,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
return funcs[index]()
|
|
|
|
|
except KeyError:
|
|
|
|
|
print("Index not in the list!")
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
def ARVI2(self):
|
|
|
|
|
"""
|
2019-12-07 13:39:08 +08:00
|
|
|
|
Atmospherically Resistant Vegetation Index 2
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=396
|
|
|
|
|
:return: index
|
|
|
|
|
−0.18+1.17*(self.nir−self.red)/(self.nir+self.red)
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return -0.18 + (1.17 * ((self.nir - self.red) / (self.nir + self.red)))
|
|
|
|
|
|
|
|
|
|
def CCCI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Canopy Chlorophyll Content Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=224
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return ((self.nir - self.redEdge) / (self.nir + self.redEdge)) / (
|
|
|
|
|
(self.nir - self.red) / (self.nir + self.red)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def CVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Chlorophyll vegetation index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=391
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
2022-01-31 03:29:54 +08:00
|
|
|
|
return self.nir * (self.red / (self.green**2))
|
2019-12-06 14:13:10 +08:00
|
|
|
|
|
|
|
|
|
def GLI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.green leaf index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=375
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (2 * self.green - self.red - self.blue) / (
|
|
|
|
|
2 * self.green + self.red + self.blue
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def NDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.nir/self.red Normalized Difference Vegetation
|
|
|
|
|
Index, Calibrated NDVI - CDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=58
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - self.red) / (self.nir + self.red)
|
|
|
|
|
|
|
|
|
|
def BNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.nir/self.blue self.blue-normalized difference
|
|
|
|
|
vegetation index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=135
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - self.blue) / (self.nir + self.blue)
|
|
|
|
|
|
|
|
|
|
def redEdgeNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.rededge/self.red
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=235
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.redEdge - self.red) / (self.redEdge + self.red)
|
|
|
|
|
|
|
|
|
|
def GNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.nir/self.green self.green NDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=401
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - self.green) / (self.nir + self.green)
|
|
|
|
|
|
|
|
|
|
def GBNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.green-self.blue NDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=186
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - (self.green + self.blue)) / (
|
|
|
|
|
self.nir + (self.green + self.blue)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def GRNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.green-self.red NDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=185
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - (self.green + self.red)) / (
|
|
|
|
|
self.nir + (self.green + self.red)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def RBNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.red-self.blue NDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=187
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - (self.blue + self.red)) / (self.nir + (self.blue + self.red))
|
|
|
|
|
|
|
|
|
|
def PNDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Pan NDVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=188
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - (self.green + self.red + self.blue)) / (
|
|
|
|
|
self.nir + (self.green + self.red + self.blue)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def ATSAVI(self, X=0.08, a=1.22, b=0.03):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Adjusted transformed soil-adjusted VI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=209
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return a * (
|
|
|
|
|
(self.nir - a * self.red - b)
|
2022-01-31 03:29:54 +08:00
|
|
|
|
/ (a * self.nir + self.red - a * b + X * (1 + a**2))
|
2019-12-06 14:13:10 +08:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def BWDRVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.blue-wide dynamic range vegetation index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=136
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (0.1 * self.nir - self.blue) / (0.1 * self.nir + self.blue)
|
|
|
|
|
|
|
|
|
|
def CIgreen(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Chlorophyll Index self.green
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=128
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir / self.green) - 1
|
|
|
|
|
|
|
|
|
|
def CIrededge(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Chlorophyll Index self.redEdge
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=131
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir / self.redEdge) - 1
|
|
|
|
|
|
|
|
|
|
def CI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Coloration Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=11
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.red - self.blue) / self.red
|
|
|
|
|
|
|
|
|
|
def CTVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Corrected Transformed Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=244
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
ndvi = self.NDVI()
|
|
|
|
|
return ((ndvi + 0.5) / (abs(ndvi + 0.5))) * (abs(ndvi + 0.5) ** (1 / 2))
|
|
|
|
|
|
|
|
|
|
def GDVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Difference self.nir/self.green self.green Difference Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=27
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.nir - self.green
|
|
|
|
|
|
|
|
|
|
def EVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Enhanced Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=16
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return 2.5 * (
|
|
|
|
|
(self.nir - self.red) / (self.nir + 6 * self.red - 7.5 * self.blue + 1)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def GEMI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Global Environment Monitoring Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=25
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
2022-01-31 03:29:54 +08:00
|
|
|
|
n = (2 * (self.nir**2 - self.red**2) + 1.5 * self.nir + 0.5 * self.red) / (
|
2019-12-06 14:13:10 +08:00
|
|
|
|
self.nir + self.red + 0.5
|
|
|
|
|
)
|
|
|
|
|
return n * (1 - 0.25 * n) - (self.red - 0.125) / (1 - self.red)
|
|
|
|
|
|
|
|
|
|
def GOSAVI(self, Y=0.16):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.green Optimized Soil Adjusted Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=29
|
|
|
|
|
mit Y = 0,16
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - self.green) / (self.nir + self.green + Y)
|
|
|
|
|
|
|
|
|
|
def GSAVI(self, L=0.5):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
self.green Soil Adjusted Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=31
|
|
|
|
|
mit L = 0,5
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return ((self.nir - self.green) / (self.nir + self.green + L)) * (1 + L)
|
|
|
|
|
|
|
|
|
|
def Hue(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Hue
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=34
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return np.arctan(
|
2020-01-03 22:25:36 +08:00
|
|
|
|
((2 * self.red - self.green - self.blue) / 30.5) * (self.green - self.blue)
|
2019-12-06 14:13:10 +08:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def IVI(self, a=None, b=None):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Ideal vegetation index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=276
|
|
|
|
|
b=intercept of vegetation line
|
|
|
|
|
a=soil line slope
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir - b) / (a * self.red)
|
|
|
|
|
|
|
|
|
|
def IPVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Infraself.red percentage vegetation index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=35
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.nir / ((self.nir + self.red) / 2)) * (self.NDVI() + 1)
|
|
|
|
|
|
2020-05-22 14:10:11 +08:00
|
|
|
|
def I(self): # noqa: E741,E743
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Intensity
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=36
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.red + self.green + self.blue) / 30.5
|
|
|
|
|
|
|
|
|
|
def RVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Ratio-Vegetation-Index
|
|
|
|
|
http://www.seos-project.eu/modules/remotesensing/remotesensing-c03-s01-p01.html
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.nir / self.red
|
|
|
|
|
|
|
|
|
|
def MRVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Modified Normalized Difference Vegetation Index RVI
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=275
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.RVI() - 1) / (self.RVI() + 1)
|
|
|
|
|
|
|
|
|
|
def MSAVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Modified Soil Adjusted Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=44
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (
|
|
|
|
|
(2 * self.nir + 1)
|
|
|
|
|
- ((2 * self.nir + 1) ** 2 - 8 * (self.nir - self.red)) ** (1 / 2)
|
|
|
|
|
) / 2
|
|
|
|
|
|
|
|
|
|
def NormG(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Norm G
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=50
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.green / (self.nir + self.red + self.green)
|
|
|
|
|
|
|
|
|
|
def NormNIR(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Norm self.nir
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=51
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.nir / (self.nir + self.red + self.green)
|
|
|
|
|
|
|
|
|
|
def NormR(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Norm R
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=52
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.red / (self.nir + self.red + self.green)
|
|
|
|
|
|
|
|
|
|
def NGRDI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.green/self.red Normalized self.green self.red
|
|
|
|
|
difference index, Visible Atmospherically Resistant Indices self.green
|
|
|
|
|
(VIself.green)
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=390
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.green - self.red) / (self.green + self.red)
|
|
|
|
|
|
|
|
|
|
def RI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Normalized Difference self.red/self.green self.redness Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=74
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.red - self.green) / (self.red + self.green)
|
|
|
|
|
|
|
|
|
|
def S(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Saturation
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=77
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
max = np.max([np.max(self.red), np.max(self.green), np.max(self.blue)])
|
|
|
|
|
min = np.min([np.min(self.red), np.min(self.green), np.min(self.blue)])
|
|
|
|
|
return (max - min) / max
|
|
|
|
|
|
|
|
|
|
def IF(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Shape Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=79
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (2 * self.red - self.green - self.blue) / (self.green - self.blue)
|
|
|
|
|
|
|
|
|
|
def DVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Simple Ratio self.nir/self.red Difference Vegetation Index, Vegetation Index
|
|
|
|
|
Number (VIN)
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=12
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return self.nir / self.red
|
|
|
|
|
|
|
|
|
|
def TVI(self):
|
|
|
|
|
"""
|
2020-09-10 16:31:26 +08:00
|
|
|
|
Transformed Vegetation Index
|
|
|
|
|
https://www.indexdatabase.de/db/i-single.php?id=98
|
|
|
|
|
:return: index
|
2019-12-06 14:13:10 +08:00
|
|
|
|
"""
|
|
|
|
|
return (self.NDVI() + 0.5) ** (1 / 2)
|
|
|
|
|
|
|
|
|
|
def NDRE(self):
|
|
|
|
|
return (self.nir - self.redEdge) / (self.nir + self.redEdge)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
# genering a random matrices to test this class
|
|
|
|
|
red = np.ones((1000,1000, 1),dtype="float64") * 46787
|
|
|
|
|
green = np.ones((1000,1000, 1),dtype="float64") * 23487
|
|
|
|
|
blue = np.ones((1000,1000, 1),dtype="float64") * 14578
|
|
|
|
|
redEdge = np.ones((1000,1000, 1),dtype="float64") * 51045
|
|
|
|
|
nir = np.ones((1000,1000, 1),dtype="float64") * 52200
|
|
|
|
|
|
|
|
|
|
# Examples of how to use the class
|
|
|
|
|
|
2020-05-22 14:10:11 +08:00
|
|
|
|
# instantiating the class
|
2019-12-06 14:13:10 +08:00
|
|
|
|
cl = IndexCalculation()
|
|
|
|
|
|
|
|
|
|
# instantiating the class with the values
|
|
|
|
|
#cl = indexCalculation(red=red, green=green, blue=blue, redEdge=redEdge, nir=nir)
|
|
|
|
|
|
2020-01-18 20:24:33 +08:00
|
|
|
|
# how set the values after instantiate the class cl, (for update the data or when don't
|
2019-12-06 14:13:10 +08:00
|
|
|
|
# instantiating the class with the values)
|
|
|
|
|
cl.setMatrices(red=red, green=green, blue=blue, redEdge=redEdge, nir=nir)
|
|
|
|
|
|
|
|
|
|
# calculating the indices for the instantiated values in the class
|
|
|
|
|
# Note: the CCCI index can be changed to any index implemented in the class.
|
|
|
|
|
indexValue_form1 = cl.calculation("CCCI", red=red, green=green, blue=blue,
|
|
|
|
|
redEdge=redEdge, nir=nir).astype(np.float64)
|
|
|
|
|
indexValue_form2 = cl.CCCI()
|
|
|
|
|
|
2020-01-18 20:24:33 +08:00
|
|
|
|
# calculating the index with the values directly -- you can set just the values
|
|
|
|
|
# preferred note: the *calculation* function performs the function *setMatrices*
|
2019-12-06 14:13:10 +08:00
|
|
|
|
indexValue_form3 = cl.calculation("CCCI", red=red, green=green, blue=blue,
|
|
|
|
|
redEdge=redEdge, nir=nir).astype(np.float64)
|
|
|
|
|
|
2020-05-22 14:10:11 +08:00
|
|
|
|
print("Form 1: "+np.array2string(indexValue_form1, precision=20, separator=', ',
|
|
|
|
|
floatmode='maxprec_equal'))
|
|
|
|
|
print("Form 2: "+np.array2string(indexValue_form2, precision=20, separator=', ',
|
|
|
|
|
floatmode='maxprec_equal'))
|
|
|
|
|
print("Form 3: "+np.array2string(indexValue_form3, precision=20, separator=', ',
|
|
|
|
|
floatmode='maxprec_equal'))
|
2019-12-06 14:13:10 +08:00
|
|
|
|
|
|
|
|
|
# A list of examples results for different type of data at NDVI
|
|
|
|
|
# float16 -> 0.31567383 #NDVI (red = 50, nir = 100)
|
|
|
|
|
# float32 -> 0.31578946 #NDVI (red = 50, nir = 100)
|
|
|
|
|
# float64 -> 0.3157894736842105 #NDVI (red = 50, nir = 100)
|
|
|
|
|
# longdouble -> 0.3157894736842105 #NDVI (red = 50, nir = 100)
|
|
|
|
|
"""
|