压缩感知学习笔记(二)——MP与OMP
压缩感知初入门小白,如有错误,欢迎指正交流~
匹配追踪(MP)与正交匹配追踪(OMP)
- 原理
- 提出
- 步骤
- 匹配追踪(MP)
- 正交匹配追踪(OMP)
- 代码实现
- 结果
- 参考
原理
在上篇博文中,指出当前压缩感知中常用的重构算法,其中贪婪算法中有使用广泛的两种算法,即匹配追踪算法(Matching Pursuit,MP)和正交匹配追踪算法(Orthogonal Matching Pursuit,OMP)。本文对以上两种算法进行总结,用于存档~
提出
匹配追踪算法(MP)起初提出是基于稀疏分解,在压缩感知概念还未被提出之前,稀疏分解要解决的问题是在冗余字典A中选出k列,用这k列的线性组合近似表达待稀疏分解信号y,可以表示为y=Aθ,求θ;
而压缩感知所要解决的问题是事先存在一个θ和矩阵A,然后得到y=Aθ(压缩观测),即在已知y和A的情况下要重构θ。二者在解决的问题上基本一致,都是已知y和A求θ。
即:已知传感矩阵A={ai}(i=1,2…N),其中ai代表的是一个列向量,即每一列称作一个原子。我们认为观测向量y是由A中的原子构成,而θ即可看作是每个原子对y的贡献,即系数。而已知y和A求θ,就是求每个原子对y的贡献程度。
核心思想:二者的核心思想基本一致,即遍历字典A中的每一个原子ai,根据内积最大化的原则找到与贡献最大的原子,作为当前的匹配原子。之后从信号中减去与该原子相近的成分,对剩余部分(即残差)与其他原子求贡献,找到贡献次大的原子,依次迭代,直至满足迭代停止条件(最大次数/迭代阈值等),停止迭代。
区别:二者的区别在于同一个原子的成分是否会被重复选择。OMP保证了残差与所有选择过的原子正交,即同一个原子不会被二次选择。而MP中不能保证正交,所以会有已选择过的原子的相近成分被二次选择,增加了收敛速度。
步骤
匹配追踪(MP)
Input:传感矩阵A(MxN),观测向量y(Mx1)
Output:稀疏系数向量s(Mx1)
Step1:初始化:残差r=y,系数x[N]={0};
Step2:计算A中每个原子ai与残差r的内积<ai,r>。求出内积最大的原子ai,并记录这个原子对应的索引 i;
Step3:计算θ:系数向量θ的第i个元素θi=<ai,r>。(可以理解为残差在di这个方向上的投影);
Step4:更新残差r:更新后残差r(i+1)=当前残差ri-di*θi;
Step5:判断迭代终止条件你,不满足则转至Step2。
正交匹配追踪(OMP)
Input:传感矩阵A(MxN),观测向量y(Mx1)
Output:稀疏系数向量s(Mx1)
Step1:初始化:残差r=y,系数x[N]={0},被选择原子所构成的字典子集S=Ø(每次迭代被选中的原子添加进这个子集作为新的一列);
Step2:计算A中每个原子ai与残差r的内积<ai,r>。求出内积最大的原子ai,并记录这个原子对应的索引 i。将ai添加到字典子集S中(每迭代一次,S中就会增加一个新的原子,这个加入的新原子就是此次迭代中发现的与残差内积最大的那个原子);
Step3:计算θ:即y=Sθ的最小二乘解(最小二乘解保证了残差与选择过的原子正交)。计算得到的最小二乘解维度和S一样,是小于稀疏系数θ的维度的,这个只需要把最小二乘解中的各个元素赋值到θ的对应元素就行了(第一步中记录了被选中原子的索引,就是为了实现这个功能);
注:区别:MP稀疏系数的计算是每次迭代只计算系数向量θ中的一个元素θi;而OMP中每次都要根据新加入的原子所更新的子集字典S重新计算整个系数向量θ(θ为向量)
Step4:更新残差r:更新后残差r(i+1)=当前残差ri-Sθ;
Step5:判断迭代终止条件你,不满足则转至Step2。
代码实现
MP较为简单,这里只放上了OMP的C语言实现代码:
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include <windows.h>
#include <math.h>
#include <assert.h>//定义矩阵数据类型
typedef struct
{double **mat;int m, n;
}matrix;matrix OMP(matrix y, matrix A, int t);//为矩阵申请存储空间
void initial_mat(matrix *T, int m, int n)
{int i;(*T).mat = (double**)malloc(m * sizeof(double*));for (i = 0; i < m; i++){(*T).mat[i] = (double*)malloc(n * sizeof(double));}(*T).m = m;(*T).n = n;
}
//初始化矩阵
void initzero(matrix *T, int m, int n)
{int i, j;initial_mat(T, m, n);for (i = 0; i < m; i++){for (j = 0; j < n; j++){(*T).mat[i][j] = 0;}}
}
//释放存储空间
void destroy(matrix *T)
{int i;for (i = 0; i < (*T).m; i++){free((*T).mat[i]);}free((*T).mat);
}
//变换为单位矩阵
void set_identity_matrix(matrix m) {int i;int j;assert(m.m == m.n);for (i = 0; i < m.m; ++i) {for (j = 0; j < m.n; ++j) {if (i == j) {m.mat[i][j] = 1.0;}else {m.mat[i][j] = 0.0;}}}
}
//矩阵转置
void transpose_matrix(matrix input, matrix output)
{int i, j;assert(input.m == output.n);assert(input.n == output.m);for (i = 0; i < input.m; i++){for (j = 0; j < input.n; j++){output.mat[j][i] = input.mat[i][j];}}
}
//矩阵相乘
void multiply_matrix(matrix a, matrix b, matrix output)
{int i, j, k;assert(a.n == b.m);assert(output.m == a.m);assert(output.n == b.n);//printf("\n");for (i = 0; i < output.m; i++){for (j = 0; j < output.n; j++){output.mat[i][j] = 0.0;for (k = 0; k < a.n; k++){//printf("a%lf b%lf", a.mat[i][k], b.mat[k][j]);output.mat[i][j] += a.mat[i][k] * b.mat[k][j];}//printf("%lf ", output.mat[i][j]);}//printf("\n");}
}
/* 交换矩阵的两行 */
void swap_rows(matrix m, int r1, int r2) {double *tmp;assert(r1 != r2);tmp = m.mat[r1];m.mat[r1] = m.mat[r2];m.mat[r2] = tmp;
}
/*矩阵某行乘以一个系数 */
void scale_row(matrix m, int r, double scalar) {int i;assert(scalar != 0.0);for (i = 0; i < m.n; ++i) {m.mat[r][i] *= scalar;}
}/* Add scalar * row r2 to row r1. */
void shear_row(matrix m, int r1, int r2, double scalar) {int i;assert(r1 != r2);for (i = 0; i < m.n; ++i) {m.mat[r1][i] += scalar * m.mat[r2][i];}
}//矩阵求逆
int matrix_inversion(matrix input, matrix output)
{int i, j, r;double scalar, shear_needed;assert(input.m == input.n);assert(input.m == output.m);assert(input.m == output.n);set_identity_matrix(output);/* Convert input to the identity matrix via elementary row operations.The ith pass through this loop turns the element at i,i to a 1and turns all other elements in column i to a 0. */for (i = 0; i < input.m; ++i) {if (input.mat[i][i] == 0.0) {/* We must swap m to get a nonzero diagonal element. */for (r = i + 1; r < input.m; ++r) {if (input.mat[r][i] != 0.0) {break;}}if (r == input.m) {/* Every remaining element in this column is zero, so thismatrix cannot be inverted. */return 0;}swap_rows(input, i, r);swap_rows(output, i, r);}/* Scale this row to ensure a 1 along the diagonal.We might need to worry about overflow from a huge scalar here. */scalar = 1.0 / input.mat[i][i];scale_row(input, i, scalar);scale_row(output, i, scalar);/* Zero out the other elements in this column. */for (j = 0; j < input.m; ++j) {if (i == j) {continue;}shear_needed = -input.mat[j][i];shear_row(input, j, i, shear_needed);shear_row(output, j, i, shear_needed);}}return 1;
}
matrix OMP(matrix y, matrix A, int t)
{int M = A.m = y.m;int N = A.n;matrix s;initzero(&s, N, 1);matrix At;initzero(&At, M, t);matrix Pos_s;initzero(&Pos_s, 1, t);matrix r_n;initzero(&r_n, M, 1);//printf("\nr_n列向量:\n");for (int i = 0; i < M; i++){r_n.mat[i][0] = y.mat[i][0];//printf("%lf ", r_n.mat[i][0]);}matrix s_ls;initzero(&s_ls, t, 1);for (int d = 0; d < t; d++){matrix A_T;initzero(&A_T, N, M);transpose_matrix(A, A_T);matrix product;initzero(&product, N, 1);multiply_matrix(A_T, r_n, product);/*printf("\n product列向量:\n");for (int i = 0; i < N; i++){printf("%lf ", product.mat[i][0]);}*/int pos = 0;double max = fabs(product.mat[0][0]);for (int i = 1; i < N; i++){if (max < fabs(product.mat[i][0])){max = fabs(product.mat[i][0]);pos = i;}}//printf("\n pos:%d\n",pos);matrix Atd;initzero(&Atd, M, d+1);for (int i = 0; i < M; i++){Atd.mat[i][d] = A.mat[i][pos];}Pos_s.mat[0][d] = pos;for (int i = 0; i < M; i++){A.mat[i][pos] = 0;}matrix Atd_T;initzero(&Atd_T, d+1, M);transpose_matrix(Atd, Atd_T);matrix temp1;initzero(&temp1, d+1, d+1);multiply_matrix(Atd_T, Atd, temp1);/*printf("\n乘积:\n");for (int i = 0; i < d+1; i++){for (int j = 0; j < d+1; j++){printf("%lf ", temp1.mat[i][j]);}}*/matrix temp2;initzero(&temp2, d+1, d+1);matrix_inversion(temp1, temp2);/*printf("\n求逆:\n");for (int i = 0; i < d+1; i++){for (int j = 0; j < d+1; j++){printf("%lf ", temp2.mat[i][j]);}}*/matrix temp3;initzero(&temp3, d+1, M);multiply_matrix(temp2, Atd_T, temp3);/*printf("\n乘ATD_T:\n");for (int i = 0; i < d + 1; i++){for (int j = 0; j < M; j++){printf("%lf ", temp3.mat[i][j]);}}*/matrix s_ls_d;initzero(&s_ls_d, d + 1, 1);multiply_matrix(temp3, y, s_ls_d);/*printf("\ns:\n");for (int i = 0; i < d + 1; i++){for (int j = 0; j < 1; j++){printf("%lf ", s_ls_d.mat[i][j]);}}*/for (int i = 0; i < d + 1; i++){s_ls.mat[i][0] = s_ls_d.mat[i][0];}matrix temp4;initzero(&temp4, M, 1);multiply_matrix(Atd, s_ls_d, temp4);for (int i = 0; i < M; i++){r_n.mat[i][0] = y.mat[i][0] - temp4.mat[i][0];}}/*printf("\ns_ls:\n");for (int i = 0; i < t; i++){printf("%lf ", s_ls.mat[i][0]);}*/for (int i = 0; i < t; i++){int index = Pos_s.mat[0][i];//printf("[%d]%lf ", index, Pos_s.mat[0][i]);//printf("\n");s.mat[index][0] = s_ls.mat[i][0];//printf("[%d]%lf ",index, s_ls.mat[i][0]);}return s;
}
void main()
{matrix A;initzero(&A, 2, 5);A.mat[0][0] = 0.0591; A.mat[0][1] = -1.6258; A.mat[0][2] = 2.6052; A.mat[0][3] = 0.2570; A.mat[0][4] = -1.1464; A.mat[1][0] = -1.4669; A.mat[1][1] = -1.9648; A.mat[1][2] = 0.9724; A.mat[1][3] = -0.9742; A.mat[1][4] = 0.5476; printf("传感矩阵A:\n");for (int i = 0; i < 2; i++){for (int j = 0; j < 5; j++){printf("%lf ", A.mat[i][j]);}printf("\n");}matrix y;initzero(&y, 2, 1);y.mat[0][0] = 7.9498;y.mat[1][0] = 2.9672;printf("\n观测值y:\n");for (int i = 0; i < 2; i++){for (int j = 0; j < 1; j++){printf("%lf ", y.mat[i][j]);}printf("\n");}int t = 1;matrix s;initzero(&s, 5, 1);s = OMP(y, A, t);matrix PSi;initzero(&PSi, 5, 5);for (int i = 0; i < 5; i++){PSi.mat[i][i] = 1;}printf("\n稀疏基PSi:\n");for (int i = 0; i < 5; i++){for (int j = 0; j <5; j++){printf("%lf ", PSi.mat[i][j]);}printf("\n");}matrix x_r;initzero(&x_r, 5, 1);multiply_matrix(PSi, s, x_r);printf("\ns:\n");for (int i = 0; i < 5; i++){printf("%lf ", s.mat[i][0]);}matrix x;initzero(&x, 5, 1);x.mat[2][0] = 3.0515;printf("\n原始信号x:\n");for (int i = 0; i < 5; i++){printf("%lf ", x_r.mat[i][0]);}printf("\n恢复信号x_r:\n");for (int i = 0; i < 5; i++){printf("%lf ", x_r.mat[i][0]);}getchar();
}
结果
参考
【1】一分钟了解”匹配追踪算法(Matching Pursuit,MP) 和 正交匹配追踪算法(Orthogonal Matching Pursuit,OMP)“
【2】匹配追踪MP和正交匹配追踪OMP算法
【3】知乎:正交匹配追踪算法OMP
【4】知乎:匹配追踪算法(match pursuit, MP)实现信号的稀疏表示
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Java中static关键字的作用与用法
Java中static关键字的作用与用法...
2024/4/29 13:34:54 - pip install --index-url https://mirrors.aliyun.com/ERROR: You must give at least one requirement to
在用阿里云镜像安装pip安装第三方包时报错:ERROR: You must give at least one requirement to install (see “pip help install”) 我用了如下命令 pip install --index-url https://mirrors.aliyun.com/pypi/simple/pyecharts 但是报错: ERROR: You must give at least on…...
2024/4/29 13:34:49 - Nodejs fs中的流以及管道流
####fs.createReadStream从文件流中读取数据 const fs=require(fs);var readStream=fs.createReadStream(./data/input.txt);var count=0; var str=; readStream.on(data,(data)=>{str+=data;count++; })readStream.on(end,()=>{console.log(str);console.log(count) })r…...
2024/5/5 21:16:22 - C# 学习笔记 ---- Part 1: Array, List
1 Array 1.1 Basic 1.1.1 声明数组 datatype[] arrayName; // 例如 double[] balance;1.1.2 初始化数组 double balance = new double[10];1.1.3 赋值给数组 // 1. 通过索引赋值 double balance = new double[10]; balance[0] = 666;// 2. 声明时赋值 double[] balance = {1,.0…...
2024/4/29 13:34:41 - 王者荣耀:电竞数据【亚服数据】APP接口
王者荣耀 电竞API专用数据接口 分享使用代码 示例演示:王者荣耀【亚服数据】接口 分享使用 野子数据 http://yes-esports.com/ 电竞API数据接口调用的示例代码 具体如下: import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.annotation.JSONField; import java.…...
2024/4/29 13:34:38 - Unity 3D 正交(Orthographic)摄像机尺寸与背景自适应
在 Unity 3D 中可以把摄像机设置为正交。正交摄像机与 Unity 3D 中普通摄像机相比没有透视效果(近大远小),所以正交相机一般可以用于 2D 游戏开发或者是 3D 游戏的 UI 开发。在 2D 游戏开发中,有时会遇到根据屏幕的分辨率对游戏的背景进行自适应缩放的需求,这就需要对正交…...
2024/4/29 13:34:34 - Leetcode | 2两数相加
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。 您可以假设除了数字 0 之外,这两个数都不会以 0 开头。 示例: …...
2024/4/29 13:34:31 - 一文搞懂位运算,面试装逼不再怕
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道…...
2024/4/29 13:34:27 - 39_表格数据使用字典和列表存储 并实现访问
文章目录39.表格数据使用字典和列表存储并实现访问(重要)对于多层字典可以,可以如此取值39.表格数据使用字典和列表存储并实现访问(重要)互联网上所有的数据本质上都是表格r1 = {"name":"onepis","age":18,"salary":30000,"city&…...
2024/4/29 13:34:22 - 文件系统理论
目录4.1 文件系统的组成部分4.1.1 block的出现4.1.2 inode的出现4.1.3 bmap出现4.1.4 inode表的出现4.1.5 imap的出现4.1.6 块组的出现4.1.7 块组的划分4.2 文件系统的完整结构4.2.1 引导块4.2.2 超级块(superblock)4.2.3 块组描述符表(GDT)4.2.4 保留GDT(Reserved GDT)4.3 Dat…...
2024/4/29 13:34:18 - java学习day16异常处理
异常处理异常处理的意义什么是异常什么是错误Throwable、Exception以及Error的关系运行时异常和非运行时异常运行时异常非运行时异常异常的捕获和处理异常处理流程代码结构finally关键字try catch finally的组合异常的抛出finally和return关键字结合自定义异常 异常处理的意义 …...
2024/4/29 13:34:15 - Java面向对象理论知识理解
1、面向过程和面向对象的区别? 1-1、什么是面向过程,面向对象? 面向过程简单来说就是分析问题,梳理出一条执行流程,然后按流程编写函数执行完毕并达到目的;而面向对象则是先分析整个问题,分离出各个对象,然后用类来描述对象身上的属性和行为,属性就是指对象身上的值数…...
2024/4/29 13:34:10 - 王者荣耀:电竞数据【韩服数据】APP接口
王者荣耀 电竞API专用数据接口 分享使用代码 示例演示:王者荣耀【韩服数据】接口 分享使用 野子数据 http://yes-esports.com/ 电竞API数据接口调用的示例代码 具体如下: import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.annotation.JSONField; import java.…...
2024/4/29 13:34:06 - Redis 入门及基本命令简介
Redis:远程字典服务 特性:内存存储 效率高,用于高速缓存 地图信息分析 计时器,计数器,订阅系统redis是单线程的,基于内存操作 Redis基础命令 redis默认有16个数据库,使用select命令切换数据库 set key value //新增键值 get key //获取某一个键值 select 1 //切换数据库…...
2024/4/29 13:34:02 - 软件项目管理-第五章软件项目任务分解
1.任务分解定义 任务分解过程:将一个项目分解为更多的工作细目或者子项目,使项目变得更小、更易管理、更易操作。 任务分解结果:WBS(任务分解结构) WBS是对项目由粗到细的分解过程;面向交付成果的;WBS它组织并定义了整个项目范围。 图表式:清单形式:工作包:WBS的底层…...
2024/4/29 13:34:01 - 【Python】16进制转10进制
一个16进制整数字符串转10进制数字 import mathdef test1():#拿到16进制的列表hex= [ord(i)-55 if (i in list("ABCDEF")) else ord(i)-48 for i in input().upper()]list1=[ hex[-1-i]*math.pow(16,i) for i in range(len(hex))]return sum(list1) 参考链接https:…...
2024/4/29 13:33:54 - SPARK-SQL - group分组聚合相关的api,groupBy().count(),groupBy().avg()等
准备orders.json文件{"id":"1", "userId":"1", "userName":"Join", "totalPrice":80.0,"qty":3.0} {"id":"2", "userId":"1", "userName"…...
2024/4/29 13:33:51 - 轻量级高精度人脸检测方法DBFace简单使用
文章目录1.DBFace 简单介绍2.摄像头使用DBFace进行人脸检测3. 利用DBFace来实现《黑人抬棺》的人脸检测 1.DBFace 简单介绍 DBFace是一个轻量级的人脸检测模型,大小仅为7M,该项目在保持较少参数的同时,检测精度也能保持很高,并且只需要opencv和pytorch就能运行。 下面这个图…...
2024/4/29 13:33:47 - 08【主谓一致】Verb & Agreement
08【主谓一致】Verb & Agreement1, 基本原则 复数主语(+s) + 单数动词(不加S):Most consumers always consider ~单数主语 (不加s) + 复数动词(+s): Tom loves you ~助动词 will, can, may, must, should,没有主语的命令句,用动词原形2,除去修饰语主谓一致,找主…...
2024/4/29 2:12:22 - 什么是静态变量 举例 C语言入门
欢迎关注笔者,你的支持是持续更博的最大动力目录相关描述代码举例其他 相关描述 局部变量:定义在函数内部的变量(函数的形参也是局部变量),只能在定义它的函数内部使用 全局变量:定义在函数外面的变量,所有函数都可以使用 静态变量:有全局变量、前面加了“static”关键…...
2024/5/5 2:49:18
最新文章
- 【Transformer系列(1)】self-attention自注意力
一、self-attention流程 自注意力机制和注意力机制的区别在于,注意力机制中的Q(查询向量),K(键向量),V(值向量)是同源的,而一般的注意力机制,Q和…...
2024/5/6 0:40:47 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - 前端 js 经典:字符编码详解
前言:计算机只能识别二进制,开发语言中数据类型还有数字,字母,中文,特殊符号等,都需要转化成二进制编码才能让技术机识别。 一. 编码方式 ACSLL、Unicode、utf-8、URL 编码、base64 等。 1. ACSLL 对英语…...
2024/5/4 10:30:35 - 流域生态系统水-碳-氮耦合过程模拟
流域是一个相对独立的自然地理单元,它是以水系为纽带,将系统内各自然地理要素连结成一个不可分割的整体。碳和氮是陆地生态系统中最重要的两种化学元素,而在流域系统内,水-碳-氮是相互联动、不可分割的耦合体。随着流域内人类活动…...
2024/5/5 8:45:42 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/5 18:19:03 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/5 12:22:20 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/5 19:59:54 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/4 23:54:44 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/5/5 15:25:47 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/5/4 23:54:49 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/4 23:54:44 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/4 14:46:12 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/5 18:50:00 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/6 0:27:44 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/5/5 2:25:33 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/4 21:24:42 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/5 13:14:22 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/5/4 13:16:06 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/5 17:03:52 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/5 21:10:50 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/5 3:37:58 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/4 23:54:30 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/5 17:03:21 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/5 15:25:31 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57