GEE 教程:如何实现对指定矢量集合的归一化操作(以北京市各区县面积和边长为例)

news2024/9/29 23:26:48

简介

数据归一化处理是指将数据按照一定的规则进行变换,使数据落入一个特定的区间范围内。数据归一化处理的目的是消除数据之间的量纲差异,同时保留数据的分布特征,以便更好地进行数据分析和建模。

常见的数据归一化方法有如下几种:

1. 线性归一化(Min-Max Scaling):将数据线性映射到[0,1]区间内,公式如下:
   X_normalized = (X - X_min) / (X_max - X_min)

   其中,X为原始数据,X_normalized为归一化后的数据,X_min和X_max分别为数据的最小和最大值。

2. Z-score标准化(Standardization):将数据转化为均值为0,标准差为1的分布,公式如下:
   X_standardized = (X - X_mean) / X_std

   其中,X为原始数据,X_standardized为标准化后的数据,X_mean为数据的平均值,X_std为数据的标准差。

3. 小数定标标准化(Decimal Scaling):将数据移到小数点后一位,并除以移动的位数,使数据落入[-1,1]区间内,公式如下:
   X_scaled = X / 10^k

   其中,X为原始数据,X_scaled为定标标准化后的数据,k为使数据落入[-1,1]区间所移动的位数。

数据归一化处理可以消除数据之间的量纲差异,使得不同量纲的数据具有可比性;同时,归一化后的数据也更适合进行某些机器学习算法的训练,如K-means聚类算法。

函数

reduceColumns(reducer, selectors, weightSelectors)

Apply a reducer to each element of a collection, using the given selectors to determine the inputs.

Returns a dictionary of results, keyed with the output names.

使用给定的选择器确定输入,对集合的每个元素应用一个减法器。

返回以输出名称为关键字的结果字典。

Arguments:

this:collection (FeatureCollection):

The collection to aggregate over.

reducer (Reducer):

The reducer to apply.

selectors (List):

A selector for each input of the reducer.

weightSelectors (List, default: null):

A selector for each weighted input of the reducer.

Returns: Dictionary

repeat(count)

Creates a Reducer by combining the specified number of copies of the given reducer. Output names are the same as the given reducer, but each is a list of the corresponding output from each of the reducers.

通过合并指定数量的还原器副本创建还原器。输出名称与给定的还原器相同,但每个还原器的输出都是一个列表。

Arguments:

this:reducer (Reducer)

count (Integer):

The number of copies of the reducer to combine.

Returns: Reducer

ee.Dictionary.fromLists(keys, values)

Construct a dictionary from two parallel lists of keys and values.

Arguments:

keys (List):

A list of keys.

values (List):

A list of values.

Returns: Dictionary

toDictionary(properties)

Extract properties from a feature as a dictionary.

Arguments:

this:element (Element):

The feature to extract the property from.

properties (List, default: null):

The list of properties to extract. Defaults to all non-system properties.

Returns: Dictionary

代码

//加载矢量集合或者属性表
var lucas = ee.FeatureCollection("JRC/LUCAS_HARMO/THLOC/V1");

//我们设定限制200
var exampleFC = lucas.limit(200);

// 我们分别获取你想要获取的属性名称
var listOfProps =  ['year','id'];
var minMax = exampleFC.reduceColumns(ee.Reducer.minMax().repeat(2), listOfProps);
var minDict = ee.Dictionary.fromLists(listOfProps, minMax.get('min'));
var maxDict = ee.Dictionary.fromLists(listOfProps, minMax.get('max'));

//打印查看一下结果
print('minMax',minMax)
print('minDict',minDict)
print('maxDict',maxDict)

// 进行归一化处理,这里注意需要县蒋每一个矢量进行子电话处理
var exampleFC_norm = exampleFC.map(function(f){
  var f_dict = f.toDictionary(listOfProps);
  var f_dict_norm = f_dict.map(function(property, value){
    return ee.Number(value).subtract(minDict.get(property)).divide(
            ee.Number(maxDict.get(property)).subtract(minDict.get(property)))
    });
  return f.set(f_dict_norm)
});

//查看归一化后的结果
print(exampleFC_norm.first())

结果

北京市案例1

var  table = ee.FeatureCollection("users/bqt2000204051/Beijing");

var exampleFC = table;


var listOfProps =  ['Shape_Area','Shape_Leng'];
var minMax = exampleFC.reduceColumns(ee.Reducer.minMax().repeat(2), listOfProps);
var minDict = ee.Dictionary.fromLists(listOfProps, minMax.get('min'));
var maxDict = ee.Dictionary.fromLists(listOfProps, minMax.get('max'));

print('minMax',minMax)
print('minDict',minDict)
print('maxDict',maxDict)


var exampleFC_norm = exampleFC.map(function(f){
  var f_dict = f.toDictionary(listOfProps);
  var f_dict_norm = f_dict.map(function(property, value){
    return ee.Number(value).subtract(minDict.get(property)).divide(
            ee.Number(maxDict.get(property)).subtract(minDict.get(property)))
    });
  return f.set(f_dict_norm)
});

print(exampleFC_norm.first())

矢量表 

 

结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2087890.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

快讯 | 谷歌AI引擎GameNGen颠覆游戏产业:0代码生成《毁灭战士》

硅纪元快讯栏目,每日追踪AI领域的最新动态,快速汇总最新科技新闻,助您时刻紧跟行业趋势。简明扼要的呈现资讯概要,让您快速了解前沿资讯。 1分钟速览新闻 ChatGPT用户翻倍突破2亿,AI工具融入日常生活 智谱AI发布尖端语…

电工手册 v77.9 — 专业电气知识与实用工具(Mod版)

电工手册是一款专门为电力领域从业者及爱好者设计的知识普及与技能提升应用。无论你是专业电工、DIY爱好者,还是对电力领域有兴趣的学生,这款应用都能为你提供大量实用的资源和工具。内容涵盖电气理论、接线图和计算器等多个方面,旨在帮助用户…

(echarts)散点图怎么给横坐标添加单位

(echarts)散点图怎么给横坐标添加单位 效果: 代码: 拓展-给值加

类在JVM中的工作原理

文章目录 引言I 类在JVM中的工作原理class文件的结构类的生命周期II JVM运行时数据区堆栈的意义栈帧内部结构堆III 在JIT中比较常见的优化手段引言 类是一种抽象概念,它是一种模板,用来定义一类事物的属性和行为。类是面向对象编程的基础,它是一种抽象的概念,代表一类事物…

Java 魔法类 Unsafe 源码解读(一)

Java 魔法类 Unsafe 源码解读(一) 前言 阅读过 JUC 源码的同学,一定会发现很多并发工具都调用了一个叫做 Unsafe 的类。 那这个类的作用是什么呢?有什么使用场景呢?底层源码是什么样呢?这篇文章笔者就带…

uni-app商城小程序+后台管理系统,手把手教你搭建

uni-app商城小程序是一种通过uni-app框架开发的,可以在微信、支付宝、字节跳动等多个平台上运行的轻量级电商应用。 一、特点 跨平台兼容:基于uni-app框架,一次开发,可同时适配微信小程序、支付宝小程序、H5、App等多个平台&…

3DMAX2025新款插件精选大全

关于3DMAX2025的新款插件,虽然无法提供一个详尽无遗的列表,本文根据公开发布的信息和插件的流行趋势,概述一些新款插件或插件更新。请注意,由于插件市场不断变化,以下信息可能随时间而有所更新。 以下插件按首字母排序…

ts转mp4怎么转?分享3个方法,快速搞定

在视频编辑和处理的世界里,格式转换是一个常见且必要的任务。特别是当你手头上有一些ts格式的视频文件,而你又需要将它们转换成更通用、更容易分享的mp4格式时,了解如何进行转换就显得尤为重要。 只有掌握了格式转换的技能,我们才…

yolov8训练野火烟雾识别检测模型

1.数据集下载 数据集下载链接:https://hyper.ai/datasets/33096 2. 数据集格式转换 需要将json中的标注信息转换为yolo格式的标注文件数据 import json import os import shutil import cv2 import matplotlib.pyplot as plttarget "./data/val" def…

如何在没有密码的情况下解锁 Oppo 手机?5 种简单的方法

保护智能手机隐私的一种很好的方法是设置复杂的锁屏密码或图案。一些 OPPO 手机的所有者在更改后一夜之间经历了图案或密码的内存丢失。事实上,OPPO 用户遇到的众多问题包括忘记密码或锁定屏幕。遗憾的是,没有多少人知道无需密码即可解锁 OPPO 手机的简单…

JAVA毕业设计166—基于Java+Springboot+vue3的流浪宠物救助管理小程序(源代码+数据库)

毕设所有选题: https://blog.csdn.net/2303_76227485/article/details/131104075 基于JavaSpringbootvue3的流浪宠物救助管理小程序(源代码数据库)166 一、系统介绍 本项目前后端分离带小程序(可以改为ssm版本),分为用户、救助站、管理员三种角色 1、…

chapter09-OOP高级部分——(类变量和类方法)——day12

目录 ​编辑 374-类变量引出 375-类变量快速入门 376-类变量内存剖析 377-类变量定义访问 378-类变量使用细节 379-类方法快速入门 380-类方法最佳实践 381-类方法注意事项 静态方法只能访问静态变量 非静态方法可以访问静态成员和非静态成员(都可以访问…

OpenAI AI 聊天机器人周活跃用户超 2 亿

🦉 AI新闻 🚀 OpenAI AI 聊天机器人周活跃用户超 2 亿 摘要:科技媒体 Axios 报道,OpenAI 的 AI 聊天机器人在短短一年内实现了周活跃用户超过 2 亿的增长。该公司表示,全球财富 500 强企业中已有 92% 使用其产品&…

革新客户服务艺术:揭秘高效集成第三方平台与质检升级的前沿策略

Hi~这里是ProXiao 文章参考:晓观点 如何实现与第三方客服平台的有效对接并提高客户服务的质检水平?https://insight.xiaoduoai.com/intelligent-tools/quality-inspection/how-to-achieve-effective-integration-with-third-party-customer-service-pl…

书法图片自动扣字的批处理

本程序会根据原文字图片,自动扣字并生成黑字、红字2个透明的png图片,原图片黑字或白字均可。运行的话需要先安装好 ImageMagick-7.1.1-37 用法与生成效果举例: a.jpg 白字 转 黑、红扣字png: b.jpg 黑字 转 黑、红扣字png: 分享脚本如下: …

Kafka 到数据仓库:使用 bend-ingest-kafka 将消息加载到 Databend

将消息从 Apache Kafka 导入到像 Databend 这样的云数据仓库可能是一项艰巨的任务。bend-ingest-kafka 工具简化了这一过程,使您能够轻松地将 Kafka 消息导入到 Databend 表中。 什么是 bend-ingest-kafka? bend-ingest-kafka 工具是一个专门为从 Apac…

网上一堆教人用AI做自媒体的,真的能挣钱吗?看我真实测评~

今日主题:AI副业能做吗? 今年这情况,几乎所有人都想搞个副业。 有人问我:普通人真的能靠AI做自媒体搞钱吗? 先说结论:可以,但要找准路子! 听我慢慢道来~ 我是今年开始做AI自媒体…

同声传译用什么软件?5款优质软件评测

最近,我遇到了一个尴尬的情况。在一次国际会议中,我被分配到了一个多语言小组讨论。虽然我的英语还算流利,但面对来自世界各地的同事们,各种口音和语速让我感到有些力不从心。 那一刻,我多么希望有一个神奇的工具&…

如何解决已经安装软航文档控件但依旧提示未安装的问题

目录 前言 问题现象 问题处理步骤 前言 本文介绍在办公系统中使用重庆软航科技有限公司开发的NTKO OFFICE文档控件软件时,已经通过办公系统提供的软件安装包安装,但是在360安全浏览器、360极速浏览器的兼容模式下依旧提示:本机尚未安装跨浏…

STM32F411 标准库硬件SPI (硬件NSS/CS)驱动st7735--1.8寸TFT显示屏

TFT的spi驱动文件 完整工程网盘放在末尾 #include "lcd_driver.h"static uint16_t SPI_TIMEOUT_UserCallback(uint8_t errorCode);//液晶IO初始化配置 void LCD_Driver_Init(void) {SPI_InitTypeDef SPI_InitStructure;GPIO_InitTypeDef GPIO_InitStructure;/* 使能…