数学建模强化宝典(13)M-K检验法

前言

       M-K检验法,全称为Mann-Kendall检验法,是一种非参数的假设检验方法,广泛应用于时间序列数据的趋势性变化检验,特别是气候序列中的趋势分析和突变点检测。以下是对M-K检验法的详细介绍:

一、定义与背景

       M-K检验法由Frank Mann和Donald R. Kendall提出并发展,因此得名Mann-Kendall检验法。该方法不依赖于数据的具体分布形式,能够处理含有异常值和非正态分布的数据,非常适合于气候、水文、环境等领域的时间序列数据分析。

二、基本原理

       M-K检验法的基本原理是通过比较每个数据点与其之前数据点的大小,来检测时间序列数据中的单调趋势(上升、下降或没有趋势)。具体步骤如下:

  1. 构造秩序列:对于时间序列中的每一个数据点,计算其之前所有数据中比它大或小的数据点个数,从而构造出一个秩序列。
  2. 计算统计量:基于秩序列,计算统计量UFk(正向序列)和UBk(反向序列),这两个统计量用于评估时间序列的趋势性和突变点。
  3. 显著性检验:将UFk和UBk与设定的显著性水平(如0.05)对应的临界值进行比较,判断趋势是否显著,以及是否存在突变点。

三、应用领域

M-K检验法广泛应用于以下领域:

  1. 气候变化研究:用于检测气候序列中的趋势变化和突变点,如气温、降水等气候要素的变化趋势。
  2. 水文水资源研究:分析河流流量、地下水位等水文要素的时间序列数据,评估其变化趋势和突变情况。
  3. 环境科学研究:在环境监测和评估中,利用M-K检验法分析污染物浓度、环境质量等指标的变化趋势。

四、优点与局限性

优点:
  1. 非参数检验:不依赖于数据的具体分布形式,适用于各种类型的时间序列数据。
  2. 抗干扰能力强:对异常值不敏感,能够较好地处理非正态分布的数据。
  3. 计算简便:计算过程相对简单,易于实现自动化处理。
局限性:
  1. 无法确定趋势形式:M-K检验法只能判断时间序列是否存在单调趋势,但无法确定趋势的具体形式(如线性、非线性等)。
  2. 对周期性变化不敏感:对于存在周期性变化的时间序列数据,M-K检验法的检测效果可能不佳。

五、实现 

       下面是一个简单的MATLAB函数,用于执行Mann-Kendall趋势检验,并计算统计量UFk(正向序列)以及可选的UBk(反向序列,用于确定突变点): 

function [UF, UB, pValue] = mannKendall(x)  
    % 输入:  
    % x - 时间序列数据向量  
    %  
    % 输出:  
    % UF - 正向序列的Mann-Kendall统计量  
    % UB - 反向序列的Mann-Kendall统计量(可选)  
    % pValue - 对应的p值(此函数不直接计算,通常需要查表或使用其他方法)  
  
    n = length(x);  
    s = 0;  
    varS = 0;  
    UF = zeros(1, n);  
  
    % 初始化  
    for k = 2:n  
        for j = 1:k-1  
            if x(k) > x(j)  
                s = s + 1;  
            elseif x(k) < x(j)  
                s = s - 1;  
            end  
        end  
        UF(k) = (s - k * (k - 1) / 2) / sqrt(k * (k - 1) * (2 * k + 5) / 18);  
        varS = varS + s^2;  
        s = 0;  
    end  
  
    % UB的计算需要反向序列  
    UB = zeros(1, n);  
    if nargout > 2  
        % 计算方差  
        varS = (n * (n - 1) * (2 * n + 5) / 18) - varS;  
        if varS == 0  
            varS = 1; % 避免除以零  
        end  
          
        % 反向序列  
        y = fliplr(x);  
        for k = 2:n  
            UB(k) = -UF(n+1-k); % 利用正向序列的结果  
            % 注意:这里直接利用UF的结果进行转换,实际上UB的计算需要完整重复上述过程,  
            % 但对于标准Mann-Kendall测试,通常只关注UF,UB用于确定突变点  
        end  
          
        % 标准化UB  
        UB = UB / sqrt(varS / 18);  
    end  
  
    % 注意:此函数不直接计算p值,通常需要查表或使用统计软件  
    pValue = NaN; % 占位符  
end

注意

  1. 上述代码主要计算了UF统计量,并可选地计算了UB统计量(虽然UB的计算是基于UF的简化,实际中可能需要独立计算)。
  2. p值的计算通常不是直接通过M-K统计量本身进行的,而是需要参考相应的统计表或使用专门的统计软件/函数。
  3. 对于趋势的显著性判断,通常需要将UF或UB的值与一定的显著性水平(如α=0.05对应的临界值)进行比较。
  4. 在实际应用中,你可能还需要对时间序列进行预处理,如去趋势、季节性调整等,以提高M-K检验的准确性。

六、结论

       M-K检验法作为一种非参数的假设检验方法,在气候、水文、环境等领域的时间序列数据分析中发挥着重要作用。其优点在于不依赖于数据的具体分布形式且抗干扰能力强,但也存在无法确定趋势形式和对周期性变化不敏感的局限性。在实际应用中,应根据具体研究目的和数据特点选择合适的分析方法。

 结语 

成功是优点的发挥

失败是缺点的累积

!!!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode面试经典150题-83.删除链表中的重复元素

解法都在代码里&#xff0c;不懂就留言或者私信 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val val; }* ListNode(int val, ListNode next) { this.val …

服务器监控工具都是监控服务器的哪些性能和指标

服务器监控工具通常用于确保服务器及其相关服务的正常运行。这些工具可以帮助管理员快速识别并解决问题&#xff0c;从而减少停机时间和性能下降的风险。以下是服务器监控工具通常会监控的一些主要内容&#xff1a; 系统健康状态&#xff1a; CPU使用率 内存&#xff08;RAM&…

油猴插件录制请求,封装接口自动化参数

参考&#xff1a;如何使用油猴插件提高测试工作效率 一、背景 在酷家乐设计工具测试中&#xff0c;总会有许多高频且较繁琐的工作&#xff0c;比如&#xff1a; 查询插件版本&#xff1a;需要打开Chrome控制台&#xff0c;输入好几个命令然后过滤出版本信息。 查询模型商品&…

JAVA—单元测试

单元测试&#xff1a;就是针对最小的功能单元&#xff08;方法&#xff09;&#xff0c;编写测试代码对其进行正确性测试 之前是使用main函数调用来进行检测&#xff0c;无法实现自动化测试 也会影响其他方法的测试 目录 1.junit框架概述 2.junit框架的常见注解 1.junit框架…

基于C++实现(MFC界面)家谱管理系统

一、题目&#xff1a;家谱管理系统 二、内容&#xff1a; 2.1 概述 2.1.1 选题原因 做此题的原因是因为可以比较方便的记录家族历代成员的情况与关系&#xff0c;能很好的保存家族每一代的信息&#xff0c;而不用人工纸质的方式来存取家谱&#xff0c;更便于人们保存和使用…

基于STELLA系统动态模拟技术及在农业、生态环境等科学领域中的实践应用

STELLA是一种用户友好的计算机软件。通过绘画出一个系统的形象图形&#xff0c;并给这个系统提供数学公式和输入数据&#xff0c;从而建立模型。依据专业兴趣&#xff0c;STELLA可以用来建立各种各样的农业、生态、环境等方面的系统动态模型&#xff0c;为科研、教学、管理服务…

Day16_0.1基础学习MATLAB学习小技巧总结(16)——元胞数组

利用空闲时间把碎片化的MATLAB知识重新系统的学习一遍&#xff0c;为了在这个过程中加深印象&#xff0c;也为了能够有所足迹&#xff0c;我会把自己的学习总结发在专栏中&#xff0c;以便学习交流。 素材来源“数学建模清风” 特此说明&#xff1a;本博客的内容只在于总结在…

linux top命令介绍以及使用

文章目录 介绍 top 命令1. top 的基本功能2. 如何启动 top3. top 的输出解释系统概况任务和 CPU 使用情况内存和交换空间进程信息 4. 常用操作 总结查看逻辑CPU的个数查看系统运行时间 介绍 top 命令 top 是一个在类 Unix 系统中广泛使用的命令行工具&#xff0c;用于实时显示…

pikachu文件包含漏洞靶场攻略

1.File inclusion(local)&#xff08;本地文件包含&#xff09; 提交一个球员信息 filename后面输入../../../../../1.php访问php文件 2.File Inclusion(remote)&#xff08;远程文件包含&#xff09; 修改配置 远程包含漏洞的前提&#xff1a;需要php.ini配置如下&#…

深入理解 Babel - 微内核架构与 ECMAScript 标准化|得物技术

随着浏览器版本的持续更新&#xff0c;浏览器对JavaScript的支持越来越强大&#xff0c;Babel的重要性显得较低了。但Babel的设计思路、背后依赖的ECMAScript标准化思想仍然值得借鉴。 本文涉及的Babel版本主要是V7.16及以下&#xff0c;截至发文时&#xff0c;Babel最新发布的…

利用SSH加密实现的HTTP隧道分析与检测

1.隧道介绍 Chisel是一个快速稳定的TCP/UDP隧道工具&#xff0c;该工具基于HTTP实现&#xff0c;并通过SSH加密保证通信安全。Chisel可以进行端口转发、反向端口转发以及SOCKS流量代理&#xff0c;使用GO语言编写&#xff0c;具备较好的跨平台特性。该工具的主要用于绕过防火墙…

Hive数据库与表操作全指南

目录 Hive数据库操作详解 创建数据库 1&#xff09;语法 2&#xff09;案例 查询数据库 1&#xff09;展示所有数据库 &#xff08;1&#xff09;语法 &#xff08;2&#xff09;案例 2&#xff09;查看数据库信息 &#xff08;1&#xff09;语法 &#xff08;2&#…

Spring之整合Mybatis底层源码解析

整合核心思路 由很多框架都需要和Spring进行整合&#xff0c;而整合的核心思想就是把其他框架所产生的对象放到Spring容器中&#xff0c;让其成为Bean。 ​ 比如Mybatis&#xff0c;Mybatis框架可以单独使用&#xff0c;而单独使用Mybatis框架就需要用到Mybatis所提供的一些类…

学习笔记八:基于Jenkins+k8s+Git+DockerHub等技术链构建企业级DevOps容器云平台

基于Jenkinsk8sGitDockerHub等技术链构建企业级DevOps容器云平台 测试jenkins的CI/CD在Jenkins中安装kubernetes插件安装blueocean插件配置jenkins连接到我们存在的k8s集群配置pod-template添加自己的dockerhub凭据测试通过Jenkins部署应用发布到k8s开发环境、测试环境、生产环…

手机玩机常识-----小米系列机型 Android 15 更新计划 那些机型将会更新安卓15

小米机型是很多米粉最喜欢把玩的&#xff0c;其中解锁bl root 刷写twrp以及刷第三方系统资源相对其他品牌机型来说比较丰富。目前安卓15快要更新到很多机型。我们来了解下小米系列机型的更新计划是咋样的 小米会定期更新有关 Redmi红米 设备的支持日期的数据&#xff0c;包括可…

嵌入式学习(内核链表)

内核链表和普通链表的区别&#xff1a; 1. 普通链表当中数据域和指针域&#xff0c;没有做到区分&#xff0c;数据与指针形成了一个整体&#xff0c;而内核链表数据与指针是完全剥离的没有直接的关系。 2. 在普通链表当中所有节点的数据都是一样的类型&#xff0c;而内核链表中…

HarmonyOS开发实战( Beta5.0)Native Drawing自绘制能力替代Canvas提升性能

简介 Canvas 画布组件是用来显示自绘内容的组件&#xff0c;它具有保留历史绘制内容、增量绘制的特点。Canvas 有 CanvasRenderingContext2D/OffscreenCanvasRenderingContext2D 和 DrawingRenderingContext 两套API&#xff0c;应用使用两套API绘制的内容都可以在绑定的 Canv…

【WPS Excel】复制表格时,提示“图片太大,超过部份将被截去“ 问题

WPS表格 2019版本 升级到 WPS最新版 WPS-支持多人在线协作编辑Word、Excel和PPT文档_WPS官方网站 使用最新版就能够解决这个问题&#xff0c;如果仍旧无法解决可以勾选如下配置 重启Excel解决。 请勾选&#xff1a;文件 - 选项 - 编辑 - 不提示且不压缩文件中的图像

html 页面引入 vue 组件之 http-vue-loader.js

一、http-vue-loader.js http-vue-loader.js 是一个 Vue 单文件组件加载器&#xff0c;可以让我们在传统的 HTML 页面中使用 Vue 单文件组件&#xff0c;而不必依赖 Node.js 等其他构建工具。它内置了 Vue.js 和样式加载器&#xff0c;并能自动解析 Vue 单文件组件中的所有内容…

电脑知识:如何恢复 Word、媒体和存档文件?

如果您是 Word 用户&#xff0c;那么您一定对无法打开 Word 文档的问题很熟悉。当文档包含大量关键信息时&#xff0c;情况会变得更加复杂。如果您遇到这种情况&#xff0c;那么您将如何处理&#xff1f; 我们再怎么强调在外部存储位置&#xff08;如外部硬盘、网络位置&#…