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

无极app定制开发公司网站模板关键词优化案例

无极app定制开发公司网站模板,关键词优化案例,西安营销型网站建设,室内设计网页1. NVIDIA DALI简介 NVIDIA DALI全称是NVIDIA Data Loading Library,是一个用GPU加速的数据加载和预处理库,可用于图像、视频和语音数据的加载和处理,从而为深度学习的训练和推理加速。 NVIDIA DALI库的出发点是,深度学习应用中…

1. NVIDIA DALI简介

NVIDIA DALI全称是NVIDIA Data Loading Library,是一个用GPU加速的数据加载和预处理库,可用于图像、视频和语音数据的加载和处理,从而为深度学习的训练和推理加速。

NVIDIA DALI库的出发点是,深度学习应用中复杂的数据处理pipeline,如数据加载、解码、裁剪、Resize等功能,在CPU上处理已经成为瓶颈,限制了深度学习训练和推理的性能及可扩展性。DALI库通过使用GPU来处理这些功能,并封装了pre-fetch、并行执行、批处理等功能,降低用户的编程难度。

NVIDIA可适配于多种深度学习框架,如TensorFlow、PyTorch、MXNet和PaddlePaddle。

2. NVIDIA DALI安装

目前NVIDIA DALI只支持Linux x64系统,且CUDA版本在CUDA 11.0以上。

对于CUDA 11.X版本,安装命令行:

pip install --extra-index-url https://developer.download.nvidia.com/compute/redist --upgrade nvidia-dali-cuda110

对于CUDA 12.X版本,安装命令行如下:

pip install --extra-index-url https://developer.download.nvidia.com/compute/redist --upgrade nvidia-dali-cuda120

3. 读取视频帧

在深度学习应用中,我们常常需要从视频文件或者图像序列构建数据库。这一节就通过一个小例子说明如何用NVIDIA DALI从视频文件中读取指定数量视频帧。

最简单的使用方式,是通过@pipeline_def修饰符来定义nvidia dali pipeline,如下例,我们定义一个从视频文件(通过filenames指定视频文件列表)读取指定数量视频帧(通过sequence_length指定)的pipeline。

# Define a video pipeline
@pipeline_def
def video_pipeline(filenames, sequence_length):videos = fn.readers.video(device='gpu', filenames=filenames, sequence_length=sequence_length, name='Reader')return videos

 然后对以上定义的pipeline实例化:

sequence_length = 25
video_directory = r'/home/grace/BSVD/datasets/DAVIS-training-mp4'
video_files = [video_directory + '/' + f for f in os.listdir(video_directory)]# Build the video pipeline
pipe = video_pipeline(batch_size=1, num_threads=2, device_id=0, filenames=video_files, sequence_length=sequence_length, seed=123456)
pipe.build()

实例化过程中,可以传入其他pipeline参数,如batch_size、num_threads等。

构建完成后,通过pipeline.run()来实现视频帧的输出,默认为RGB类型。

for i in range(0,20):pipe_out = pipe.run()sequence_out = pipe_out[0].as_cpu().as_array()print('i = {}, sequence shape = {}'.format(i, sequence_out.shape))# show_sequence(sequence_out[0])save_images(i, sequence_out[0])   # 保存读取到的图像序列

4. 读取图像序列

除了从视频文件中读取视频帧,NVIDIA DALI还提供从图像序列读取数据的功能。

参考nvidia dali官方说明文档中的一个示例,亲测有效。

from nvidia.dali import pipeline_def
import nvidia.dali.fn as fn
import nvidia.dali.types as types# Define a function for showing output image
import matplotlib.gridspec as gridspec
import matplotlib.pyplot as plt
%matplotlib inlinedef show_images(image_batch):columns = 4rows = (max_batch_size + 1) // (columns)fig = plt.figure(figsize = (24,(24 // columns) * rows))gs = gridspec.GridSpec(rows, columns)for j in range(rows*columns):plt.subplot(gs[j])plt.axis("off")plt.imshow(image_batch.at(j))# image sequence dir
image_dir = "data/images"
max_batch_size = 8# Define an image sequence reading pipeline
@pipeline_def
def simple_pipeline():jpegs, labels = fn.readers.file(file_root=image_dir)images = fn.decoders.image(jpegs, device='cpu')return images, labels# Build the pipeline
pipe = simple_pipeline(batch_size=max_batch_size, num_threads=1, device_id=0)
pipe.build()# Run the pipeline and show outputpipe_out = pipe.run()
images, labels = pipe_out
show_images(images)

输出结果如下:

除了以上基础用法,nvidia dali还集成了很多数据增广方法,如旋转、剪切、resize等等,今天由于时间关系,下次再继续补充吧。 

http://www.shuangfujiaoyu.com/news/50235.html

相关文章:

  • 石家庄求做网站技能培训班有哪些
  • 如何给英文网站做外链搜狗seo查询
  • 做高仿表网站容易被k吗如何实现网站的快速排名
  • 做企业网站哪家强最佳bt磁力猫
  • 加强普法网站和普法网络集群建设怎么在百度做宣传广告
  • 专业做轮胎的网站seo交流网
  • 做一家网站要多少钱长春模板建站代理
  • 全国网站建设公北京百度推广官网首页
  • 网站怎么做下载市场调研分析报告模板
  • seo快速排名优化方法优化搜狗排名
  • 制作 网站 盈利市场营销实务
  • 优秀产品设计作品抖音seo优化排名
  • 有个专门做3d同人网站怎样做线上销售
  • 织梦做的网站前面有不安全it培训机构培训费用
  • 做网站和做app哪个简单网络推广公司企业
  • 阿里巴巴有几个网站是做外贸的搜索引擎营销的主要方式有
  • 营销网站建设步骤东莞百度快照优化排名
  • 惠州高端网站建设芜湖seo
  • 黄埔网站建设 信科网络自助建站系统平台
  • 网站怎么做关键词在哪做企业做推广有用吗
  • 齐河网站建设华与华营销策划公司
  • 禅城网站建设报价网推拉新app推广平台
  • 做网站团队适合seo软件
  • 免费网站java源码大全小说八百客crm系统登录入口
  • 做公司网站成本关键词搜索排行榜
  • 模板之家官网首页seo搜索引擎优化书籍
  • 网站后台搭建图文优就业seo怎么样
  • 微信app网站建设免费投放广告的平台
  • 网站建设的实训周制作网站的软件有哪些
  • wordpress去掉工具栏seo免费教程