tensorflow

不需要手写CUDA代码能跑GPU;
容易构建大的计算图
Tensorflow包含以下特性:
模型的建立与调试、模型的训练、模型的部署、预训练模型调用
tf2.0将专注于简单性和易用性
使用keras和eager execution轻松构建模型
在任意平台上实现生产环境的稳健模型部署
为研究提供强大的实验工具
通过清理废弃的api和减少重复来简化api
tf.data加载数据、tf.keras构建训练并验证模型、使用分布式策略进行分布式训练、导出到saved model

tf.keras介绍

tf.keras 数据集

from keras.datasets import cifar100
(x_train,y_train),(x_test,y_test)=cifar100.load_data()

tensorflow基础

import tensorflow as tf

tensorflow使用张量作为基本的计算单位

#定义一个随机数
random_float=tf.random.uniform(shape=())
#定义一个有2个元素的零向量
zero_vector=tf.zzeros(shape=(2))
#定义2*2的常量矩阵
a=tf.constant([[1.,2.],[3.,4.]])
#形状
a.shape
#类型
a.dtype
#数值
a.numpy()

自动求导机制

x=tf.Variable(initial_value=3.)
with tf.GradientTape() as tape:
	y=tf.square(x)
y_grad=tape.gradient(y,x)
optimizer=tf.keras.optimizer.SGD(learning_rate=1e-3)
grads=tape.gradient(loss,variables)
optimizer.apply_gradients(grads_and_vars=zip(grads,variables))

tensorflow快速入门模型

模型构建-model与layer

class mymodel(tf.keras.Model):
	def __init__(self):
		super().__init__()
		layers=tf.keras.layers
	def call(self,input)
		output=layers(inputs)
	return output

迁移学习

tf.keras.applications中有一些预定义好的经典卷积神经网络结构,如VGG16,ResNet,MobileNet

model=tf.keras.application.MobileNetV2(weights=None,classes=5)

keras pipline与自定义模型

mdel=tf.keras.models.Sequential([
tf.keras.layers
tf.keras.layers.Softmax()])
inputs=tf.keras.Inputs(shape=(28,28,1))
x=tf.keras.layers(inputs)
outputs=tf.keras.layers.Softmax()(x)
model=tf.keras.Model(inputs=inputs,outputs=outputs)

使用keras Model的compile、fit和evaluate方法训练和评估模型

model.compile(optimizer,loss,metrics=[‘accuracy’],准确率衡):配置训练的相关参数

model.fit(data_loader.train_data,data_loader.train_label,epochs,batchsize)

model.evaluate(test_image,test_label)

model.save_weights(filepath)
model.load_weights(filepath,by_name=False)

tf常用功能模块

callbacks:
定制化保存模型,保存events文件

tensorboard:观察损失等情况

tf.data:数据集的构建与预处理

dataset=tf.data.Dataset.from_tensor_slices((x,y))
for x,y in dataset:

Datasets.map(f):对数据通过f函数解码
Datasets.shuffle(buffer_size):打乱
Datasets.batch(batch_size):批次处理

#数据增强
tf.keras.preprocessing.image.ImageDataGenerator()

读取目录

train_generator.flow_from_directory()
# 工程内容 这个程序是基于tensorflow的tflearn库实现部分RCNN功能。 # 开发环境 windows10 + python3.5 + tensorflow1.2 + tflearn + cv2 + scikit-learn # 数据集 采用17flowers据集, 官网下载:http://www.robots.ox.ac.uk/~vgg/data/flowers/17/ # 程序说明 1、setup.py---初始化路径 2、config.py---配置 3、tools.py---进度条和显示带框图像工具 4、train_alexnet.py---大数据集预训练Alexnet网络,140个epoch左右,bitch_size为64 5、preprocessing_RCNN.py---图像的处理(选择性搜索、数据存取等) 6、selectivesearch.py---选择性搜索源码 7、fine_tune_RCNN.py---小数据集微调Alexnet 8、RCNN_output.py---训练SVM并测试RCNN(测试的时候测试图片选择第7、16类中没有参与训练的,单朵的花效果好,因为训练用的都是单朵的) # 文件说明 1、train_list.txt---预训练数据,数据在17flowers文件夹中 2、fine_tune_list.txt---微调数据2flowers文件夹中 3、1.png---直接用选择性搜索的区域划分 4、2.png---通过RCNN后的区域划分 # 程序问题 1、由于数据集小的原因,在微调时候并没有像论文一样按一个bitch32个正样本,128个负样本输入,感觉正样本过少; 2、还没有懂最后是怎么给区域打分的,所有非极大值抑制集合canny算子没有进行,待续; 3、对选择的区域是直接进行缩放的; 4、由于数据集合论文采用不一样,但是微调和训练SVM时采用的IOU阈值一样,有待调参。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值