forked from brmagnuson/LandFallowingInEarthEngine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCentralValleyNDVI.js
97 lines (76 loc) · 2.93 KB
/
CentralValleyNDVI.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/**
* Created by BonnieRose on 11/23/15.
*/
///////////////
// Prepare data
///////////////
// Parameters
var ndviParams = {palette: 'FF0000, 000000, 00FF00', min: -0.5, max: 0.5};
var vizParams2010 = {bands: ['B3', 'B2', 'B1'], min: 0, max: 0.3};
var vizParams2015 = {bands: ['B4', 'B3', 'B2'], min: 0, max: 0.3};
var bands2010 = ['B1', 'B2', 'B3', 'B4'];
var bands2015 = ['B2', 'B3', 'B4', 'B5'];
// Define Central Valley region
var centralValley = ee.FeatureCollection('ft:1h46ENpEp8vO3pOe1EqeF1sZLEDhSVMxbu8pHAoU4', 'geometry');
// Get median-pixel composite for the summers of 2010 and 2015 from Landsat 5 & 8.
var summer2010 = ee.ImageCollection('LEDAPS/LT5_L1T_SR')
.filterDate('2010-06-01', '2010-08-30')
.select(bands2010);
var summer2015 = ee.ImageCollection('LANDSAT/LC8_L1T_TOA')
.filterDate('2015-06-01', '2015-08-30')
.select(bands2015);
var median2010 = summer2010.median();
var median2015 = summer2015.median();
// Clip Landsat composite by California state boundary.
var clipped2010 = median2010.clip(centralValley);
var clipped2015 = median2015.clip(centralValley);
/////////////////
// Calculate NDVI
/////////////////
// This function gets NDVI from any imagery with red and NIR bands.
var getNDVI = function(image, redBand, nirBand) {
return image.normalizedDifference([nirBand, redBand]);
};
// Find NDVI
var ndvi2010 = getNDVI(clipped2010, 'B3', 'B4');
var ndvi2015 = getNDVI(clipped2015, 'B4', 'B5');
// Map.addLayer(ndvi2010);
// Map.addLayer(ndvi2015);
// Create a land layer so that we can mask out known water areas.
var land = ndvi2010.gt(0);
// Mask ndvi to just the land areas.
ndvi2010 = ndvi2010.mask(land);
ndvi2015 = ndvi2015.mask(land);
// Find the difference in NDVI. Result is positive if NDVI increased, negative if it decreased.
var ndviDifference = ndvi2015.subtract(ndvi2010);
// Map NDVI difference
Map.addLayer(ndviDifference, ndviParams);
//////////////////////////
// Calculate Fallowed Area
//////////////////////////
// Histogram of 2010 NDVI.
var options = {
title: 'Central Valley NDVI Histogram',
fontSize: 20,
hAxis: {title: 'NDVI'},
vAxis: {title: 'count'},
series: {
0: {color: 'blue'}}
};
var histogram = Chart.image.histogram(ndvi2010, centralValley, 100)
.setSeriesNames(['NDVI'])
.setOptions(options);
print(histogram);
// Calculate fallowed area by pixel (0 if pixel was not fallowed)
var fallowed = ndviDifference.lt(-0.2);
var areaImageSqM = ee.Image.pixelArea()
.clip(centralValley);
var areaImageSqKm = areaImageSqM.multiply(0.000001);
var fallowedArea = fallowed.multiply(areaImageSqKm);
// Calculate total fallowed area in square kilometers. 30 meters is Landsat 5 & 8's spatial resolution,
// but reduceRegion apparently can't handle that much for this area. Smallest it could handle:
var totalFallowedArea = fallowedArea.reduceRegion(ee.Reducer.sum(), centralValley, 90);
print(totalFallowedArea);
// Map
Map.addLayer(fallowedArea, {'min': 0, 'max': 0.013});
Map.setCenter(-120.959, 37.571, 7);