在这里对从零手写VIO的第二次作业进行总结:
作业题目:
在这里插入图片描述

1仿真代码解析

仿真代码地址:https://github.com/HeYijia/vio_data_simulation
该github仓库中除了提供了普通版本的仿真代码外,还提供了ROS版本的仿真代码,用于生成img.bag,以供后面使用Allan方差工具进行标定。

1.1编译vio_data_simulation-master

首先是编译这个普通版本的仿真代码,就是按编译的常规套路来:

git clone https://github.com/HeYijia/vio_data_simulation
cd vio_data_simulation
mkdir build
cd build
camke ..
make
cd ../bin
./data_gen

这样就生成我们所需的:

imu_pose_noise.txt ,imu_pose.txt ,imu_int_pose_noise.txt, imu_int_pose.txt

等数据。

使用python-tool下的Python脚本,可以绘制处点,IMU轨迹等

cd ../python_tool
python draw_trajctory.py

1.2仿真思路

指定轨迹方程,求一阶导得到速度, 角速度,求二阶导得到加速度。对加速度角速度添加高斯白噪声和bias 的随机游走噪声,得到仿真数据。

1.3运动模型

在该仿真代码中,在imu.cpp中定义了IMU的运动模型:

MotionData IMU::MotionModel(double t)
{MotionData data;// paramfloat ellipse_x = 15;float ellipse_y = 20;float z = 1;           // z轴做sin运动float K1 = 10;          // z轴的正弦频率是x,y的k1倍float K = M_PI/ 10;    // 20 * K = 2pi   由于我们采取的是时间是20s, 系数K控制yaw正好旋转一圈,运动一周// translation world系下 因为IMU的position就是body系在world系下的坐标// twb:  body frame in world frameEigen::Vector3d position( ellipse_x * cos( K * t) + 5, ellipse_y * sin( K * t) + 5,  z * sin( K1 * K * t ) + 5);Eigen::Vector3d dp(- K * ellipse_x * sin(K*t),  K * ellipse_y * cos(K*t), z*K1*K * cos(K1 * K * t));              // position导数 in world framedouble K2 = K*K;Eigen::Vector3d ddp( -K2 * ellipse_x * cos(K*t),  -K2 * ellipse_y * sin(K*t), -z*K1*K1*K2 * sin(K1 * K * t));     // position二阶导数// Rotation double k_roll = 0.1;double k_pitch = 0.2;// body系下的角度Eigen::Vector3d eulerAngles(k_roll * cos(t) , k_pitch * sin(t) , K*t );   // roll ~ [-0.2, 0.2], pitch ~ [-0.3, 0.3], yaw ~ [0,2pi]// 对欧拉角进行求导,得到world系下的欧拉角速度Eigen::Vector3d eulerAnglesRates(-k_roll * sin(t) , k_pitch * cos(t) , K);      // euler angles 的导数//    Eigen::Vector3d eulerAngles(0.0,0.0, K*t );   // roll ~ 0, pitch ~ 0, yaw ~ [0,2pi]
//    Eigen::Vector3d eulerAnglesRates(0.,0. , K);      // euler angles 的导数Eigen::Matrix3d Rwb = euler2Rotation(eulerAngles);         // body frame to world frameEigen::Vector3d imu_gyro = eulerRates2bodyRates(eulerAngles) * eulerAnglesRates;   //  euler rates trans to body gyroEigen::Vector3d gn (0,0,-9.81);                                   //  gravity in navigation frame(ENU)   ENU (0,0,-9.81)  NED(0,0,9,81)Eigen::Vector3d imu_acc = Rwb.transpose() * ( ddp -  gn );  //  Rbw * Rwn * gn = gsdata.imu_gyro = imu_gyro;   // body系下的角速度data.imu_acc = imu_acc;     // body系下的加速度data.Rwb = Rwb;             //IMU的位姿数据使用Twb进行存储data.twb = position;data.imu_velocity = dp;     // IMU的速度 world系data.timestamp = t;         // 时间戳return data;}

可以看到,指定的IMU轨迹方程Position比较简单,大致能想出它的样子,大概是一个“王冠”的样子它在xy面投影为圆心(-5,,5)的圆。同时IMU也在以自身坐标系下做旋转运动,以欧拉角表示其旋转,该旋转也是一个随时间变化的函数。

对Position进行一阶导和二阶导,分别得到IMU在世界坐标系下的速度和加速度。对Rotation进行一阶导,得到IMU在body系下的角速度。利用这些值,我们最终得到了IMU的MotionData:

	data.imu_gyro = imu_gyro;   // body系下的角速度data.imu_acc = imu_acc;     // body系下的加速度data.Rwb = Rwb;             //IMU的位姿数据使用Twb进行存储data.twb = position;data.imu_velocity = dp;     // IMU的速度 world系data.timestamp = t;         // 时间戳

1.4添加噪声

设定,加速度的高斯白噪声设定为 0.019, 陀螺仪的高斯白噪声为 0.015. 加速度 bias 的随机游走噪声设定为 5e−4 ,陀螺仪的 bias 随机游走噪声设定为 5e−5 。

void IMU::addIMUnoise(MotionData& data)
{std::random_device rd;std::default_random_engine generator_(rd());std::normal_distribution<double> noise(0.0, 1.0);// gyroEigen::Vector3d noise_gyro(noise(generator_),noise(generator_),noise(generator_));// 生成一个高斯白噪声Eigen::Matrix3d gyro_sqrt_cov = param_.gyro_noise_sigma * Eigen::Matrix3d::Identity();  // 感觉这里可有可无// w = w + ng + bg, 其中ng = σd*n, n~N(0,1),σd = σ/sqrt(Δt)  ,bg会在下面单独更新data.imu_gyro = data.imu_gyro + gyro_sqrt_cov * noise_gyro / sqrt( param_.imu_timestep ) + gyro_bias_;// accEigen::Vector3d noise_acc(noise(generator_),noise(generator_),noise(generator_));Eigen::Matrix3d acc_sqrt_cov = param_.acc_noise_sigma * Eigen::Matrix3d::Identity();// // a = a + na + ba, 其中na = σd*n, n~N(0,1),σd = σ/sqrt(Δt)  ,ba会在下面单独更新data.imu_acc = data.imu_acc + acc_sqrt_cov * noise_acc / sqrt( param_.imu_timestep ) + acc_bias_;// gyro_bias updateEigen::Vector3d noise_gyro_bias(noise(generator_),noise(generator_),noise(generator_));// bg = σd*n, n~N(0,1), σd = σ*sqrt(Δt)gyro_bias_ += param_.gyro_bias_sigma * sqrt(param_.imu_timestep ) * noise_gyro_bias;data.imu_gyro_bias = gyro_bias_;// acc_bias updateEigen::Vector3d noise_acc_bias(noise(generator_),noise(generator_),noise(generator_));// ba = σd*n, n~N(0,1), σd = σ*sqrt(Δt)acc_bias_ += param_.acc_bias_sigma * sqrt(param_.imu_timestep ) * noise_acc_bias;data.imu_acc_bias = acc_bias_;}

在这里我们只考虑了高斯白噪声和 bias 随机游走,需要注意两者的计算:

w = w + ng + bg, 其中ng = σdn, n~N(0,1),σd = σ/sqrt(Δt) , bg = σdn, n~N(0,1), σd = σsqrt(Δt)
a = a + na + ba, 其中na = σd
n, n~N(0,1),σd = σ/sqrt(Δt), ba = σdn, n~N(0,1), σd = σsqrt(Δt)

因为IMU获取的数据都是离散数据,注意高斯白噪声方差从连续时间到离散时间需要乘以一个1/sqrt(Δt),随机游走的噪声方差从连续时间到离散之间需要乘以一个sqrt(Δt),Δt为传感器的采样时间。

至此我们获得了IMU的仿真数据,主要是IMU在body系下的位姿数据:
imu_pose_noise.txt
imu_pose.txt

1.5运动模型的离散积分

在实际应用中,因为IMU的频率远远大于相机频率,所以我们往往需要对IMU离散数据进行积分,使IMU数据与相机数据对齐。
这次就利用上面得到的IMU的离散仿真数据,使用欧拉积分和中值积分,比较两种积分的的效果。(通过比较积分后的轨迹imu_int_pose.txt是否和积分前的轨迹imu_pose.txt重合)

1.5.1欧拉积分

在这里插入图片描述
代码:

for (int i = 1; i < imudata.size(); ++i) {MotionData imupose = imudata[i];//delta_q = [1 , 1/2 * thetax , 1/2 * theta_y, 1/2 * theta_z]Eigen::Quaterniond dq;Eigen::Vector3d dtheta_half = imupose.imu_gyro * dt / 2.0;dq.w() = 1;dq.x() = dtheta_half.x();dq.y() = dtheta_half.y();dq.z() = dtheta_half.z();/// imu 动力学模型 欧拉积分Eigen::Vector3d acc_w = Qwb * (imupose.imu_acc) + gw;  // aw = Rwb * ( acc_body - acc_bias ) + gwQwb = Qwb * dq;Pwb = Pwb + Vw * dt + 0.5 * dt * dt * acc_w;Vw = Vw + acc_w * dt;// 按着imu postion, imu quaternion , cam postion, cam quaternion 的格式存储,由于没有cam,所以imu存了两次save_points << imupose.timestamp << " "<< Qwb.w() << " "<< Qwb.x() << " "<< Qwb.y() << " "<< Qwb.z() << " "<< Pwb(0) << " "<< Pwb(1) << " "<< Pwb(2) << " "<< Qwb.w() << " "<< Qwb.x() << " "<< Qwb.y() << " "<< Qwb.z() << " "<< Pwb(0) << " "<< Pwb(1) << " "<< Pwb(2) << " "<< std::endl;}

效果:
在这里插入图片描述

1.5.2中值积分

在这里插入图片描述
代码:

for (int i = 1; i < imudata.size(); ++i){MotionData imupose_pre = imudata[i-1];MotionData imupose_now = imudata[i];MotionData imupose_mean = imudata[i];imupose_mean.imu_gyro = (imupose_pre.imu_gyro + imupose_now.imu_gyro) / 2.0;Eigen::Quaterniond dq;Eigen::Vector3d dtheta_half = (imupose_mean.imu_gyro) * dt / 2.0;dq.w() = 1;dq.x() = dtheta_half.x();dq.y() = dtheta_half.y();dq.z() = dtheta_half.z();// imu 动力学模型 参考svo预积分论文Eigen::Vector3d acc_w = Qwb * (imupose_pre.imu_acc) + gw;  // aw = Rwb * ( acc_body - acc_bias ) + gwQwb = Qwb * dq; //获得Qwb_k+1//Qwb+1Eigen::Vector3d acc_w1 = Qwb * (imupose_now.imu_acc) + gw;  // aw = Rwb * ( acc_body - acc_bias ) + gwacc_w = (acc_w + acc_w1) / 2.0;//a updateVw = Vw + acc_w * dt;//Pwb updatePwb = Pwb + Vw * dt + 0.5 * dt * dt * acc_w;// 按着imu postion, imu quaternion , cam postion, cam quaternion 的格式存储,由于没有cam,所以imu存了两次save_points << imupose_mean.timestamp << " "<< Qwb.w() << " "<< Qwb.x() << " "<< Qwb.y() << " "<< Qwb.z() << " "<< Pwb(0) << " "<< Pwb(1) << " "<< Pwb(2) << " "<< Qwb.w() << " "<< Qwb.x() << " "<< Qwb.y() << " "<< Qwb.z() << " "<< Pwb(0) << " "<< Pwb(1) << " "<< Pwb(2) << " "<< std::endl;}

效果:
在这里插入图片描述
很明显,中值积分的效果要好于欧拉积分,当然,这是显而易见的,根据原理我们就能看出:
在这里插入图片描述

2ROS版的IMU仿真代码

2.1 下载编译

下载编译:

mkdir vio_sim_ws/src
cd src
git clone https://github.com/HeYijia/vio_data_simulation
git checkout ros_version
catkin_make

2.2 生成imu.bag

首先,打开catkin_ws_vio_data_simulation/src/vio_data_simulation-ros_version/src/gener_alldata.cpp,设置imu.bag的存储路径。

bag.open("/your-path/imu.bag", rosbag::bagmode::Write);

然后,启动节点,生成imu.bag。

source devel/setup.bash
rosrun vio_data_simulation vio_data_simulation_node

至此,我们得到了一个IMU仿真数据的ROS bag包。接下来利用Allan方差工具对其进行标定。

3使用Allan方差工具标定

主要是使用imu_utils和kalibr_allan进行标定。

3.1 使用imu_utils标定

3.1.1 安装im_utils

首先,安装依赖:

sudo apt-get install libdw-dev

先编译code_utils,然后再编译imu_utils

mkdir -p imu-calibration/src
cd imu-calibration/src
git clone https://github.com/gaowenliang/code_utils.git
cd ..
catkin_make
cd imu-calibration/src
git clone https://github.com/gaowenliang/imu_utils.git
cd ..
catkin_make

中间出现的问题:
错误1:找不到Eigen
我们一般通过以下命令安装Eigen:

sudo apt-get install libeigen3-dev

这样Eigen就默认安装在/usr/include/eigen3,需要在/home/jlg/imu-calibration/src/code_utils/CMakeLists.txt中注释掉find_package(Eigen3 REQUIRED),然后添加:

include_directories(/usr/include/eigen3)

错误2:找不到backward.hpp

atal error: backward.hpp: No such file or directory

把文件code_utils/src/sumpixel_test.cpp中的#include "backward.hpp"改成#include "code_utils/backward.hpp"即可。

错误3:std::ofstream未定义

/home/***/imu-calibration/src/imu_utils/src/imu_an.cpp:69:19: error:
aggregate ‘std::ofstream out_t’ has incomplete type and cannot be
defined

打开文件imu_utils/src/imu_an.cpp,添加:

#include <fstream>

这里参考了:https://blog.csdn.net/learning_tortosie/article/details/102415313
事实上,可能是运气好,我没有碰到这些问题,但是还是记录一下,以防万一。

3.1.2 标定

  1. 采集IMU数据
    这里的IMU数据就使用我们上面生成的imu.bag。当然作者也提供了几个包,可以先测试一下。
    在这里插入图片描述
    可以看到,我们之前生成的img.bag,topic为imu, 大概大概四个小时的时长。
  2. 写launch文件
    可以参考launch文件夹下作者写的几个launch文件,根据自己imu的topic和name进行修改:
<launch><node pkg="imu_utils" type="imu_an" name="imu_an" output="screen"><param name="imu_topic" type="string" value= "/imu"/><param name="imu_name" type="string" value= "mems"/><param name="data_save_path" type="string" value= "$(find imu_utils)/data/"/><param name="max_time_min" type="int" value= "120"/><param name="max_cluster" type="int" value= "100"/></node>
</launch>

比如我这里就修改了imu_topic所对应的value:/imu,imu_name所对应的value:mems,另外要记得把launch文件名改成imu_name,我这里就是mems.launch。

  1. 生成Allan方差数据
    启动刚才的launch文件
cd imu-calibration
source./devel/setup.bash
roslaunch imu_utils mems.launch

在这里插入图片描述
新打开一个terminal窗口,以200倍速播放imu.bag

rosbag play -r 200 imu.bag

要注意,这里 img.bag要带上你存放的路径:yourpath/imu.bag

过一段时间(15s左右?),就会在data文件夹下生成一些数据:

在这里插入图片描述
以及一个mems_imu_param.yaml:

%YAML:1.0
---
type: IMU
name: mems
Gyr:unit: " rad/s"avg-axis:gyr_n: 2.1221203233760574e-01gyr_w: 8.9467924142534435e-04x-axis:gyr_n: 2.1046384179740413e-01gyr_w: 8.0473827758366584e-04y-axis:gyr_n: 2.1360563530391058e-01gyr_w: 9.2214122848867288e-04z-axis:gyr_n: 2.1256661991150250e-01gyr_w: 9.5715821820369432e-04
Acc:unit: " m/s^2"avg-axis:acc_n: 2.6764053623067113e-01acc_w: 3.6174135533268148e-03x-axis:acc_n: 2.6811296473220231e-01acc_w: 3.6652237104732588e-03y-axis:acc_n: 2.6789918945541225e-01acc_w: 3.7987720199202969e-03z-axis:acc_n: 2.6690945450439874e-01acc_w: 3.3882449295868896e-03
  1. 绘制Allan方差图
    修改 draw_allan.m中文件路径
    在这里插入图片描述
    将这几个路径都改为刚刚生成的数据的路径,然后运行drawn_allan.m
    在这里插入图片描述
    需要注意的是,纵坐标的单位是deg/h。
    对该图的理解,可以参考:
    https://www.cl.cam.ac.uk/techreports/UCAM-CL-TR-696.pdf
    https://www.vectornav.com/support/library/gyroscope
    对图进行分析即可得到加速度和角速度的高斯白噪声和游走Bias误差
    t =1 的时候索对应的纵坐标值就是高斯白噪声
    t=3的时候对应的纵坐标就是游走Bias误差。
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 考研二战日记-第27天——高数4.4几种特殊类型函数的积分

    ...

    2024/4/24 13:12:50
  2. 华南农业大学 汇编考试题型总结 2020年 题库版(简答题)

    简答题 考点考移位 考乘除运算 考串指令 考访存 考程序理解(大小写,排序,字符筛选…)1. 考移位下面程序段执行后,寄存器BX的值是多少?MOV BX,25 PUSH BX MOV CL,4 SHL BX,CL POP AX SUB BX,AX BX的值为375执行下面的程序段后,AX寄存器的内容是多少?MOV AX,1234H…...

    2024/4/24 13:12:49
  3. 死锁与多线程通信问题

    死锁 死锁的情况通常发生于两边的线程都需要对面的运行结果才能继续运行. 示例 public static void main(String[] args) {Criminal c = new Criminal();Police p = new Police();Mythread thread = new Mythread(c,p);thread.start();// 警察喊话c.say(p);// 罪犯喊话}static …...

    2024/4/15 4:09:17
  4. 最小重量机器设计问题-分支限界法-队列式(FIFO)

    问题描述:设某一机器由n个部件组成,每一种部件都可以从m个不同的供应商处购得。设 w[i][j] 是从供应商j处够来的部件i的重量,c[i][j] 是相应的价格。 #include<iostream> using namespace std;struct HeadNode //节点模拟 {int cost; //当前节点的花费int weight; …...

    2024/4/15 4:09:16
  5. [C++]——位图上下反向

    实现方法介绍 1.已经知道位图的高度是从第22个字节开始,那么先把指针移动到该位置; 2.将位图的高度读取出来; 3.再讲指针移回去; 4.直接将高度值赋值为负数; 5.将改完之后的值写入图片中; 代码 #include <iostream> #include <windows.h> using namespace st…...

    2024/4/15 4:09:15
  6. 下一个排列

    实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。必须原地修改,只允许使用额外常数空间。以下是一些例子,输入位于左侧列,其相应输出位于右侧列。 1,2,3 →…...

    2024/5/2 3:48:48
  7. Python——深拷贝与浅拷贝

    s1 = 你好 s2 = s1print(id(s1)) print(id(s2))>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 2118051305672 2118051305672变量之间赋值相当于C++引用a = [c1, c2] for b in a:pri…...

    2024/4/15 4:09:14
  8. [C++学习笔记] 2-2 面向对象语言的发展历程

    目录1. 早期程序设计语言的历史2. C++语言的历史3. C++标准的发展1. 早期程序设计语言的历史2. C++语言的历史3. C++标准的发展站在巨人的肩上 【1】北京大学信息技术学院《程序设计实习》...

    2024/5/2 14:19:35
  9. Kafka核心源码解析 - SocketServer源码解析

    1.初始化和启动 SocketServer var socketServer: SocketServer = null 。。。 // Create and start the socket server acceptor threads so that the bound port is known. // Delay starting processors until the end of the initialization sequence to ensure // that cre…...

    2024/4/25 23:26:29
  10. STM32数模转换器简介

    Analog-to-Digital Converter(ADC), 模/数转换器。是指将连续变量的模拟信号转换为离散的数字信 号的器件。典型的ADC将模拟信号转换为表示一定比例电压值的数字信号。 电压输入范围 • ADC 输入范围为:VREF- ≤ VIN ≤ VREF+。由VREF-、VREF+ 、VDDA 、VSSA、 这四个外部引脚…...

    2024/4/15 4:09:10
  11. 【Linux】第二章 Linux系统ubuntu安装与更新

    Ubuntu是一个以桌面应用为主的Linux操作系统。虚拟机安装虚拟机可以说是一种软件,也可以说是一种技术,它允许你在一台主机上虚拟出多台计算机,每台虚拟的计算机都可以有自己的硬件及软件配置。目前,市场上使用最为广泛的三种虚拟机为:VMware、Vartual PC、Vartual Box。优…...

    2024/4/24 13:12:48
  12. 将SpringBoot Jar包打成Docker镜像

    将SpringBoot Jar包打成Docker镜像前言项目打包制作Docker镜像查看及运行Docker镜像访问接口 前言 先说下大概流程,我这边使用SpringBoot构建项目,直接打成Jar包,运行在Linux上的8082端口,将Jar包名字修改为docker-package.jar,把Jar包上传后在同级目录下创建Dockerfile文…...

    2024/4/24 13:12:47
  13. Linux基础整理---1

    一、目录和文件管理1. ls (list)功能描述:显示目录下的项目常用选项:-a 显示所有文件,包括隐藏文件(隐藏文件不是不想让人看到,二十bioashi该文件是系统中重要的文件,不是必须,不要 动它)。-i 显示文件的ID,long:…...

    2024/4/24 13:12:46
  14. F2. Flying Sort 区间dp

    F2. Flying Sort 题意:给定n个数,n个数可能有相同的,每次操作只能选择一个数,将它放在这个数组的首位或者尾部,询问你最少需要进行多少次操作能够让这个数组非递减。 题解:首先离散化一下,然后定义dp[i]代表全选a[i]的最长子序列的长度,定义子序列:子序列之外的元素都…...

    2024/4/24 13:12:50
  15. 分布式事务还是MQ?强一致性还是最终一致性?

    文章目录一、单机事务的延伸二、九十年代的XA事务XA事务原理三、常见的分布式事务方案事务补偿本地消息表消息队列四、分布式事务框架SeataAT模式TCC模式SAGA模式XA模式 一、单机事务的延伸 所谓单机事务,可以理解为单体应用和数据库这两个东西之间实现原子操作的一种方式,其…...

    2024/4/30 2:07:14
  16. 每个网站设计师都应该参考或者访问的几个网站

    令人赞叹的网站设计!!! 真的是太棒了,以下的这些网站。不论是在动态交互,动漫,设计等方面都做得太好了。 https://www.rouserlab.com/about/ https://theyearofgreta.com/ https://useplink.com/en/ https://numbered.studio/ http://www.amandabraga.com/ https://5scon…...

    2024/4/24 13:12:43
  17. 毕设代码讲解

    后端java 注解 @Entity 表示这是一个实体类 @Table(name=“user”) 表示对应的表名是 user @JsonIgnoreProperties({ “handler”,“hibernateLazyInitializer” })为了简化对数据库的操作,我们使用了 Java Persistence API(JPA),对于 @JsonIgnoreProperties({ “handler”…...

    2024/4/26 6:52:33
  18. IOS开发之——超级猜图之放大图片(43)

    一 概述本文要实现超级猜图程序,包含以下功能:根据图片猜名字,猜对了金币增加进入下一题,猜错了金币减少,并且名字变红提示:提示当前题目的第一个字大图:放大图片,点击其他位置缩小图片下一题:跳过当前题目<!--more-->二 功能演示(大图)点击大图按钮,图片放大,…...

    2024/4/24 13:12:41
  19. nvidia-smi每0.1s实时显示显存使用情况,且数字变化处有白底

    nvidia-smi每0.1s实时显示显存使用情况,且数字变化处有白底watch -n 0.1 -d nvidia-smi #每隔0.1秒刷新一次当然别的命令也可以用watch...

    2024/4/24 13:12:40
  20. 手把手带你入门SQL语言--01数据库分类及SQL的类型

    这里写目录标题一.数据库简介及分类1.1 数据库的简介1.2 数据库的分类二.MySQL介绍2.1 mySQL登入登出操作2.2 SQL语句常用类型2.3 SQL的数据类型 【微信公众号offerNeed 】 大量公司内推信息,还有互联网半导体技术产品交流群,欢迎关注! 一.数据库简介及分类 SQL其实是一种结…...

    2024/4/24 13:12:39

最新文章

  1. 【经典算法】LeetCode112. 路径总和(Java/C/Python3/Go实现含注释说明,Easy)

    作者主页&#xff1a; &#x1f517;进朱者赤的博客 精选专栏&#xff1a;&#x1f517;经典算法 作者简介&#xff1a;阿里非典型程序员一枚 &#xff0c;记录在大厂的打怪升级之路。 一起学习Java、大数据、数据结构算法&#xff08;公众号同名&#xff09; ❤️觉得文章还…...

    2024/5/2 19:11:41
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 二维相位解包理论算法和软件【全文翻译- 掩码(3.4)】

    本节我们将研究从质量图中提取掩码的问题。掩码是一个质量图,其像素只有两个值:0 或 1。零值像素标志着质量最低的相位值,这些相位值将被屏蔽、零权重或忽略。第 5 章中的某些 L/ 正则算法需要使用掩码来定义零权重。掩码还可用于某些路径跟踪算法,如第 4.5 节中将要介绍的…...

    2024/4/23 7:43:06
  4. Nginx配置文件修改结合内网穿透实现公网访问多个本地web站点

    文章目录 1. 下载windows版Nginx2. 配置Nginx3. 测试局域网访问4. cpolar内网穿透5. 测试公网访问6. 配置固定二级子域名7. 测试访问公网固定二级子域名 1. 下载windows版Nginx 进入官方网站(http://nginx.org/en/download.html)下载windows版的nginx 下载好后解压进入nginx目…...

    2024/5/1 13:14:34
  5. Jmeter02-1:参数化组件CVS

    目录 1、Jmeter组件&#xff1a;参数化概述 1.1 是什么&#xff1f; 1.2 为什么&#xff1f; 1.3 怎么用&#xff1f; 2、Jmeter组件&#xff1a;参数化实现之CSV Data Set Config(重点中重点) 2.1 是什么&#xff1f; 2.2 为什么&#xff1f; 2.3 怎么用&#xff1f; …...

    2024/5/1 13:53:24
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/2 16:16:39
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/2 9:28:15
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/2 15:04:34
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; 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
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在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