使用TVM将深度学习模型编译为WebGL TVM带有全新的OpenGL / WebGL后端! OpenGL / WebGL后端 TVM已经瞄准了涵盖各种平台的大量后端:CPU,GPU,移动设备等.这次,添加了另一个后端:OpenGL / WebGL. OpenGL / WebGL使能够在未安装CUDA的环境中利用GPU.在浏览器中使用GPU的方法. 后端允许以3种不同的方式使用OpenGL / WebGL: 本地OpenGL:可以将深度学习模型编译为OpenGL,完全使用Python在本地计算机…
  0x00 PyTorch是什么? PyTorch是一个基于Python的科学计算工具包,它主要面向两种场景: 用于替代NumPy,可以使用GPU的计算力 一种深度学习研究平台,可以提供最大的灵活性和速度 0x01 开始学习 1.Tensors Tensors(张量)类似于numpy的ndarrays,不过Tensors还可以运行于GPU上以提升计算速度. from __future__ import print_function import torch 创建一个5x3且未初始化的矩阵: x…
  神经网络可以通过使用torch.nn包来构建. 既然你已经了解了autograd,而nn依赖于autograd来定义模型并对其求微分.一个nn.Module包含多个网络层,以及一个返回输出的方法forward(input) . 例如,查看下图中的对数字图片分类的网络: 这是一个简单的前馈网络.它接受输入,并将输入依次通过多个层,然后给出输出结果. 对于神经网络来说,一个经典的训练过程包括以下步骤: 定义一个包含一些可学习的参数(或权重)的神经网络 对输入数据集进行迭代 通过网络处理输入 计算…
  在本节中,我们将学习如何利用DataParallel使用多个GPU. 在PyTorch中使用多个GPU非常容易,你可以使用下面代码将模型放在GPU上: model.gpu() 然后,你可以将所有张量拷贝到GPU上: mytensor = my_tensor.gpu() 请注意,仅仅调用my_tensor.gpu()并不会将张量拷贝到GPU上,你需要将它指派给一个新的张量,然后在GPU上使用这个新张量. 在多个GPU上执行你的前向和后向传播是一件很自然的事情.然而,PyTorch默认情况下只会…
  太棒啦!到目前为止,你已经了解了如何定义神经网络.计算损失,以及更新网络权重.不过,现在你可能会思考以下几个方面: 0x01 数据集 通常,当你需要处理图像.文本.音频或视频数据时,你可以使用标准的python包将数据加载到numpy数组中.然后你可以将该数组转换成一个torch.*Tensor. 对于图像,Pillow.OpenCV这些包将有所帮助. 对于音频,可以使用scipy和librosa包. 对于文本,无论是基于原始的Python还是Cython的加载,或者NLTK和SpaCy都将…
  在PyTorch中,集中于所有神经网络的是autograd包.首先,我们简要地看一下此工具包,然后我们将训练第一个神经网络. autograd包为张量的所有操作提供了自动微分.它是一个运行式定义的框架,这意味着你的后向传播是由你的代码运行方式来定义的,并且每一个迭代都可以是不同的. 下面,让我们使用一些更简单的术语和例子来解释这个问题. 0x01 变量(Variable) autograd.Variable是autograd包的核心类,它封装了一个张量,并支持几乎所有在该张量上定义的操作.一…
  说明:本系列教程翻译自PyTorch官方教程<Deep Learning with PyTorch: A 60 Minute Blitz>,基于PyTorch 0.3.0.post4   教程目标 在高层次上理解PyTorch的Tensor库和神经网络 训练一个小型的神经网络来分类图像 前提条件 假设读者熟悉基础的NumPy库 确保已经安装了torch和torchvision包 系列目录 PyTorch是什么? Autograd:自动化微分 神经网络 训练分类器 数据并行化…
  利用 TFLearn 快速搭建经典深度学习模型 使用 TensorFlow 一个最大的好处是可以用各种运算符(Ops)灵活构建计算图,同时可以支持自定义运算符(见本公众号早期文章<TensorFlow 增加自定义运算符>).由于运算符的粒度较小,在构建深度学习模型时,代码写出来比较冗长,比如实现卷积层:5, 9 这种方式在设计较大模型时会比较麻烦,需要程序员徒手完成各个运算符之间的连接,像一些中间变量的维度变换.运算符参数选项.多个子网络连接处极易发生问题,肉眼检查也很难发现代码中潜伏的…
本文适合有 Java 基础的人群 作者:DJL-Keerthan&Lanking HelloGitHub 推出的<讲解开源项目> 系列.这一期是由亚马逊工程师:Keerthan Vasist,为我们讲解 DJL(完全由 Java 构建的深度学习平台)系列的第 4 篇. 一.前言 很长时间以来,Java 都是一个很受企业欢迎的编程语言.得益于丰富的生态以及完善维护的包和框架,Java 拥有着庞大的开发者社区.尽管深度学习应用的不断演进和落地,提供给 Java 开发者的框架和库却十分短缺.…
概述 Apple的Core ML 3是一个为开发人员和程序员设计的工具,帮助程序员进入人工智能生态 你可以使用Core ML 3为iPhone构建机器学习和深度学习模型 在本文中,我们将为iPhone构建一个全新的应用程序! 介绍 想象一下,在不需要深入了解机器学习的情况下,使用最先进的机器学习模型来构建应用程序.这就是Apple的Core ML 3! 你是Apple的狂热粉丝吗?你用iPhone吗?有没有想过Apple是如何利用机器学习和深度学习来驱动其应用和软件的? 如果你对以上任何一个问题…