文章目录

    • 一、之前工作回顾
    • 二、图片处理过程
      • (1)图片的裁剪
      • (2)生成xml文件的相关代码
    • 三、使用yolov4模型,训练预测蛾子数据集
    • 四、项目步骤记录
    • 五、数据标注范例
    • 六、关于xml的创建、读写问题
      • (1)xml的创建
      • (2)在xml有根元素时写入
      • (3)xml的读取
    • 参考

一、之前工作回顾


  • 在【python-opencv】 sobel算子 图像边缘检测 图像二值化处理 并进行框标定 这一篇文章中,讨论了如何使用边缘检测算法将图片二值化处理。
  • 其中th, im_th = cv2.threshold(im_in, 40, 255, cv2.THRESH_BINARY)这一行代码中,40这个值可以根据不同的图片改变,以达到二值化的最佳状态。
  • 在这一步,为之后实现图像的框标定,提取出图片中物体的x, y, w, h的值奠定了基础。

  • 在【python-opencv】对图片二值化处理后,对图像进行框标定 这篇文章中,讨论了如何对二值化的图片进行框标定,并返回图片中物体的x, y, w, h的值。
  • 其中MIN_BOX = 5000这个参数应当随着物体大小的改变而改变,对于小的蛾子,参数应当调小。
  • 在这一步,为之后将返回的图片中物体的x, y, w, h的值以voc格式写入xml文件提供了基础。

二、图片处理过程

(1)图片的裁剪

  • 裁剪掉周围没有物体的地方,裁剪后的图片大小固定
  • 图片裁剪.py
# -*- coding: utf-8 -*-
import cv2
import numpy as npdef cut_pic(img):# 裁剪图片imgs = cv2.resize(img, (0, 0), fx=0.2, fy=0.2, interpolation=cv2.INTER_NEAREST)[25:25 + 700, 210:210 + 760]# plt.imshow(img)return imgs

(2)生成xml文件的相关代码

  • 在将图片裁剪完成之后,运行 框标定.py 即可以生成相关的voc数据集格式文件。

  • 生成的xml文件格式 详见 数据标注范例

  • 生成图片的xml文件.py

# -*- coding:utf-8 -*-
# https://zhuanlan.zhihu.com/p/54269963# from xml.etree import ElementTree as  etree
from xml.etree.ElementTree import Element
from xml.etree.ElementTree import SubElement
from xml.etree.ElementTree import ElementTree
from xml.dom import minidom
import osdef generate_head(pic_filename, pic_path):# generate root nodeannotation = Element('annotation')# generate first child-node folderfolder = SubElement(annotation, 'folder')folder.text = "VOC2007"# generate second child-node filenamefilename = SubElement(annotation, 'filename')filename.text = pic_filename# generate child-node pathpath = SubElement(annotation, 'path')path.text = pic_path# generate third child-node sourcesource = SubElement(annotation, 'source')# child-node of source nodedatabase = SubElement(source, 'database')database.text = "ezi"# generate fourth child-node sourcesize = SubElement(annotation, 'size')# child-node of sizewidth = SubElement(size, 'width')width.text = "760"# child-node of sizeheight = SubElement(size, 'height')height.text = "700"# child-node of sizedepth = SubElement(size, 'depth')depth.text = "3"# generate fifth child-node foldersegmented = SubElement(annotation, 'segmented')segmented.text = "0"return annotationdef generate_object(annotation, pic_label, x, y, w, h):# generate child-node object of annotationobject = SubElement(annotation, 'object')# child-node of objectname = SubElement(object, 'name')name.text = pic_label# child-node of objectpose = SubElement(object, 'pose')pose.text = "Unspecified"# child-node of objecttruncated = SubElement(object, 'truncated')truncated.text = "0"# child-node of objectdifficult = SubElement(object, 'difficult')difficult.text = "0"# child-node of objectbndbox = SubElement(object, 'bndbox')# child-node of bndboxxmin = SubElement(bndbox, 'xmin')xmin.text = str(x)# child-node of bndboxymin = SubElement(bndbox, 'ymin')ymin.text = str(y)# child-node of bndboxxmax = SubElement(bndbox, 'xmax')xmax.text = str(x + w)# child-node of bndboxymax = SubElement(bndbox, 'ymax')ymax.text = str(y + h)return annotationdef write_xml(annotation, xml_path):dir_name = os.path.dirname(xml_path)if not os.path.exists(dir_name):os.makedirs(dir_name)# os.path.split(xml_path)[-1] 得到文件名# open(xml_path, "w").close()# 打包为tree,以便写入tree = ElementTree(annotation)# write out xml datatree.write(xml_path, encoding='utf-8')
  • sobel算子边缘检测.py
# -*- coding: utf-8 -*-
import cv2
import numpy as np
from 图片裁剪 import cut_picdef fillHole(im_in):# Threshold.# Set values equal to or above 40 to 255.# Set values below 40 to 0.# https://blog.csdn.net/a19990412/article/details/81172426 thresh的用法th, im_th = cv2.threshold(im_in, 55, 255, cv2.THRESH_BINARY)# Copy the thresholded image.im_floodfill = im_th.copy()# print(im_th)# Mask used to flood filling.# Notice the size needs to be 2 pixels than the image.h, w = im_th.shape[:2]mask = np.zeros((h + 2, w + 2), np.uint8)# Floodfill from point (0, 0)cv2.floodFill(im_floodfill, mask, (0, 0), 255)# Invert floodfilled imageim_floodfill_inv = cv2.bitwise_not(im_floodfill)# Combine the two images to get the foreground.im_out = im_th | im_floodfill_invreturn im_outdef baweraopen(image, size):'''@image:单通道二值图,数据类型uint8@size:欲去除区域大小(黑底上的白区域)'''output = image.copy()nlabels, labels, stats, centroids = cv2.connectedComponentsWithStats(image)for i in range(1, nlabels - 1):regions_size = stats[i, 4]if regions_size < size:x0 = stats[i, 0]y0 = stats[i, 1]x1 = stats[i, 0] + stats[i, 2]y1 = stats[i, 1] + stats[i, 3]for row in range(y0, y1):for col in range(x0, x1):if labels[row, col] == i:output[row, col] = 0return outputdef sobel_cal(imgs):if imgs.size != 1596000:# 裁剪图片imgs = cut_pic(imgs)# plt.imshow(img)# 高斯模糊去噪img = cv2.medianBlur(imgs, 7)# 高斯模糊去噪# img = cv2.medianBlur(img, 7)hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)H, S, V = cv2.split(hsv)lab = cv2.cvtColor(img, cv2.COLOR_BGR2LAB)lab_l = lab[..., 0]lab_a = lab[..., 1]lab_b = lab[..., 2]# cv2.imshow("image1", lab_b)color_space = S# Sobel算子x = cv2.Sobel(color_space, cv2.CV_16S, 1, 0)  # 对x求一阶导y = cv2.Sobel(color_space, cv2.CV_16S, 0, 1)  # 对y求一阶导absX = cv2.convertScaleAbs(x)absY = cv2.convertScaleAbs(y)sobel = cv2.addWeighted(absX, 0.5, absY, 0.5, 0)# b.设置卷积核5*5kernel = np.ones((2, 2), np.uint8)# 腐蚀的作用说白了就是让暗的区域变大,而膨胀的作用就是让亮的区域变大# 图像的膨胀dst = cv2.dilate(sobel, kernel)# 空洞填充out = fillHole(dst)# c.图像的腐蚀,默认迭代次数erosion = cv2.erode(out, kernel)# 图像的膨胀dst = cv2.dilate(erosion, kernel)# 去除小的斑点out = baweraopen(dst, 300)return imgs, outif __name__ == '__main__':# 读取图像# 此处注意cv2.imread读出来的是bgr格式要转为rgbimg = cv2.imread('img/13.jpg')img, out = sobel_cal(img)# 显示图形# cv2.imwrite('10.jpg', img)cv2.imshow('out', out)cv2.waitKey()
  • 框标定.py
import cv2
import numpy as npfrom sobel算子边缘检测 import sobel_cal
from 生成图片的xml文件 import generate_object, generate_head, write_xml
import os# 设置最小框的面积
MIN_BOX = 2500def draw_min_rect_circle(img, cnts, pic_filename, pic_label, pic_path, xml_path):  # conts = contoursimg = np.copy(img)annotation = generate_head(pic_filename, pic_path)for cnt in cnts:x, y, w, h = cv2.boundingRect(cnt)if w * h < MIN_BOX:continueannotation = generate_object(annotation, pic_label, x, y, w, h)# print(x, y, w, h)cv2.rectangle(img, (x, y), (x + w, y + h), (255, 0, 0), 2)  # bluewrite_xml(annotation, xml_path)return imgdef run(pic_filename, pic_label, pic_path, xml_path):imgs = cv2.imread(pic_path)  # a black objects on white image is better# print(pic_path)# print(imgs)# img为裁剪过后的图片,image为二值化之后的黑白图片。imgs, image = sobel_cal(imgs)# cv2.imshow("contour", image)# cv2.waitKey()thresh = cv2.GaussianBlur(image, (5, 5), 0)thresh = cv2.Canny(thresh, 0, 104)contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)# print(hierarchy, ":hierarchy")"""[[[-1 -1 -1 -1]]] :hierarchy  # cv2.Canny()[[[ 1 -1 -1 -1][ 2  0 -1 -1][ 3  1 -1 -1][-1  2 -1 -1]]] :hierarchy  # cv2.threshold()"""# 传入的是没有高斯去噪的图片imgs = draw_min_rect_circle(imgs, contours, pic_filename, pic_label, pic_path, xml_path)# cv2.imshow("contours", imgs)    # cv2.waitKey()if __name__ == '__main__':pic_root = "./dataset"xml_root = "./Annotations"for i in os.listdir(pic_root):pic_label = ifor j in os.listdir(os.path.join(pic_root, pic_label)):pic_filename = jpic_path = os.path.join(pic_root, pic_label, j)# 生成到对应的文件夹下,但弄出来很麻烦,我直接生成在annotation里面了# xml_path = os.path.join(xml_root, pic_label, str(j[:-3] + "xml"))xml_path = os.path.join(xml_root, str(j[:-3] + "xml"))print(pic_filename, pic_label, pic_path, xml_path)run(pic_filename, pic_label, pic_path, xml_path)

三、使用yolov4模型,训练预测蛾子数据集

  • 使用生成的xml文件构建蛾子的voc数据集。具体步骤参考 项目步骤记录。

  • 项目刚刚开始,数据集还不充分,这里写下这些记录一下过程。

  • 结果展示
    在这里插入图片描述在这里插入图片描述

四、项目步骤记录

1、使用 image_preprocessing/generate_xml_dir/图片裁剪.py 文件将原来的图片裁剪成统一格式的文件。
2、image_preprocessing/generate_xml_dir/生成图片的xml文件.py 用于存放生成框标定的文件
3、使用genenrate_xml_dir 文件夹下的 框标定.py 来生产xml文件
4、将对应目录下的xml和jpg文件剪切到yolov4 voc数据集 相关目录
5、使用 yolov4-pytorch-master/VOCdevkit 文件夹下的 voc2yolo4.py 来生成yolov4-pytorch-master/VOCdevkit/VOC2007/ImageSets/Main 文件夹下的 train.txt等文件。
6、运行 yolov4-pytorch-master/voc_annotation.py 文件,记得更改classes为自己的classes。
7、在使用 yolov4-pytorch-master/predict.py 预测的时候,记得更改 yolov4-pytorch-master/yolo.py 下的"anchors_path""classes_path"两个文件路径为自己的路径,及log下的pth和model_data下的classes.txt
8、使用predict.py进行预测,发现结果棉铃虫效果较好,其他的稍微差一些。注意事项:
1、opencv不能读取含中文路径的图片,涉及图片的文件夹路径一律使用英文
2、image_preprocessing/generate_xml_dir/sobel算子边缘检测.py 里面对于不同的蛾子,cv2.threshold的参数应该不一样,这一次没有管它们的差别,如果想要更加精细化训练,可以考虑加上

五、数据标注范例

<annotation><folder>VOC2007</folder><filename>DSC00142.JPG</filename><source><database>ezi</database></source><size><width>760</width><height>700</height><depth>3</depth></size><segmented>0</segmented><object><name>mlc</name><pose>Unspecified</pose><truncated>0</truncated><difficult>0</difficult><bndbox><xmin>483</xmin><ymin>446</ymin><xmax>582</xmax><ymax>549</ymax></bndbox></object><object><name>mlc</name><pose>Unspecified</pose><truncated>0</truncated><difficult>0</difficult><bndbox><xmin>131</xmin><ymin>442</ymin><xmax>221</xmax><ymax>532</ymax></bndbox></object>
</annotation>

六、关于xml的创建、读写问题

(1)xml的创建

# -*- coding:utf-8 -*-
# https://zhuanlan.zhihu.com/p/54269963# from xml.etree import ElementTree as  etree
from xml.etree.ElementTree import Element
from xml.etree.ElementTree import SubElement
from xml.etree.ElementTree import ElementTree
from xml.dom import minidom# generate root node
root = Element('root')# generate first child-node head
head = SubElement(root, 'head')# child-node of head node
title = SubElement(head, 'title')
title.text = "Well Dola!"# generate second child-node body
body = SubElement(root, 'body')
body.text = "I Love Dola!"tree = ElementTree(root)# write out xml data
tree.write('result.xml', encoding='utf-8')
  • 结果 :result.xml
<root><head><title>Well Dola!</title></head><body>I Love Dola!</body>
</root>

(2)在xml有根元素时写入

  • customer.xml
<customer ID="C003"><name>kavin</name><phone>32467</phone><comments><![CDATA[A small but healthy company.]]></comments>
</customer>
  • 在 customer.xml 中写入的范例代码
from xml.dom.minidom import parse
import xml.dom.minidom
import osdef writeXML():domTree = parse("./customer.xml")# 文档根元素rootNode = domTree.documentElement# 新建一个customer节点customer_node = domTree.createElement("customer")customer_node.setAttribute("ID", "C003")# 创建name节点,并设置textValuename_node = domTree.createElement("name")name_text_value = domTree.createTextNode("kavin")name_node.appendChild(name_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(name_node)# 创建phone节点,并设置textValuephone_node = domTree.createElement("phone")phone_text_value = domTree.createTextNode("32467")phone_node.appendChild(phone_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(phone_node)# 创建comments节点,这里是CDATAcomments_node = domTree.createElement("comments")cdata_text_value = domTree.createCDATASection("A small but healthy company.")comments_node.appendChild(cdata_text_value)customer_node.appendChild(comments_node)rootNode.appendChild(customer_node)with open('added_customer.xml', 'w') as f:# 缩进 - 换行 - 编码domTree.writexml(f, addindent='  ', encoding='utf-8')if __name__ == '__main__':writeXML()
  • 结果
<?xml version="1.0" encoding="utf-8"?>
<customer ID="C003"><name>kavin</name><phone>32467</phone><comments><![CDATA[A small but healthy company.]]></comments><customer ID="C003"><name>kavin</name><phone>32467</phone><comments><![CDATA[A small but healthy company.]]>    </comments></customer>
</customer>

(3)xml的读取

  • movie.xml
<collection shelf="New Arrivals"><movie title="Enemy Behind"><type>War, Thriller</type><format>DVD</format><year>2003</year><rating>PG</rating><stars>10</stars><description>Talk about a US-Japan war</description></movie><movie title="Transformers"><type>Anime, Science Fiction</type><format>DVD</format><year>1989</year><rating>R</rating><stars>8</stars><description>A schientific fiction</description></movie><movie title="Trigun"><type>Anime, Action</type><format>DVD</format><episodes>4</episodes><rating>PG</rating><stars>10</stars><description>Vash the Stampede!</description></movie><movie title="Ishtar"><type>Comedy</type><format>VHS</format><rating>PG</rating><stars>2</stars><description>Viewable boredom</description></movie>
</collection>
  • 读取代码
# https://www.cnblogs.com/smart-zihan/p/12015192.htmlfrom xml.dom.minidom import parse
import xml.dom.minidom
import osdef is_xml_exist(xml_path):xml_exist = os.path.exists(xml_path)if not xml_exist:return Falsereturn Truedef read_movie_xml():path = "movie.xml"if not is_xml_exist(path):print("%s is not exist" % path)else:# 使用minidom解析器打开XML文档open_xml = parse(path)root_node = open_xml.documentElementshelf_attrib = "shelf"if root_node.hasAttribute(shelf_attrib):print("Lable: %s\tAttrib: %s\t\tValue: %s" % (root_node.nodeName, shelf_attrib, root_node.getAttribute(shelf_attrib)))print("")# 在集合中获取所有电影movie_node = "movie"movies = root_node.getElementsByTagName(movie_node)# 打印每部电影的详细信息for movie in movies:print("**** Movie ****")if movie.hasAttribute("title"):print("Title: %s" % movie.getAttribute("title"))type_movie = movie.getElementsByTagName('type')[0]print("Type: %s" % type_movie.childNodes[0].data)format_movie = movie.getElementsByTagName('format')[0]print("Format: %s" % format_movie.childNodes[0].data)rating_movie = movie.getElementsByTagName('rating')[0]print("Rating: %s" % rating_movie.childNodes[0].data)descrip_movie = movie.getElementsByTagName('description')[0]print("Rating: %s" % descrip_movie.childNodes[0].data)print("")if __name__ == "__main__":read_movie_xml()

参考

  • 我的关联文章
    【python-opencv】 sobel算子 图像边缘检测 图像二值化处理 并进行框标定
    【python-opencv】对图片二值化处理后,对图像进行框标定
  • 参考文章或博客
    YOLOv4: Optimal Speed and Accuracy of Object Detection
    Python创建、修改、保存XML文件——xml.etree.ElementTree模块
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. LeetCode 102. 二叉树的层序遍历

    一个简单的数学解决方法 一般来说 层序遍历要求我们使用的是队列这种数据结构 这道题要求我们返回一个List<List>类型 首先通过观察我们可以发现 最外面那层list的大小是这棵树的层数 里面那层list的大小就是某一层的节点的个数 比如这个例子 list里面有三层 代表这棵树有…...

    2024/4/25 0:13:34
  2. [C++]临时抱佛脚——模拟考系统

    大家好,这里是卑微小李 好久没写部落格了,刚好敲了一堆拿得出手(根本拿不出手)的代码,不多,也就459行 就是一个专门用来临时抱佛聊的复习系统 废话不多说,放代码 记得点赞qwq /* 助考程序 题型: SC 单选 sc.txt MC 多选 mc.txt FB 填空 fb.txt AW 简答 aw.txt参数 st.tx…...

    2024/5/4 17:26:29
  3. Flutter搜索框SearchBar

    题记 —— 执剑天涯,从你的点滴积累开始,所及之处,必精益求精,即是折腾每一天。 重要消息网易云【玩转大前端】配套课程EDU配套 教程Flutter开发的点滴积累系列文章1 使用封装库 1.1 添加依赖 小编已将本效果写成一个依赖库,读者可根据使用直接添加依赖,代码如下: git…...

    2024/4/25 0:13:32
  4. keras快速搭建神经网络实现手写数字识别

    利用keras 快速搭建神经网络模型,实现手写数字识别。用tensorflow作为后端 代码 import numpy as np import pandas as pd import matplotlib.pyplot as plt from scipy.io import loadmat from sklearn.model_selection import train_test_split import keras from keras.mod…...

    2024/4/25 0:13:32
  5. 1930. 灌溉农田(irrigation)

    1930. 灌溉农田(irrigation) 题目描述 由于最近缺少降雨,农夫约翰决定在他的N块农田之间建立一个供水管网。每块的位置可以用一个二维坐标来表示(xi,yi),在第i块地和第j块地之间修建一个管道的话,代价是(xi - xj)^2 + (yi - yj)^2。农夫约翰想要建立一个花费代价最小的供…...

    2024/4/25 0:13:37
  6. ActiveMQ学习笔记1——入门

    1 ActiveMQ简介1.1支持多语言和协议便捷客户端。语言:java、python、C、C++、php等应用协议:OpenWrite,Stomp REST,XMPP,AMQP等 1.2对spring支持; 1.3支持通过JDBC和journal提供高速的消息持久化;即可保存在关系型数据库和内存File数据库中。 1.4支持集群,客户端-服务器…...

    2024/4/25 0:13:29
  7. 在centos 7.5上安装nginx 以及简单配置

    第一步:安装环境 因为我的环境是全新的,没有Nginx需要的环境,所以第一步我们先把环境配好 具体包括:c++,pcre、pcre-devel,openssl和zlib 下面依次安装 安装c++(用作编译环境) 输入命令:yum install gcc-c++,出现选择y/n 的时候直接y就行,如下,我的是安装好的结果 …...

    2024/4/25 0:13:28
  8. QFuture的使用:多线程与进度条

    介绍QFuture 类可以用来获取异步计算的结果(类似 std::future ),一般配合 Qt Concurrent 模块和 QFutureWatcher 类工作。在 Qt Creator 中搜索 concurrent 可以看到一些相关示例。官方示例中, QFuture 一般和 QFutureWatcher 配合,因为 QFuture 不是 QObject 子类,没有信…...

    2024/4/25 0:13:34
  9. 【0-1背包之必须充满背包】最小邮票数

    文章目录题目链接代码实现码后反思题目链接 代码实现 //这是一类装满背包的问题~ #include <cstdio> #include <algorithm> using namespace std; const int maxm = 110; const int maxn = 30;int n; int m; int w[maxn]; int dp[maxm];int main(){while(scanf(&q…...

    2024/4/25 0:13:26
  10. Swift 编程范式

    范式转换 - 从一个题目说起读入一个文本文件,确定所有单词的使用频率并从高到低排序,打印所有单词及其频率的排序列表范式转换 - 传统解决方案 范式转换 - 函数式范式转换命令式编程常常迫使我们处于性能考虑,把不同的任务交织起来,以便能够用一次循环来完成多个任务。 而函…...

    2024/4/25 0:13:25
  11. C++中的i++和++i的实现总结

    i++ const int int::operator(int) {int oldValue = *this;*this+=1;return oldValue; }++i const int int::operator(int) {*this+=1;return *this; }...

    2024/4/25 0:13:24
  12. 2020-6-25如何在HBuilderX中使用模拟器

    如何在如何在HBuilderX中使用模拟器 说明: 由于我在工作中经常会用到手机进行调试,会看一下手机端界面的样式等问题。但是手机插在电脑上进行调试,多多少少会带来一些不方便,所以想是否可以通过手机模拟器来代替手机调试的作用。 其实过程很简单,我就将自己所知道的方法以…...

    2024/4/14 20:44:57
  13. 知识普及篇——动手做foc无刷电机电子调速器

    第一篇-电机常识无刷电机模型电机构造电机模型与运动原理电机模型电机运动原理电角度与机械角本系列博客将从零,详细的讲解FOC电机调速器的制作(包括电机理论知识、软件、硬件,以及具体的实现)。涉及的知识面有点大,希望读者是有一定计算机知识储备的受过高等教育的学生或…...

    2024/4/18 1:17:24
  14. 【图像处理】blender的简单使用

    【图像处理】blender的简单使用 在ubuntu16.04上安装新版blender将blender修改为中文界面blender的基础操作结语 在ubuntu16.04上安装新版blender进入blender下载页面:https://www.blender.org/download/页面跳转后,选择对应的系统,我这里选择ubuntu,点击页面跳转后,有对应…...

    2024/4/23 22:37:14
  15. 2020前端面试题总结(针对2年经验)

    前端面试题总结(针对2年经验的开发,2020)前言面试流程面试题csshtmljsvue其他 前言 从6月初裸辞到现在,大大小小的面试差不多也快10家(已经拿到offer并准备去啦),每次面试完后都会针对面试上没回答上的问题进行总结,写这篇文章也是想要分享给经验不多没有足够时间准备面…...

    2024/4/14 20:44:54
  16. 源码编译 apache2.4

    Apache HTTP Server是Apache软件基金会的一个开放源码的网页服务器软件,可以在大多数电脑操作系统中运行。由于其跨平台和安全性,被广泛使用,是最流行的Web服务器软件之一。它快速、可靠并且可通过简单的API扩展,将Perl/Python等解释器编译到服务器中。[root@Jaking12 ~]#…...

    2024/4/25 0:13:23
  17. 从缺陷中学习C++(06)

    2.编译问题动态链接库加载错误版本在程序test.cpp中,mian函数使用了动态链接库libiscore.so中的函数avg_score,如下:float avg_score(int s){return (float)s / 12; }int main(){int sum = 4000;float average = avg_score(sum);cout<<"score per morth:"<&…...

    2024/4/25 0:13:29
  18. 协议分类

    网络通讯协议分类 UDP协议:用户数据报协议,面向无连接的协议。1发2,不用连接。 特点:耗资小,通讯效率高,偶尔会丢失数据,当传输重要数据时,不建议使用UDP协议,例如飞秋,QQ的聊天功能都使用的是UDP协议,然而数据却被限制在64kb以内。 TCP协议:传输控制协议,面向连接…...

    2024/4/25 0:13:23
  19. samba服务器如何配置

    一:samba服务器配置安装samba sudo apt-get install system-config-samba -y 修改smb.conf sudo vi /etc/samba/smb.conf[work]comment = share for liujiaxingpath = /home/liujiaxing/projectpublic = yeswriteable = yesavailable = yesbrowseable = yescreate mode = 0664…...

    2024/5/1 23:30:58
  20. laravel 学习(35) 生成url

    ...

    2024/4/27 1:57:13

最新文章

  1. Pytorch分布式train——pytorch.distributed.launch V.S. torchrun

    1. 较早的pytorch.distributed.launch python -m torch.distributed.launch --nproc_per_node4 --nnodes1 --node_rank0 train.py --args XXX 参数解析&#xff1a; nnodes&#xff1a;节点&#xff08;主机&#xff09;的数量&#xff0c;通常一个节点对应一个主机 node_rank…...

    2024/5/4 17:55:40
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 【C++】类和对象①(什么是面向对象 | 类的定义 | 类的访问限定符及封装 | 类的作用域和实例化 | 类对象的存储方式 | this指针)

    目录 前言 什么是面向对象&#xff1f; 类的定义 类的访问限定符及封装 访问限定符 封装 类的作用域 类的实例化 类对象的存储方式 this指针 结语 前言 最早的C版本&#xff08;C with classes&#xff09;中&#xff0c;最先加上的就是类的机制&#xff0c;它构成…...

    2024/5/1 13:18:37
  4. 微信小程序实现左滑删除

    效果 实现思路 使用的是官方提供的movable-area 嵌套movable-view 1、movable-area&#xff1a;注意点&#xff0c;需要设置其高度&#xff0c;否则会出现列表内容重叠的现象。 2、由于movable-view需要向右移动&#xff0c;左滑的时候给删除控件展示的空间&#xff0c;故 mov…...

    2024/5/1 13:30:10
  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