Skip to content
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

buildSRcollection does not work for southern hemisphere #26

Open
S-AQ opened this issue Sep 22, 2021 · 1 comment
Open

buildSRcollection does not work for southern hemisphere #26

S-AQ opened this issue Sep 22, 2021 · 1 comment
Assignees
Labels
enhancement New feature or request

Comments

@S-AQ
Copy link

S-AQ commented Sep 22, 2021

In update 14.11 on 2018-06-13, you wrote that you improved the buildSRcollection function to account for the medoid image of the growing season of the southern hemisphere. The theory was that as long as you take the startDay later in the year than the endDay, you would result in a medoid image collection consisting of acquisition dates somewhere in January for example.

I ran the following code snippet that was published along with the update, but it did not result in acquisition dates in the southern summer.

// load the LandTrendr.js module
var ltgee = require('users/emaprlab/public:Modules/LandTrendr.js');

// define parameters
var startYear = 1985;
var endYear = 2017;
var startDay = '12-20';
var endDay = '02-20';
var aoi = ee.Geometry.Point(-122.8848, 43.7929);

// center and zoom the display in case outputs are to be mapped 
Map.centerObject(aoi,10);
Map.addLayer(aoi);

// apply LandTrendr.js functions
var annualSRcollection = ltgee.buildSRcollection(startYear, endYear, startDay, endDay, aoi);

// add property 'acquisition_date' to each image with the date converted to UNIX style. 
var annualSRcollection = annualSRcollection.map(function(im){
  var newdate = ee.Date(im.get('system:time_start')).format("yyyy-MM-dd");
  return im.set({'acquisition_date': newdate});
});
print(annualSRcollection);

But the code returns an image collection where all images are taken around August 31st
image

Why does it do that?

Could it have anything to do with the hardcoded date of August 1st in lines 217 and 205?

line 205:
.set('system:time_start', (new Date(year,8,1)).valueOf()); // add the year to each medoid image - the data is hard-coded Aug 1st

line 217:
imgs = imgs.concat(tmp.set('system:time_start', (new Date(i,8,1)).valueOf())); // concatenate the annual image medoid to the collection (img) and set the date of the image - hard coded to the year that is being worked on for Aug 1st

@jdbcode
Copy link
Member

jdbcode commented Sep 22, 2021

The date for the annual medoid composites is hard coded. See line

imgs = imgs.concat(tmp.set('system:time_start', (new Date(i,8,1)).valueOf())); // concatenate the annual image medoid to the collection (img) and set the date of the image - hard coded to the year that is being worked on for Aug 1st

The comment says August first, but the month parameters for the Date function is 0-based month index, not month number. It's a little strange that the formatted acquisition_date is August 31st, I'd expect it to be September 1st, issue is likely due to time zones.

A better solution here would be to use the median date of the images in the composite and also maybe add a property to the annual composites listing the dates of all of the images used in a given composite.

I'll keep this issue open and implement a change for better date assignment. Thanks for bring this to our attention!

@jdbcode jdbcode self-assigned this Sep 22, 2021
@jdbcode jdbcode added the enhancement New feature or request label Sep 22, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants