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

网站建设的所需解决的技术问题线上推广的公司

网站建设的所需解决的技术问题,线上推广的公司,长沙望城建设局网站,wordpress多文件传递变量在深度学习领域,YOLO(You Only Look Once)系列模型因其高效和准确性而广受欢迎。然而,随着项目需求的变化,有时我们需要对预训练模型的配置文件进行调整。本文将详细介绍如何使用Python脚本自动转换YOLOv5的配置文件到…

在深度学习领域,YOLO(You Only Look Once)系列模型因其高效和准确性而广受欢迎。然而,随着项目需求的变化,有时我们需要对预训练模型的配置文件进行调整。本文将详细介绍如何使用Python脚本自动转换YOLOv5的配置文件到https://github.com/ultralytics/ultralytics,并解释每个步骤的目的和实现方法。

准备工作

首先,确保安装了必要的库:

pip install pyyaml

代码详解

定义格式化和过滤函数

def format_and_filter_list(lst):formatted_items = []for item in lst:if isinstance(item, list):processed_item = format_and_filter_list(item)if processed_item:  # 只添加非空列表formatted_items.append(processed_item)elif isinstance(item, str):if item == 'nearest':formatted_items.append(f"'{item}'")elif item != 'anchors':  # 过滤掉 'anchors'formatted_items.append(item)else:formatted_items.append(str(item))return f"[{', '.join(formatted_items)}]"

定义转换配置函数

def transform_config(original_config):transformed = {'nc': original_config['nc'],  # number of classes'scales': {'n': [original_config['depth_multiple'], original_config['width_multiple'], 1024]},'backbone': [],'head': []}# Transform backbonefor layer in original_config['backbone']:if not isinstance(layer, list):layer = [layer]transformed['backbone'].append(layer)# Adjust the head to match the desired format, also updating nc and anchors usagefor i, layer in enumerate(original_config['head']):if not isinstance(layer, list):layer = [layer]if isinstance(layer[0], list) and len(layer[0]) > 3 and layer[0][3] == 'Detect':layer[0][3] = ['nc', 'anchors']transformed['head'].append([layer[0]])else:transformed['head'].append(layer)# Special case: update the final Detect layer configurationif transformed['head'] and isinstance(transformed['head'][-1], list) and transformed['head'][-1]:last_layer = transformed['head'][-1]if isinstance(last_layer[0], list) and len(last_layer[0]) > 3:last_layer[0][3] = ['nc']return transformed

定义主函数以更改YAML文件


def change_yaml(yolov5_config):# Check if input file existsif not os.path.exists(yolov5_config):print(f"Error: Input file '{yolov5_config}' does not exist.")else:old_path = os.path.dirname(yolov5_config)save_path = os.path.dirname(old_path)new_yaml_name_path = os.path.join(save_path, "yolov5_" + os.path.basename(yolov5_config))# Load your YAML filewith open(yolov5_config, 'r') as file:try:original_config = yaml.safe_load(file)except yaml.YAMLError as exc:print(f"Error: Failed to parse YAML file. {exc}")exit(1)transformed_config = transform_config(original_config)# Ensure that each element in backbone and head is a listdef ensure_list_format(config_part):new_config_part = []for item in config_part:if not isinstance(item, list):item = [item]new_config_part.append(item)return new_config_parttransformed_config['backbone'] = ensure_list_format(transformed_config['backbone'])transformed_config['head'] = ensure_list_format(transformed_config['head'])# Generate the formatted YAML contentformatted_yaml_content = f"""# Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license# Ultralytics YOLOv5 object detection model with P3/8 - P5/32 outputs
# Model docs: https://docs.ultralytics.com/models/yolov5
# Task docs: https://docs.ultralytics.com/tasks/detect# Parameters
nc: {transformed_config['nc']} # number of classes
scales: # model compound scaling constants, i.e. 'model=yolov5n.yaml' will call yolov5.yaml with scale 'n'# [depth, width, max_channels]n: {transformed_config['scales']['n']}
# YOLOv5 v6.0 backbone
backbone:
"""for layer in transformed_config['backbone']:layer = format_and_filter_list(layer)print(layer)formatted_yaml_content += f"  - {layer}\n"formatted_yaml_content += """
# YOLOv5 v6.0 head with (P2, P3, P4, P5) outputs
head:
"""for layer in transformed_config['head']:print(layer)if isinstance(layer, list) and layer[2] == 'Conv':formatted_yaml_content += '\n'layer = format_and_filter_list(layer)print(layer)formatted_yaml_content += f"  - {layer}\n"# Save the transformed configuration to a new YAML filewith open(new_yaml_name_path, 'w') as file:file.write(formatted_yaml_content)print(f"Configuration has been transformed and saved to '{new_yaml_name_path}'.")

批量处理多个配置文件

input_path = "/media/lindsay/data/ultralytics-main/ultralytics/cfg/models/v5/yolov5"
input_path_list = [os.path.join(input_path, i) for i in os.listdir(input_path)]
for i in input_path_list:change_yaml(i)

总结

通过上述步骤,您可以轻松地将YOLOv5的配置文件转换为ultralytics-yolov8所需的格式,并且可以批量处理多个配置文件。这个脚本不仅可以帮助您节省时间,还能减少手动操作带来的错误。希望这篇博客能为您提供有价值的指导,让您更高效地管理深度学习项目的配置文件。

完整代码

import yaml
import os# 函数用于格式化列表为所需形式
def format_and_filter_list(lst):formatted_items = []for item in lst:if isinstance(item, list):# 如果是列表类型,则递归调用此函数进行格式化和过滤processed_item = format_and_filter_list(item)if processed_item:  # 只添加非空列表formatted_items.append(processed_item)elif isinstance(item, str):# 特殊处理需要保留引号的字符串if item == 'nearest':formatted_items.append(f"'{item}'")elif item != 'anchors':  # 过滤掉 'anchors'formatted_items.append(item)else:# 其他类型直接转换成字符串表示formatted_items.append(str(item))# 返回格式化后的列表字符串表示return f"[{', '.join(formatted_items)}]"def transform_config(original_config):transformed = {'nc': original_config['nc'],  # number of classes'scales': {'n': [original_config['depth_multiple'], original_config['width_multiple'], 1024]},'backbone': [],'head': []}# Transform backbonefor layer in original_config['backbone']:if not isinstance(layer, list):layer = [layer]transformed['backbone'].append(layer)# Adjust the head to match the desired format, also updating nc and anchors usagefor i, layer in enumerate(original_config['head']):if not isinstance(layer, list):layer = [layer]if isinstance(layer[0], list) and len(layer[0]) > 3 and layer[0][3] == 'Detect':# Update Detect layer to use 'nc' instead of specific numbers for classeslayer[0][3] = ['nc', 'anchors']transformed['head'].append([layer[0]])else:transformed['head'].append(layer)# Special case: update the final Detect layer configurationif transformed['head'] and isinstance(transformed['head'][-1], list) and transformed['head'][-1]:last_layer = transformed['head'][-1]if isinstance(last_layer[0], list) and len(last_layer[0]) > 3:last_layer[0][3] = ['nc']return transformeddef change_yaml(yolov5_config):# Check if input file existsif not os.path.exists(yolov5_config):print(f"Error: Input file '{yolov5_config}' does not exist.")else:old_path = os.path.dirname(yolov5_config)save_path = os.path.dirname(old_path)new_yaml_name_path = os.path.join(save_path, "yolov5_" + os.path.basename(yolov5_config))# Load your YAML filewith open(yolov5_config, 'r') as file:try:original_config = yaml.safe_load(file)except yaml.YAMLError as exc:print(f"Error: Failed to parse YAML file. {exc}")exit(1)transformed_config = transform_config(original_config)# Ensure that each element in backbone and head is a listdef ensure_list_format(config_part):new_config_part = []for item in config_part:if not isinstance(item, list):item = [item]new_config_part.append(item)return new_config_parttransformed_config['backbone'] = ensure_list_format(transformed_config['backbone'])transformed_config['head'] = ensure_list_format(transformed_config['head'])# Generate the formatted YAML contentformatted_yaml_content = f"""# Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license# Ultralytics YOLOv5 object detection model with P3/8 - P5/32 outputs
# Model docs: https://docs.ultralytics.com/models/yolov5
# Task docs: https://docs.ultralytics.com/tasks/detect# Parameters
nc: {transformed_config['nc']} # number of classes
scales: # model compound scaling constants, i.e. 'model=yolov5n.yaml' will call yolov5.yaml with scale 'n'# [depth, width, max_channels]n: {transformed_config['scales']['n']}
# YOLOv5 v6.0 backbone
backbone:
"""for layer in transformed_config['backbone']:layer = format_and_filter_list(layer)print(layer)formatted_yaml_content += f"  - {layer}\n"formatted_yaml_content += """
# YOLOv5 v6.0 head with (P2, P3, P4, P5) outputs
head:
"""for layer in transformed_config['head']:print(layer)if isinstance(layer, list) and layer[2] == 'Conv':formatted_yaml_content += '\n'layer = format_and_filter_list(layer)print(layer)formatted_yaml_content += f"  - {layer}\n"# Save the transformed configuration to a new YAML filewith open(new_yaml_name_path, 'w') as file:file.write(formatted_yaml_content)print(f"Configuration has been transformed and saved to '{new_yaml_name_path}'.")input_path = "/media/lindsay/data/ultralytics-main/ultralytics/cfg/models/v5/yolov5"
input_path_list = [os.path.join(input_path, i) for i in os.listdir(input_path)]
for i in input_path_list:change_yaml(i)
http://www.dtcms.com/wzjs/183566.html

相关文章:

  • winform和网站做交互百度灰色关键词排名
  • 做网站的核验单 是下载的吗汕头seo计费管理
  • aspcms网站打不开永久免费用的在线客服系统
  • 网站开发案例加拿大搜索引擎
  • 深圳网站建设怎样容易seo顾问阿亮博客
  • b站倒过来的网站谁做的国内免费域名注册
  • 用手机做网站的软件各大网站的网址
  • windows 2003做网站百度学术论文查重入口
  • 网站建设需要企业石家庄网站建设公司
  • 360网站seo优化怎么做百度推广登陆入口官网
  • 360中小网站建设什么关键词能搜到资源
  • 网站建设格式合肥网站设计
  • 照片展示网站模板免费下载推广资讯
  • 网站建设实训报告的内容怎么写怎么进行网络推广
  • 网站网站建设企业seo优化网页
  • 门户网站建设 工具深圳网络营销渠道
  • 建网站需要了解哪些网站建设知识建站软件
  • 网站开发公司是互联网公司seo技术外包 乐云践新专家
  • 泉州seo网站关键词优营销软文500字
  • 网站建设公司何去何从关键词排名怎么上首页
  • 网站后台管理模板html网站域名费一年多少钱
  • 建手机网站什么是seo搜索优化
  • 如何做电影网站赚钱吗谷歌广告上海有限公司
  • 怎么把自己做的网站放到公网上网络营销方案策划论文
  • 香港网站 淘宝客营销案例分析报告模板
  • 浙江网站建设费用百度竞价推广出价技巧
  • 自己用dw做网站要多久网站seo优化怎么做
  • 如东网站建设自己建网站的详细步骤
  • 如何修改网站title电商平台开发
  • 莱芜网站建设企业网络营销推广方法