当前位置: 首页 > news >正文

seo优化推广业务员招聘seo顾问服务福建

seo优化推广业务员招聘,seo顾问服务福建,自己怎样建网站,做wish选品参考什么网站目录 1. 介绍 2. 完整代码 3. 代码讲解 3.1 生成 my_train_data.txt和my_val_data.txt 3.2 生成 my_data.data 文件 3.3 生成 my_yolov3.cfg 3.4 关于my_data_label.names文件 1. 介绍 根据 第一节 的操作#xff0c;已经生成了下图中圆圈中的部分#xff0c;而本…目录 1.  介绍 2. 完整代码 3. 代码讲解 3.1 生成 my_train_data.txt和my_val_data.txt 3.2 生成 my_data.data 文件 3.3  生成 my_yolov3.cfg 3.4 关于my_data_label.names文件 1.  介绍 根据 第一节 的操作已经生成了下图中圆圈中的部分而本章的内容就是通过代码生成矩形框中的部分为后面的工作做准备 my_yolov3.cfg 是将官方的yolov3-spp.cfg 网络的配置文件根据自定义的数据集修改得到的自己的网络配置因为检测的分类个数不同yolo输出的信息也会不同my_train_data.txt 和 my_val_data.txt 是训练集 / 验证集中所有图片的完整路径也就是my_yolo_dataset 中 两个 images 下面的所有图片的路径my_data.data 是分类个数、my_train_data.txt 和 my_val_data.txt这两个文件的路径、以及my_data_label.names 的路径如果一开始数据集就是yolo格式的就不会经过第一节的操作也不会生成这个.names文件所以要自己建立 2. 完整代码 实现代码为 calculate_dataset.py 该脚本有3个功能 1.统计训练集和验证集的数据并生成相应.txt文件 2.创建my_data.data文件记录目标检测的 classes个数, train以及 val数据集文件(.txt)路径和 label.names文件路径 3.根据 yolov3-spp.cfg创建 my_yolov3.cfg文件修改其中的 predictor filters以及 yolo classes参数(这两个参数是根据类别数改变的)import os# 生成训练集、验证集的所有数据路径文件 def calculate_data_txt(txt_path, dataset_dir):with open(txt_path, w) as w:for file_name in os.listdir(dataset_dir): # 遍历数据的标注文件train、val下的labelsif file_name classes.txt:continue# 根据标注文件找到对应的图片图片后缀需要是jpgimg_path os.path.join(dataset_dir.replace(labels, images),file_name.split(.)[0]) .jpgline img_path \n # 写入一个数据路径就换行assert os.path.exists(img_path), file:{} not exist!.format(img_path)w.write(line)# 创建data.data文件记录分类类别个数、训练集、验证集、分类类别的文件路径 def create_data_data(create_data_path, train_path, val_path, classes_info):with open(create_data_path, w) as w:w.write(classes{}.format(len(classes_info)) \n) # 记录类别个数w.write(train{}.format(train_path) \n) # 记录训练集对应txt文件路径w.write(valid{}.format(val_path) \n) # 记录验证集对应txt文件路径w.write(namesdata/my_data_label.names \n) # 记录label.names文件路径# 创建yolo v3 spp的配置信息 def change_and_create_cfg_file(classes_info, save_cfg_path./cfg/my_yolov3.cfg):filters_lines [636, 722, 809]classes_lines [643, 729, 816]cfg_lines open(cfg_path, r).readlines()for i in filters_lines:assert filters in cfg_lines[i-1], filters param is not in line:{}.format(i-1)output_num (5 len(classes_info)) * 3 # (x,y,w,h置信度 类别的个数) * 每一个cell生成 3 个预测框cfg_lines[i-1] filters{}\n.format(output_num)for i in classes_lines:assert classes in cfg_lines[i-1], classes param is not in line:{}.format(i-1)cfg_lines[i-1] classes{}\n.format(len(classes_info))with open(save_cfg_path, w) as w:w.writelines(cfg_lines)def main():# 统计训练集和验证集的数据并生成相应 txt文件train_txt_path data/my_train_data.txtval_txt_path data/my_val_data.txtcalculate_data_txt(train_txt_path, train_annotation_dir) # 所有训练集的路径calculate_data_txt(val_txt_path, val_annotation_dir) # 所有验证集的路径# 获取检测的所有类别classes_info [line.strip() for line in open(classes_label, r).readlines() if len(line.strip()) 0]# 创建data.data文件记录classes个数, train以及val数据集文件(.txt)路径和 label.names文件路径create_data_data(./data/my_data.data, train_txt_path, val_txt_path, classes_info)# 根据yolov3-spp.cfg创建my_yolov3.cfg文件修改其中的predictor filters以及yolo classes参数(这两个参数是根据类别数改变的)change_and_create_cfg_file(classes_info)if __name__ __main__:train_annotation_dir ./my_yolo_dataset/train/labels # 训练集的标注文件val_annotation_dir ./my_yolo_dataset/val/labels # 验证集的标注文件classes_label ./data/my_data_label.names # 检测的分类labelcfg_path ./cfg/yolov3-spp.cfg # 官方的yolov3-spp 的配置文件assert os.path.exists(train_annotation_dir), train_annotation_dir not exist!assert os.path.exists(val_annotation_dir), val_annotation_dir not exist!assert os.path.exists(classes_label), classes_label not exist!assert os.path.exists(cfg_path), cfg_path not exist!main()3. 代码讲解 代码有些部分自己又加了些注释这里会挑着讲解 首先将相关路径设定好 3.1 生成 my_train_data.txt和my_val_data.txt 然后生成数据集图片的路径这里训练集和测试集一样只讲解训练集 对于训练集来说写入my_train_data.txt 文件。 其中file_name 就是labels 下面文件名因为这里文件名就是图片的名称。通过路径替换就能、后缀替换就可以找到images所有的图片完整路径写入my_train_data.txt 文件即可 生成的my_train_data.txt 和my_val_data.txt 如下 3.2 生成 my_data.data 文件 代码如下 其中classes_info 信息如下[aeroplane, bicycle, bird, boat, bottle, bus, car, cat, chair, cow, diningtable, dog, horse, motorbike, person, pottedplant, sheep, sofa, train, tvmonitor] 其实就是分类的名称 然后进入create_data_data 函数内部将对应的文件路径写入即可 my_data.data 文件 3.3  生成 my_yolov3.cfg 因为不同检测任务的分类个数可能不同因此需要更改yolo的配置信息 实现的方式如下 因为yolo输出是三个尺度的而 filters_lines [636, 722, 809] classes_lines [643, 729, 816]就是对应三个尺度的信息。除了检测的类别更改自定义数据集的类别个数外。预测框输出的tensor也和类别有关 如下官方的classes 是coco所以是80类别。这里使用的是pascal voc 所以是20类别 75 x、y、w、h置信度 类别个数* 3(每一个cell生成3个预测框)  25 * 3 官方是  5 80*3 255 3.4 关于my_data_label.names文件 如果本身就是yolo 数据集的话是不需要进行第一节的操作的 那么这个文件my_data_label.names是不存在的需要手工建立如下 只需要更改文件名就行了
http://www.w-s-a.com/news/25109/

相关文章:

  • 成都私人网站建设seo网站推广方案策划书
  • 广州网站建设工作室wordpress log
  • 网站后台添加wordpress h1标签优化
  • 自己做网站都需要什么高密 网站建设
  • 网站语言选择郑州本地做团购的网站
  • dw网页设计模板图片谷歌wordpress优化
  • 网站seo优化要怎么做礼品公司怎么做网站
  • 做网页网站需要钱吗提供常州微信网站建设
  • 网站建设文化效果广东网站建设哪家有
  • 毕业设计做网站怎样做特别一点在线网页制作软件
  • html网站代码上海这边敲墙拆旧做啥网站的比较多
  • 微网站怎么用在线crm管理系统
  • 中国城乡建设部人力网站首页如何利用某个软件做一个网站
  • 个人承接网站建设wordpress editor
  • 建站主机 wordpress专业的菏泽网站建设公司
  • 网站响应时间 标准网站建设色调的
  • 网站开发的合同网站建设 设计
  • 网站开发设置网页端口申请免费个人网站空间
  • 制作广告网站的步骤云服务器做网站
  • ipv6可以做网站吗东莞网站建站推广
  • 注册功能的网站怎么做做网站容易还是编程容易
  • wordpress建立目录seo编辑培训
  • 网站怎么群发广州现在可以正常出入吗
  • 微信有网站开发吗多语种网站
  • 深圳网站设计 建设首选深圳市室内设计公司排名前50
  • 上海网站建设 觉策动力wordpress接口开发
  • 网站建设服务器的选择方案小型视频网站建设
  • 江宁做网站价格扬州立扬计算机培训网站建设怎么样
  • 手表网站背景开发新客户的十大渠道
  • 定制网站设计wordpress写的网站