GEE错误——XXX is not a function,如何解决这个问题?

错误:

这里的时错误原始的代码链接:

https://code.earthengine.google.com/4bf0975a41e14d0c40e01925c6f3cf2a

这里主要的问题时这个单一影像不存在:

ImageCollection (Error)

ImageCollection.load: ImageCollection asset 'LANDSAT/LC08/C01/T1_SR/LC08_221077_20170411' not found (does not exist or caller does not have access).

而表面的问题是

Line 16: nir.subtract is not a function

原始代码:

// Importar imagem Landsat 8
var image = ee.ImageCollection('LANDSAT/LC08/C01/T1_SR/LC08_221077_20170411');

// Centrar mapa 
Map.setCenter(-46.19804603400004,-12.026968211384917);


// Obter bandas espectrais
var nir = image.select('B5'); // Infravermelho próximo
var red = image.select('B4'); // Vermelho
var blue = image.select('B2'); // Azul
var green = image.select('B3'); // Verde

// Calcular índices de vegetação
var ndvi = nir.subtract(red).divide(nir.add(red)).rename('NDVI'); // NDVI
var savi = nir.subtract(red).multiply(1.5).divide(nir.add(red).add(0.5)).rename('SAVI'); // SAVI
var evi = nir.subtract(red).multiply(2.5).divide(nir.add(red.multiply(6)).subtract(blue.multiply(7.5)).add(1)).rename('EVI'); // EVI
var wdvi = nir.subtract(red.multiply(0.87)).rename('WDVI'); // WDVI
var gndvi = nir.subtract(green).divide(nir.add(green)).rename('GNDVI'); // GNDVI
var grvi = green.divide(red).rename('GRVI'); // GRVI
var gci = nir.divide(green).subtract(1).rename('GCI'); // GCI
var pri = blue.subtract(green).divide(blue.add(green)).rename('PRI'); // PRI
var tvi = nir.subtract(green).multiply(120).subtract(red.subtract(green).multiply(200)).multiply(0.5).add(0.5).rename('TVI'); // TVI
var msavi = nir.multiply(2).add(1).subtract(ee.Image.constant(2).multiply(nir.add(1)).pow(2).subtract(ee.Image.constant(8).multiply(nir.subtract(red))).sqrt()).multiply(0.5).rename('MSAVI'); // MSAVI
var osavi = nir.subtract(red).divide(nir.add(red).add(0.16)).rename('OSAVI'); // OSAVI
var mtvi1 = nir.subtract(green).multiply(1.2).subtract(red.subtract(green).multiply(2.5)).rename('MTVI1'); // MTVI1
var mtvi2 = nir.divide(green).subtract(1.2).multiply(1.5).subtract(red.divide(green).subtract(2.5)).multiply(1.5).rename('MTVI2'); // MTVI2

// Definir parâmetros de visualização dos índices
var ndviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'NDVI'}; // NDVI
var saviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'SAVI'}; // SAVI
var eviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'EVI'}; // EVI
var wdviParams = {min: -0.1, max: 0.6, palette: ['blue', 'white', 'green'], bands: 'WDVI'}; // WDVI
var gndviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'GNDVI'}; // GNDVI
var grviParams = {min: 0, max: 1, palette: ['red', 'yellow', 'green'], bands: 'GRVI'}; // GRVI
var gciParams = {min: -0.5, max: 0.5, palette: ['red', 'white', 'green'], bands: 'GCI'}; // GCI
var priParams = {min: -0.5, max: 0.5, palette: ['red', 'white', 'green'], bands: 'PRI'}; // PRI
var tviParams = {min: 0, max: 1, palette: ['blue', 'white', 'green'], bands: 'TVI'}; // TVI
var msaviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MSAVI'}; // MSAVI
var osaviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'OSAVI'}; // OSAVI
var mtvi1Params = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MTVI1'}; // MTVI1
var mtvi2Params = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MTVI2'}; // MTVI2

// Adicionar camadas dos índices ao mapa
Map.addLayer(ndvi, ndviParams, 'NDVI');
Map.addLayer(savi, saviParams, 'SAVI');
Map.addLayer(evi, eviParams, 'EVI');
Map.addLayer(wdvi, wdviParams, 'WDVI');
Map.addLayer(gndvi, gndviParams, 'GNDVI');
Map.addLayer(grvi, grviParams, 'GRVI');
Map.addLayer(gci, gciParams, 'GCI');
Map.addLayer(pri, priParams, 'PRI');
Map.addLayer(tvi, tviParams, 'TVI');
Map.addLayer(msavi, msaviParams, 'MSAVI');
Map.addLayer(osavi, osaviParams, 'OSAVI');
Map.addLayer(mtvi1, mtvi1Params, 'MTVI1');
Map.addLayer(mtvi2, mtvi2Params, 'MTVI2');

修改后的代码:

var geometry = /* color: #d63000 */ee.Geometry.Point([-46.19804603400004, -12.026968211384917]);
// Importar imagem Landsat 8
//var image = ee.ImageCollection('LANDSAT/LC08/C01/T1_SR/LC08_221077_20170411');
// Centrar mapa 
Map.setCenter(-46.19804603400004,-12.026968211384917);
var image = ee.ImageCollection('LANDSAT/LC08/C01/T1_SR').filterBounds(geometry).first();

// Obter bandas espectrais
var nir = image.select('B5'); // Infravermelho próximo
var red = image.select('B4'); // Vermelho
var blue = image.select('B2'); // Azul
var green = image.select('B3'); // Verde

// Calcular índices de vegetação
var ndvi = nir.subtract(red).divide(nir.add(red)).rename('NDVI'); // NDVI
var savi = nir.subtract(red).multiply(1.5).divide(nir.add(red).add(0.5)).rename('SAVI'); // SAVI
var evi = nir.subtract(red).multiply(2.5).divide(nir.add(red.multiply(6)).subtract(blue.multiply(7.5)).add(1)).rename('EVI'); // EVI
var wdvi = nir.subtract(red.multiply(0.87)).rename('WDVI'); // WDVI
var gndvi = nir.subtract(green).divide(nir.add(green)).rename('GNDVI'); // GNDVI
var grvi = green.divide(red).rename('GRVI'); // GRVI
var gci = nir.divide(green).subtract(1).rename('GCI'); // GCI
var pri = blue.subtract(green).divide(blue.add(green)).rename('PRI'); // PRI
var tvi = nir.subtract(green).multiply(120).subtract(red.subtract(green).multiply(200)).multiply(0.5).add(0.5).rename('TVI'); // TVI
var msavi = nir.multiply(2).add(1).subtract(ee.Image.constant(2).multiply(nir.add(1)).pow(2).subtract(ee.Image.constant(8).multiply(nir.subtract(red))).sqrt()).multiply(0.5).rename('MSAVI'); // MSAVI
var osavi = nir.subtract(red).divide(nir.add(red).add(0.16)).rename('OSAVI'); // OSAVI
var mtvi1 = nir.subtract(green).multiply(1.2).subtract(red.subtract(green).multiply(2.5)).rename('MTVI1'); // MTVI1
var mtvi2 = nir.divide(green).subtract(1.2).multiply(1.5).subtract(red.divide(green).subtract(2.5)).multiply(1.5).rename('MTVI2'); // MTVI2

// Definir parâmetros de visualização dos índices
var ndviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'NDVI'}; // NDVI
var saviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'SAVI'}; // SAVI
var eviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'EVI'}; // EVI
var wdviParams = {min: -0.1, max: 0.6, palette: ['blue', 'white', 'green'], bands: 'WDVI'}; // WDVI
var gndviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'GNDVI'}; // GNDVI
var grviParams = {min: 0, max: 1, palette: ['red', 'yellow', 'green'], bands: 'GRVI'}; // GRVI
var gciParams = {min: -0.5, max: 0.5, palette: ['red', 'white', 'green'], bands: 'GCI'}; // GCI
var priParams = {min: -0.5, max: 0.5, palette: ['red', 'white', 'green'], bands: 'PRI'}; // PRI
var tviParams = {min: 0, max: 1, palette: ['blue', 'white', 'green'], bands: 'TVI'}; // TVI
var msaviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MSAVI'}; // MSAVI
var osaviParams = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'OSAVI'}; // OSAVI
var mtvi1Params = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MTVI1'}; // MTVI1
var mtvi2Params = {min: -1, max: 1, palette: ['blue', 'white', 'green'], bands: 'MTVI2'}; // MTVI2

// Adicionar camadas dos índices ao mapa
Map.addLayer(ndvi, ndviParams, 'NDVI');
Map.addLayer(savi, saviParams, 'SAVI');
Map.addLayer(evi, eviParams, 'EVI');
Map.addLayer(wdvi, wdviParams, 'WDVI');
Map.addLayer(gndvi, gndviParams, 'GNDVI');
Map.addLayer(grvi, grviParams, 'GRVI');
Map.addLayer(gci, gciParams, 'GCI');
Map.addLayer(pri, priParams, 'PRI');
Map.addLayer(tvi, tviParams, 'TVI');
Map.addLayer(msavi, msaviParams, 'MSAVI');
Map.addLayer(osavi, osaviParams, 'OSAVI');
Map.addLayer(mtvi1, mtvi1Params, 'MTVI1');
Map.addLayer(mtvi2, mtvi2Params, 'MTVI2');

在Google Earth Engine (GEE)中遇到'sortedSubValues.indexOf is not a function'错误,通常是因为尝试在一个不是数组的对象上调用.indexOf()方法。以下是一些解决这个问题的步骤: 1. 检查数据类型: 确保sortedSubValues确实是一个数组。使用print()函数来调试和查看sortedSubValues的类型和内容。 ```javascript print('sortedSubValues:', sortedSubValues); print('Type of sortedSubValues:', typeof sortedSubValues); ``` 2. 转换数据类型: 如果sortedSubValues不是数组,使用JavaScript的Array.from()方法将其转换为数组。 ```javascript sortedSubValues = Array.from(sortedSubValues); ``` 3. 使用更安全的方法: 考虑使用Array.prototype.includes()方法代替indexOf(),或者使用Lodash库的_.includes()方法。 ```javascript if (sortedSubValues.includes(value)) { // 执行相关操作 } ``` 4. 初始化数组: 确保在使用indexOf()之前,sortedSubValues已经被正确初始化为一个空数组。 ```javascript var sortedSubValues = []; ``` 5. 检查函数上下文: 确保indexOf()是在正确的上下文中调用的。如果是在map()或其他迭代函数中,确保正确使用this或外部变量。 ```javascript var index = sortedSubValues.indexOf(value); ``` 6. 使用GEE的ee.Algorithms库: 如果你正在处理GEE特有的数据结构,考虑使用GEE的ee.Algorithms库中的相关函数。 ```javascript var index = ee.Algorithms.arrayIndexOf(sortedSubValues, value); ``` 7. 检查数据来源: 确保sortedSubValues的数据来源是正确的,并且没有被意外地赋值为非数组类型。 通过以上步骤,你应该能够解决'sortedSubValues.indexOf is not a function'这个错误。如果问题仍然存在,建议检查整个代码逻辑,确保在调用indexOf()之前,sortedSubValues确实是一个包含你要查找的值的数组。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

此星光明

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值