Python互相关统计学 地震学 心理学 数学物理和算法模型及数据科学应用

news2025/1/8 6:37:58

🎯要点

  1. 同步时间序列数据
  2. 地震时频域信息
  3. 绘制地震噪声干涉图和频谱
  4. 计算光变曲线和时滞
  5. 互相关光变曲线并计算峰值和质心
  6. 图像几何对应关系算法
  7. 气候相关矩阵图
  8. 测量麦克风间距离
  9. 图像相似性量化及显着性统计测试
  10. 个体同步性量化分析
  11. 计算绘制有无泊松噪声的光曲线
  12. 地震幅度和时间检测
  13. 判别同类型音频信号
    在这里插入图片描述

Python和MATLAB互相关

在信号处理中,互相关是对两个系列的相似性的度量,作为一个系列相对于另一个系列的位移的函数。这也称为滑动点积或滑动内积。它通常用于在长信号中搜索较短的已知特征。它在模式识别、单粒子分析、电子断层扫描、平均、密码分析和神经生理学方面有应用。互相关本质上类似于两个函数的卷积。在自相关(即信号与其自身的互相关)中,始终会在零滞后处出现峰值,其大小就是信号能量。

在概率和统计中,互相关是指两个随机向量 X X X Y Y Y的条目之间的相关性,而随机向量 X X X的相关性是 X X X本身的条目之间的相关性,那些形成 X X X的相关矩阵。如果 X X X Y Y Y 中的每一个都是在时间序列中重复实现的标量随机变量,则 X X X 的各个时间实例的相关性称为 X X X 的自相关性,而互相关性称为 X X X 的自相关性 X X X Y Y Y 随时间的变化是时间互相关。在概率和统计学中,相关性的定义始终包含标准化因子,使得相关性的值介于 -1 和 +1 之间。

显示了几个时间延迟的互相关的直观示例:

在这里插入图片描述

应用于:

  • 相位噪声分析:未知振荡器的相位噪声测量通常会受到测量电子设备本身的附加噪声的限制。为了解决这一难题,可以将设备馈入两个不同的解调通道。对两个结果信号进行互相关分析可以消除由单独的本地振荡器添加的不相关噪声,同时保留相关噪声,这是感兴趣的数字。这样可以测量低于测量设备本身的相位噪声。
  • 时间延迟估计:当两个相似信号在时间上匹配时,它们之间的互相关函数会产生幅度最大值。这一特性在确定雷达测量中的距离或飞行时间,或同步电信中的信号等应用中非常有用。
  • 信号分析:使用互相关分析地震信号、雷达、声纳和其他信号。将传入信号与已知模板进行比较可以帮助检测低于噪声阈值的事件、提取信息或识别特定事件。

互相关数学

对于连续函数 f f f g g g,互相关定义为:
( f ⋆ g ) ( τ ) ≜ ∫ − ∞ ∞ f ( t ) ‾ g ( t + τ ) d t (f \star g)(\tau) \triangleq \int_{-\infty}^{\infty} \overline{f(t)} g(t+\tau) d t (fg)(τ)f(t)g(t+τ)dt
等同于
( f ⋆ g ) ( τ ) ≜ ∫ − ∞ ∞ f ( t − τ ) ‾ g ( t ) d t (f \star g)(\tau) \triangleq \int_{-\infty}^{\infty} \overline{f(t-\tau)} g(t) d t (fg)(τ)f(tτ)g(t)dt
其中 f ( t ) ‾ \overline{f(t)} f(t)表示 f ( t ) f(t) f(t)的复共轭, τ \tau τ称为位移或滞后。对于高度相关的 f f f g g g,它们在特定的 τ \tau τ 处具有最大互相关性, t t t 处的 f f f 中的特征稍后也会出现在 t + τ t+\tau t+τ 处的 g g g 中。

Python互相关方式

方式1:

import math
import random

t = [i * 0.1 for i in range(100)]
signal1 = [math.sin(2 * math.pi * 2 * i) + 0.5 * math.cos(2 * math.pi * 3 * i) + random.normalvariate(0, 0.1) for i in t]
signal2 = [math.sin(2 * math.pi * 2 * i) + 0.5 * math.cos(2 * math.pi * 3 * i) + random.normalvariate(0, 0.1) for i in t]

def mean(arr):
    return sum(arr) / len(arr)

def cross_correlation(x, y):
    x_mean = mean(x)
    y_mean = mean(y)
    
    numerator = sum((a - x_mean) * (b - y_mean) for a, b in zip(x, y))
    x_sq_diff = sum((a - x_mean) ** 2 for a in x)
    y_sq_diff = sum((b - y_mean) ** 2 for b in y)
    denominator = math.sqrt(x_sq_diff * y_sq_diff)
    correlation = numerator / denominator
    
    return correlation
  
correlation = cross_correlation(signal1, signal2)
print('Correlation:', correlation)

输出:

Manual Correlation: 0.9837294963190838

方式2:

import numpy as np

t = np.arange(0, 10, 0.1)

signal1 = np.sin(2 * np.pi * 2 * t) + 0.5 * np.cos(2 * np.pi * 3 * t) + np.random.normal(0, 0.1, len(t))
signal2 = np.sin(2 * np.pi * 2 * t) + 0.5 * np.cos(2 * np.pi * 3 * t) + np.random.normal(0, 0.1, len(t))

numpy_correlation = np.corrcoef(signal1, signal2)[0, 1]
print('NumPy Correlation:', numpy_correlation)

NumPy Correlation: 0.9796920509627758

方式3:

import numpy as np

t = np.arange(0, 10, 0.1)
signal1 = np.sin(2 * np.pi * 2 * t) + 0.5 * np.cos(2 * np.pi * 3 * t) + np.random.normal(0, 0.1, len(t))
signal2 = np.sin(2 * np.pi * 2 * t) + 0.5 * np.cos(2 * np.pi * 3 * t) + np.random.normal(0, 0.1, len(t))

from scipy.stats import pearsonr

scipy_correlation, _ = pearsonr(signal1, signal2)
print('SciPy Correlation:', scipy_correlation)

SciPy Correlation: 0.9865169592702046

MATLAB互相关方式

n = 0:15;
x = 0.84.^n;
y = circshift(x, 5);
[c, lags] = xcorr(x, y);
figure;
stem(lags, c);
title('Cross-Correlation of x and y');
xlabel('Lag');
ylabel('Cross-Correlation');

lags = -15:15
c = [0.0000, 0.0000, 0.0000, ..., 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000]

MATLAB计算相关系数

x = randn(100, 1);
y = 2 * x + randn(100, 1); 
R = corrcoef(x, y);
disp('Correlation Coefficient Matrix:');
disp(R);

Correlation Coefficient Matrix:
    1.0000    0.8945
    0.8945    1.0000

👉更新:亚图跨际

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

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

相关文章

通信工程学习:什么是接入网(AN)中的CF核心功能

接入网(AN)中的CF核心功能 在通信工程中,CF(Core Function)通常指的是核心功能,它是接入网(AN)中的一个重要组成部分。CF的主要作用是将用户或业务端口的承载要求与公共传送承载进行…

一键生成中秋国风插画!FLUX中秋专属Lora的使用教程

如何在中秋节期间快速生成富有节日气氛的国风插画吗? 不需要复杂的设计技能,或者手绘功底。只需借助FLUX中秋专属Lora-中秋国风人物插画v1.0_FLUX, 就可以轻松实现一键生成精美插画,特别适合用于宣传海报、包装设计等场景。 这个…

6.接口测试加密接口(Jmeter/工具/函数助手对话框、Beanshell脚本)

一、接口测试加密接口,签名接口 1.加密算法: 可以解密的: 对称式加密(私钥加密):AES,DES,Base64 https://www.bejson.com 非对称加密(双…

编写程序模版的搭建

1 完整的程序工程有些部分组成 1.1 头文件介绍 头文件嵌套包括的功能 CCS如何找到需要的头文件 1.2 源文件 1.3 库文件 1.4 CMD文件 2 工程模板创建 2.1 获取工程模板基础文件 <

CleanMyMac X 4.15.6正式版 mac直装破解版

你知道 CleanMyMac是什么吗&#xff1f;它的字面意思为“清理我的Mac”&#xff0c;作为软件&#xff0c;那就是一款 Mac清理工具 &#xff0c;Mac OS X 系统下知名系统清理软件&#xff0c;是数以万计的Mac用户的选择。它可以流畅地与系统性能相结合&#xff0c;只需…

dubbo一

Dubbo 分布式系统的演进 SOA面向服务架构 NSA微服务架构 节点与网络 分片和冗余 分布式系统挑战 分布式系统特性与衡量标准 一致性理论 强一致性ACID CAP 弱一致性BASE 一致性算法 dubbo dubbo六大核心功能 API与SPI

【第36章】Spring Cloud之Seata分布式事务

文章目录 前言一、架构图1. 介绍2. 项目结构3. 功能描述 二、用例1. 准备1.1 系统表1.2 业务表1.3 初始化数据 2. 项目搭建2.1 项目结构2.2 主要依赖2.3 主要配置 三、主要业务代码1. 仓储服务1.1 controller1.2 service1.3 dao 2. 订单服务1.1 controller1.2 service1.3 dao 3…

对操作系统(OS)管理和进程的理解

文章目录 从冯诺依曼体系入手来了解计算机硬件部分操作系统操作系统的概念设计操作系统&#xff08;OS&#xff09;的目的对下&#xff08;硬件&#xff09;OS的管理对上如何理解系统调用 进程 在计算机系统中&#xff0c;硬件、操作系统和进程是三个至关重要的概念。它们相互协…

【数据库】MySQL内置函数

本篇分享一些在MySQL中常见的一些内置函数&#xff0c;如日期函数&#xff0c;字符串函数和数学函数&#xff0c;以方便于操作数据库中的数据。 1.日期函数 我们先整体观察一下这些函数再讲解案例 日期函数使用起来都非常就简单 获得年月日&#xff1a; select current_dat…

LocalMamba: Visual State Space Model with Windowed Selective Scan 论文总结

题目&#xff1a;LocalMamba: Visual State Space Model&#xff08;视觉状态空间模型&#xff09; with Windowed Selective Scan&#xff08;窗口化的选择扫描&#xff09; 论文&#xff1a;[2403.09338] LocalMamba: Visual State Space Model with Windowed Selective Scan…

opencv彩色图像转灰度图原理

opencv彩色图像转灰度图原理 在OpenCV中&#xff0c;将彩色图像转换为灰度图像的基本原理是使用颜色空间转换的方法。具体来说&#xff0c;OpenCV提供了cvtColor函数&#xff0c;它可以将图像从一个颜色空间转换到另一个。 对于从BGR颜色空间&#xff08;OpenCV中的默认彩色图…

少儿编程Scratch中秋节动画贺卡免费下载,让孩子轻松学编程

Scratch节日动画 – 中秋节动画贺卡免费下载-小虎鲸Scratch资源站 中秋佳节将至&#xff0c;如何让孩子在节日中既能感受到传统文化的魅力&#xff0c;又能学到编程知识&#xff1f;小虎鲸Scratch资源站特别推出了中秋节动画贺卡&#xff0c;不仅能让孩子通过简单的编程技巧制作…

【AI大模型】OpenAI API实现翻译助手场景

一、OpenAI简介 OpenAI,美国人工智能研究公司&#xff0c;是一家开放人工智能研究和部署公司&#xff0c;其使命是确保通用人工智能造福全人类 。创立于2015年12月&#xff0c;总部位于美国旧金山。现由营利性公司OpenAI LP及非营利性母公司OpenAI Inc组成。 随着2018年埃隆马…

24年云南省下半年事业单位少有人知的10个真相

云南下半年事业单位&#xff0c;已经确定了9月19号报名&#xff0c;11月2日笔试&#xff0c;关于下半年事业单位联考的一些考情&#xff0c;一次看懂: . 1⃣️专科生的岗位很多 根据过往三年的情况来看&#xff0c;云南下半年的事业单位考试&#xff0c;其实专科生有不少的岗位…

java项目之在线考试与学习交流网页平台源码(springboot)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的在线考试与学习交流网页平台。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 基于JAVA语言…

基于Springboot的校园防疫管理系统的设计与实现

文未可获取一份本项目的java源码和数据库参考。 1&#xff0e;本毕业设计&#xff08;论文&#xff09;课题应达到的目的&#xff1a; 1.1选题意义&#xff1a; 高校作为一种人群高度密集、人口来源地组成复杂的公共场所&#xff0c;一旦发生因传染病疫情导致的公共卫生安全事…

wpf触发与模板的使用示例:批量生产工具

批量生产工具 <Window x:Class"WpfM20UpdateFW.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expressio…

java项目之基于工程教育认证的计算机课程管理平台(源码+论文)

项目简介 基于工程教育认证的计算机课程管理平台的主要管理员可以管理教师&#xff0c;可以对教师信息修改删除以及查询操作&#xff1b;可以对通知公告信息进行添加&#xff0c;修改&#xff0c;删除以及查询操作&#xff1b;可以对学生信息进行添加&#xff0c;修改&#xf…

anaconda安装manim

anaconda安装manim &#xff08;安装时间2024年9月15日&#xff0c;后续版本变化再做更新&#xff09; 创建环境test 等一下我们创建一个manim项目作为试水 切换到test环境 {:height 430, :width 780} 输入以下代码 # using conda or mamba conda create -n my-manim-envi…

qt绘制时钟

代码 #include "widget.h" #include "ui_widget.h"#include <QWidget> #include <QPaintEvent> //绘图事件 #include <QDebug> //测试 #include <QPainter> //画家 #include <QPen> //笔 #include <QBrush> //画刷 …