骨架提取是将二值图像减少到1像素宽的表示。这对于特征提取和(或)表示对象的拓扑结构非常有用。

# pip install scikit-image
from skimage.morphology import skeletonize
from skimage import data
import matplotlib.pyplot as plt
from skimage.util import invert# Invert the horse image
image = invert(data.horse())# perform skeletonization
skeleton = skeletonize(image)# display results
fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(8, 4),sharex=True, sharey=True)ax = axes.ravel()ax[0].imshow(image, cmap=plt.cm.gray)
ax[0].axis('off')
ax[0].set_title('original', fontsize=20)ax[1].imshow(skeleton, cmap=plt.cm.gray)
ax[1].axis('off')
ax[1].set_title('skeleton', fontsize=20)fig.tight_layout()
plt.show()

在这里插入图片描述

1.张的方法与李的方法

skeletonize的工作原理是连续遍历图像,移除对象边界上的像素。这一直持续到无法移除更多像素为止。该图像与一个掩码相关联,该掩码为每个像素分配一个 [0…255] 范围内的数字,对应于其 8 个相邻像素的每个可能模式。然后使用查找表为像素分配值 0、1、2 或 3,这些值在迭代过程中被有选择地删除。

skeletonize(..., method='lee')使用八叉树数据结构来检查像素的3x3x3邻域。该算法通过迭代扫过图像,并在每次迭代中删除像素,直到图像停止变化。每个迭代包含两个步骤:首先,将候选删除列表组装起来;然后从这个列表中的像素顺序重新检查,以更好地保持图像的连通性。

请注意,Lee 的方法旨在用于 3-D 图像,并且会自动为这些图像选择。出于说明目的,我们将此算法应用于二维图像。

import matplotlib.pyplot as plt
from skimage.morphology import skeletonizeblobs = data.binary_blobs(200, blob_size_fraction=.2,volume_fraction=.35, seed=1)skeleton = skeletonize(blobs)
skeleton_lee = skeletonize(blobs, method='lee')fig, axes = plt.subplots(1, 3, figsize=(8, 4), sharex=True, sharey=True)
ax = axes.ravel()ax[0].imshow(blobs, cmap=plt.cm.gray)
ax[0].set_title('original')
ax[0].axis('off')ax[1].imshow(skeleton, cmap=plt.cm.gray)
ax[1].set_title('skeletonize')
ax[1].axis('off')ax[2].imshow(skeleton_lee, cmap=plt.cm.gray)
ax[2].set_title('skeletonize (Lee 94)')
ax[2].axis('off')fig.tight_layout()
plt.show()

在这里插入图片描述

2.中轴骨架化

对象的中轴是在对象边界上有一个以上最近点的所有点的集合。它通常被称为拓扑骨架,因为它是对象的 1 像素宽的骨架,与原始对象具有相同的连通性。 在这里,我们使用中轴变换来计算前景对象的宽度。由于函数 medial_axis 除中轴外还返回距离变换(使用关键字参数 return_distance=True),因此可以使用此函数计算中轴所有点到背景的距离。这给出了对象局部宽度的估计。 对于分支较少的骨架,应该首选skeletonize

from skimage.morphology import medial_axis, skeletonize# Generate the data
blobs = data.binary_blobs(200, blob_size_fraction=.2,volume_fraction=.35, seed=1)# Compute the medial axis (skeleton) and the distance transform
skel, distance = medial_axis(blobs, return_distance=True)# Compare with other skeletonization algorithms
skeleton = skeletonize(blobs)
skeleton_lee = skeletonize(blobs, method='lee')# Distance to the background for pixels of the skeleton
dist_on_skel = distance * skelfig, axes = plt.subplots(2, 2, figsize=(8, 8), sharex=True, sharey=True)
ax = axes.ravel()ax[0].imshow(blobs, cmap=plt.cm.gray)
ax[0].set_title('original')
ax[0].axis('off')ax[1].imshow(dist_on_skel, cmap='magma')
ax[1].contour(blobs, [0.5], colors='w')
ax[1].set_title('medial_axis')
ax[1].axis('off')ax[2].imshow(skeleton, cmap=plt.cm.gray)
ax[2].set_title('skeletonize')
ax[2].axis('off')ax[3].imshow(skeleton_lee, cmap=plt.cm.gray)
ax[3].set_title("skeletonize (Lee 94)")
ax[3].axis('off')fig.tight_layout()
plt.show()

在这里插入图片描述

3.形态学细化

thin 函数中实现的形态学细化与骨架化的工作原理相同:在每次迭代时从边界移除像素,直到在不改变连通性的情况下无法移除任何像素。不同的移除规则可以加速骨架化并导致不同的最终骨架。

thin 函数还采用可选的 max_num_iter 关键字参数来限制细化迭代的次数,从而产生相对较厚的骨架。

from skimage.morphology import skeletonize, thinskeleton = skeletonize(image)
thinned = thin(image)
thinned_partial = thin(image, max_num_iter=25)fig, axes = plt.subplots(2, 2, figsize=(8, 8), sharex=True, sharey=True)
ax = axes.ravel()ax[0].imshow(image, cmap=plt.cm.gray)
ax[0].set_title('original')
ax[0].axis('off')ax[1].imshow(skeleton, cmap=plt.cm.gray)
ax[1].set_title('skeleton')
ax[1].axis('off')ax[2].imshow(thinned, cmap=plt.cm.gray)
ax[2].set_title('thinned')
ax[2].axis('off')ax[3].imshow(thinned_partial, cmap=plt.cm.gray)
ax[3].set_title('partially thinned')
ax[3].axis('off')fig.tight_layout()
plt.show()

在这里插入图片描述

4.ZHANG-SUEN 图像骨架提取算法的原理和OPENCV实现

该算法每一次的迭代步骤是对符合特定条件的目标像素进行腐蚀,效果就是目标变得越来越细。不断的迭代,直到在上一次的腐蚀后的目标在本轮操作中,没有新的像素点被腐蚀,算法结束。
在这里插入图片描述

#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;void thinImage(Mat & srcImg) {vector<Point> deleteList;int neighbourhood[9];int nl = srcImg.rows;int nc = srcImg.cols;bool inOddIterations = true;while (true) {for (int j = 1; j < (nl - 1); j++) {uchar* data_last = srcImg.ptr<uchar>(j - 1);uchar* data = srcImg.ptr<uchar>(j);uchar* data_next = srcImg.ptr<uchar>(j + 1);for (int i = 1; i < (nc - 1); i++) {if (data[i] == 255) {int whitePointCount = 0;neighbourhood[0] = 1;if (data_last[i] == 255) neighbourhood[1] = 1;else  neighbourhood[1] = 0;if (data_last[i + 1] == 255) neighbourhood[2] = 1;else  neighbourhood[2] = 0;if (data[i + 1] == 255) neighbourhood[3] = 1;else  neighbourhood[3] = 0;if (data_next[i + 1] == 255) neighbourhood[4] = 1;else  neighbourhood[4] = 0;if (data_next[i] == 255) neighbourhood[5] = 1;else  neighbourhood[5] = 0;if (data_next[i - 1] == 255) neighbourhood[6] = 1;else  neighbourhood[6] = 0;if (data[i - 1] == 255) neighbourhood[7] = 1;else  neighbourhood[7] = 0;if (data_last[i - 1] == 255) neighbourhood[8] = 1;else  neighbourhood[8] = 0;for (int k = 1; k < 9; k++) {whitePointCount += neighbourhood[k];}if ((whitePointCount >= 2) && (whitePointCount <= 6)) {int ap = 0;if ((neighbourhood[1] == 0) && (neighbourhood[2] == 1)) ap++;if ((neighbourhood[2] == 0) && (neighbourhood[3] == 1)) ap++;if ((neighbourhood[3] == 0) && (neighbourhood[4] == 1)) ap++;if ((neighbourhood[4] == 0) && (neighbourhood[5] == 1)) ap++;if ((neighbourhood[5] == 0) && (neighbourhood[6] == 1)) ap++;if ((neighbourhood[6] == 0) && (neighbourhood[7] == 1)) ap++;if ((neighbourhood[7] == 0) && (neighbourhood[8] == 1)) ap++;if ((neighbourhood[8] == 0) && (neighbourhood[1] == 1)) ap++;if (ap == 1) {if (inOddIterations && (neighbourhood[3] * neighbourhood[5] * neighbourhood[7] == 0)&& (neighbourhood[1] * neighbourhood[3] * neighbourhood[5] == 0)) {deleteList.push_back(Point(i, j));}else if (!inOddIterations && (neighbourhood[1] * neighbourhood[5] * neighbourhood[7] == 0)&& (neighbourhood[1] * neighbourhood[3] * neighbourhood[7] == 0)) {deleteList.push_back(Point(i, j));}}}}}}if (deleteList.size() == 0)break;for (size_t i = 0; i < deleteList.size(); i++) {Point tem;tem = deleteList[i];uchar* data = srcImg.ptr<uchar>(tem.y);data[tem.x] = 0;}deleteList.clear();inOddIterations = !inOddIterations;}
}
int main()
{string srcImg = "opencv.png";Mat img = imread(srcImg);cvtColor(img, img, COLOR_BGR2GRAY);threshold(img, img, 127, 255, THRESH_OTSU);namedWindow("src", 0);imshow("src", img);thinImage(img);namedWindow("dst", 0);imshow("dst", img);waitKey(0);}

原图:
在这里插入图片描述
在这里插入图片描述

细化后:
在这里插入图片描述
在这里插入图片描述

5.基于ITK的骨架提取

模板:template<typename TInputImage, typename TOutputImage>class BinaryThinningImageFilter : public itk::ImageToImageFilter<TInputImage, TOutputImage>这个函数计算输入图像的一个像素宽的边缘。此函数通过输入图像的类型和输出图像的类型进行参数化。

假设输入是一个二值图像。如果输入图像的前景像素值不为 1,则会在内部将它们重新缩放为 1 以简化计算。

函数将生成对象的骨架。输出背景值为 0,前景值为 1。

这个函数是一个连续细化算法,计算时间依赖于图像的大小。

  • python实现
#!/usr/bin/env pythonimport itk
import argparseparser = argparse.ArgumentParser(description="Thin Image.")
parser.add_argument("input_image", nargs="?")
args = parser.parse_args()PixelType = itk.UC
Dimension = 2
ImageType = itk.Image[PixelType, Dimension]if args.input_image:image = itk.imread(args.input_image)else:# Create an imagestart = itk.Index[Dimension]()start.Fill(0)size = itk.Size[Dimension]()size.Fill(100)region = itk.ImageRegion[Dimension]()region.SetIndex(start)region.SetSize(size)image = ImageType.New(Regions=region)image.Allocate()image.FillBuffer(0)# Draw a 5 pixel wide lineimage[50:55, 20:80] = 255# Write Imageitk.imwrite(image, "input.png")image = itk.binary_thinning_image_filter(image)# Rescale the image so that it can be seen (the output is 0 and 1, we want 0 and 255)
image = itk.rescale_intensity_image_filter(image, output_minimum=0, output_maximum=255)# Write Image
itk.imwrite(image, "outputPython.png")
  • C++实现
#include"itkBinaryThinningImageFilter.h"
#include"itkImage.h"
#include"itkImageFileReader.h"
#include"itkImageFileWriter.h"
#include"itkRescaleIntensityImageFilter.h"
// PNG对应
#include <itkPNGImageIOFactory.h>
// BMP对应
#include <itkBMPImageIOFactory.h>
// JPG对应
#include <itkJPEGImageIOFactory.h>
// mhd格式图像
// #include <itkMetaImageIOFactory.h>using ImageType=itk::Image<unsigned char,2>;
static void WriteImage(const ImageType::Pointer image,const std::string&fileName);
static void CreateImage(ImageType::Pointer image);
int main(int argc, char*argv[])
{ImageType::Pointer image = ImageType::New();if (argc == 2) {itk::ObjectFactoryBase::RegisterFactory(itk::PNGImageIOFactory::New());// 或itk::BMPImageIOFactory::New() // 或itk::JPGImageIOFactory::New()using ImageReader = itk::ImageFileReader<ImageType>;ImageReader::Pointer reader = ImageReader::New();std::string fileName = argv[1];reader->SetFileName(fileName);reader->Update();image = reader->GetOutput();}else {itk::ObjectFactoryBase::RegisterFactory(itk::PNGImageIOFactory::New());// 或itk::BMPImageIOFactory::New() // 或itk::JPGImageIOFactory::New()CreateImage(image);WriteImage(image, "input.png");}using BinaryThinningImageFilterType = itk::BinaryThinningImageFilter<ImageType, ImageType>;BinaryThinningImageFilterType::Pointer binaryThinningImageFilter = BinaryThinningImageFilterType::New();binaryThinningImageFilter->SetInput(image);binaryThinningImageFilter->Update();//Rescale the image so that it can be seen(the output is 0 and 1,we want 0 and 255)using RescaleType = itk::RescaleIntensityImageFilter<ImageType, ImageType>;RescaleType::Pointer rescaler = RescaleType::New();rescaler->SetInput(binaryThinningImageFilter->GetOutput());rescaler->SetOutputMinimum(0);rescaler->SetOutputMaximum(255);rescaler->Update();WriteImage(rescaler->GetOutput(), "output.png");return EXIT_SUCCESS;
}
void CreateImage(ImageType::Pointer image) 
{//Create an imageImageType::IndexType start;start.Fill(0);ImageType::SizeType size;size.Fill(100);ImageType::RegionType region(start,size);image->SetRegions(region);image->Allocate();image->FillBuffer(0);//Draw a 5pixel wide linefor(unsigned int i=20;i<80;++i){for(unsigned int j=50;j<55;++j){itk::Index<2>index;index[0]=i;index[1]=j;image->SetPixel(index,255);}}
}
void WriteImage(const ImageType::Pointer image, const std::string&fileName) {using WriterType = itk::ImageFileWriter<ImageType>;WriterType::Pointer writer = WriterType::New();writer->SetFileName(fileName);writer->SetInput(image);writer->Update();
}

在这里插入图片描述在这里插入图片描述

参考目录

https://www.freesion.com/article/8054209684/
https://scikit-image.org/docs/dev/auto_examples/edges/plot_skeleton.html

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. PAT BASIC 1070 结绳

    给定一段一段的绳子&#xff0c;你需要把它们串成一条绳。每次串连的时候&#xff0c;是把两段绳子对折&#xff0c;再如下图所示套接在一起。这样得到的绳子又被当成是另一段绳子&#xff0c;可以再次对折去跟另一段绳子串连。每次串连后&#xff0c;原来两段绳子的长度就会减…...

    2024/4/20 13:42:28
  2. DEFAULT.DTF问题

    安装proteus后出现图片的问题 安装完成后&#xff0c;启动软件出现&#xff0c;无法找到DEFAULT.DTF的对话框&#xff0c; 搜索了网上的方法后&#xff0c;发现是自己的软件的设置路径错了。 进入系统设置重新设置路径后正常。...

    2024/5/2 11:27:25
  3. 编程语言Mysql系列(十五)mysql主从配置

    编程语言Mysql系列&#xff08;十五&#xff09;mysql主从配置 从库可以很多台&#xff0c;我们假设一台主M&#xff0c;一台从S。 主M配置文件添加&#xff1a; server-id1 bin-loglogbin 这个名字随意 记得重启 从S配置文件添加&#xff1a; server-id2 配置文件就完成…...

    2024/4/20 3:00:16
  4. 水下机器人项目!大创!包含solidworks模型,程序,PCB,上位机,实物视频演示,项目报告。

    水下机器人项目&#xff01;大创&#xff01;包含solidworks模型&#xff0c;程序&#xff0c;P CB&#xff0c;上位机&#xff0c;实物视频演示&#xff0c;项目报告。 未知_玄...

    2024/5/4 13:50:26
  5. uni-app 77聊天类封装(十三)-断线重连提示

    chat.js import $U from "./util.js"; import $H from ./request.js; class chat {constructor(arg) {this.url arg.urlthis.isOnline falsethis.socket null// 获取当前用户相关信息let user $U.getStorage(user);this.user user ? JSON.parse(user) : {},// …...

    2024/4/20 13:42:26
  6. 【Ubuntu】检测内存并压力测试

    下载 https://pyropus.ca/software/memtester/ 安装 tar -zxvf memtester-4.5.1.tar.gz cd memtester-4.5.1/ # 安装依赖 apt install make apt install gcc # 编译并安装 make && make install使用&#xff1a; 语法&#xff1a; memtester [-p PHYSADDR] <MEMO…...

    2024/4/20 13:42:23
  7. 3D激光SLAM:ALOAM:激光雷达的运动畸变补偿代码解析

    3D激光SLAM:ALOAM:激光雷达的运动畸变补偿代码解析前言Code将帧中间的点转到起始点坐标系下将帧中间的点转到起始点坐标系下前言 什么是激光雷达的运动畸变 ? 激光雷达的一帧数据是过去一周期内形成的所有数据,数据仅有一时间戳,而非某个时刻的数据,因此在这一帧时间内的激光…...

    2024/4/20 13:42:23
  8. Layout Inspector不能正常显示

    问题&#xff1a;今天在使用抓布局的工具的时候不能正常显示 解决办法&#xff1a;Setting—输入“Enable Live Layout Inspector”取消勾选就行了 然后就能正常使用Layout Inspector工具来查看布局了 轻松搞定&#xff01;...

    2024/5/4 14:00:17
  9. 已更新或删除的行值要么不能使该行成为唯一行,要么改变了多个行,如何解决

    可以新增一列ID&#xff0c;设置为主键&#xff0c;然后标识符打开新增 就可以更改了...

    2024/4/27 18:09:24
  10. #1127. ZigZagging on a Tree【树的遍历】

    原题链接 Problem Description&#xff1a; Suppose that all the keys in a binary tree are distinct positive integers. A unique binary tree can be determined by a given pair of postorder and inorder traversal sequences. And it is a simple standard routine t…...

    2024/4/21 17:55:02
  11. Linux系统下centos中在线添加硬盘后不重启

    Centos7 在线添加硬盘不重启系统 CentOS 7在线添加新磁盘,无需重启 现有环境基本都是线下server以及线上虚拟机等,几乎都支持热插拔,热扩容,所以在线添加新磁盘就尤为重要,这样可以无需中断当前服务或进程也可对其进行添加硬盘操作。 下列操作用虚拟机演示&#xff1a; 1.添加…...

    2024/4/21 17:55:01
  12. 【算法】算法的时间复杂度和空间复杂度

    一、算法的时间复杂度 定义&#xff1a;算法时间复杂度是算法的时间度量&#xff0c;对于任意一个算法&#xff0c;语句总的执行次数T(n)是关于问题规模n的函数&#xff0c;该算法的时间复杂度记作T(n)O(f(n))。其中f(n)是问题规模n的某个函数。 理解&#xff1a;对于算法的时…...

    2024/4/27 1:23:17
  13. uniapp下载

    uni.downloadFile({url: http://www.example.com/file/test, //仅为示例&#xff0c;并非真实的资源success: (res) > {console.log(下载进度 res.progress);console.log(已经下载的数据长度 res.totalBytesWritten);console.log(预期需要下载的数据总长度 res.totalByte…...

    2024/4/21 17:54:59
  14. rest_framework11:jwt简单例子/自定制基于jwt认证类

    jwt简单例子 一、登陆设置 1.不需要写login的视图类&#xff0c;使用jwt内置的。 2.需要前置条件&#xff0c;已有继承AbstractUser models,并且有数据&#xff0c;用于校验&#xff0c;返回token。 urls.py from rest_framework_jwt.views import obtain_jwt_tokenurlpat…...

    2024/5/4 13:57:57
  15. npm update check failed try running with sudo or...

    找到.config文件&#xff0c;把里面的文件删除掉&#xff0c;重新执行命令就ok了。 .config文件里的文件也会重新生成...

    2024/4/21 17:54:57
  16. 数据库系统概述

    文章目录一、数据库管理系统的类型二、数据库的结构与模式三、数据模型四、关系代数四、数据的规范化五、数据的反规范化一、数据库管理系统的类型 数据库管理系统的类型通常有多个分类标准&#xff0c;但主要还是按数据模型分类&#xff0c;包括关系型数据库系统、文档型数据…...

    2024/4/21 17:54:57
  17. 正余弦转化之诱导公式:“奇变偶不变、符号看象限”

    1.正余弦转化 首先看看&#xff0c;正弦、余弦在各个象限中的正负情况&#xff0c;如下图1所示。 图1.sinx、cosx在各个象限中的正负号示意图 在图1中&#xff0c;左图表示sinx&#xff0c;右图表示cosx。首先看看坐标轴上数字是如何来的&#xff01;当x轴正半轴沿逆时针方向…...

    2024/4/30 16:08:10
  18. 编程语言Mysql系列(十三)分页查询语句

    编程语言Mysql系列&#xff08;十三&#xff09;分页查询语句 Mysql系列&#xff08;十三&#xff09;分页查询语句 MySql select tablename.* from tablename limit firstIndex,pageSize;firstIndex -------->开始索引pageSize--------->页大小 Oracle select * fr…...

    2024/4/21 17:54:54
  19. 如何管理Mac电脑菜单栏中的图标

    Mac最顶端的菜单栏上会有一些常用的macOS系统控制选项&#xff0c;例如&#xff1a;时间日期、控制中心、Wi-Fi网络、蓝牙、声音、输入法、搜寻或其他第三方App图标&#xff0c;这样我们就能快速取用&#xff0c;不用另外开启应用程序。 Bartender 4 for Mac(方便的管理菜单栏图…...

    2024/4/28 0:35:18
  20. 练习Day2

    1、取出/etc/inittab文件的第6行。 [rootlocalhost day2]# sed -n 6p /etc/inittab2、取出当前系统上所有用户的shell&#xff0c;要求每种shell只显示一次&#xff0c;并且按顺序进行显示&#xff0c;使用cut、sort结合管道实现 。 [rootlocalhost day2]# cut -d : -f7 /etc…...

    2024/4/20 13:42:37

最新文章

  1. OLTP和OLAP,StarRocks数据库,TiDB数据库

    OLTP和OLAP&#xff0c;StarRocks数据库&#xff0c;TiDB数据库 一、OLTP和OLAP二、StarRocks数据库三、TiDB数据库 一、OLTP和OLAP OLTP和OLAP是两种不同的数据处理方式&#xff0c;用于处理不同类型的工作负载。OLTP&#xff08;Online Transaction Processing&#xff09;是…...

    2024/5/4 14:12:09
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 算法四十天-删除排序链表中的重复元素

    删除排序链表中的重复元素 题目要求 解题思路 一次遍历 由于给定的链表是排好序的&#xff0c;因此重复的元素在链表中的出现的位置是连续的&#xff0c;因此我们只需要对链表进行一次遍历&#xff0c;就可以删除重复的元素。 具体地&#xff0c;我们从指针cur指向链表的头节…...

    2024/5/1 13:07:13
  4. 【stm32】I2C通信协议

    【stm32】I2C通信协议 概念及原理 如果我们想要读写寄存器来控制硬件电路&#xff0c;就至少需要定义两个字节数据 一个字节是我们要读写哪个寄存器&#xff0c;也就是指定寄存器的地址 另一个字节就是这个地址下存储寄存器的内容 写入内容就是控制电路&#xff0c;读出内容就…...

    2024/5/2 2:37:26
  5. 【外汇早评】美通胀数据走低,美元调整

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2024/5/4 2:59:34
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:18
  26. 错误使用 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,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
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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