slim.arg_scope()的使用
【https://blog.csdn.net/u013921430 转载】
slim是一种轻量级的tensorflow库,可以使模型的构建,训练,测试都变得更加简单。在slim库中对很多常用的函数进行了定义,slim.arg_scope()是slim库中经常用到的函数之一。函数的定义如下;
-
@tf_contextlib.contextmanager
-
def arg_scope(list_ops_or_scope, **kwargs):
-
"""Stores the default arguments for the given set of list_ops.
-
-
For usage, please see examples at top of the file.
-
-
Args:
-
list_ops_or_scope: List or tuple of operations to set argument scope for or
-
a dictionary containing the current scope. When list_ops_or_scope is a
-
dict, kwargs must be empty. When list_ops_or_scope is a list or tuple,
-
then every op in it need to be decorated with @add_arg_scope to work.
-
**kwargs: keyword=value that will define the defaults for each op in
-
list_ops. All the ops need to accept the given set of arguments.
-
-
Yields:
-
the current_scope, which is a dictionary of {op: {arg: value}}
-
Raises:
-
TypeError: if list_ops is not a list or a tuple.
-
ValueError: if any op in list_ops has not be decorated with @add_arg_scope.
-
"""
-
if isinstance(list_ops_or_scope, dict):
-
# Assumes that list_ops_or_scope is a scope that is being reused.
-
if kwargs:
-
raise ValueError('When attempting to re-use a scope by suppling a'
-
'dictionary, kwargs must be empty.')
-
current_scope = list_ops_or_scope.copy()
-
try:
-
_get_arg_stack().append(current_scope)
-
yield current_scope
-
finally:
-
_get_arg_stack().pop()
-
else:
-
# Assumes that list_ops_or_scope is a list/tuple of ops with kwargs.
-
if not isinstance(list_ops_or_scope, (list, tuple)):
-
raise TypeError('list_ops_or_scope must either be a list/tuple or reused'
-
'scope (i.e. dict)')
-
try:
-
current_scope = current_arg_scope().copy()
-
for op in list_ops_or_scope:
-
key_op = _key_op(op)
-
if not has_arg_scope(op):
-
raise ValueError('%s is not decorated with @add_arg_scope',
-
_name_op(op))
-
if key_op in current_scope:
-
current_kwargs = current_scope[key_op].copy()
-
current_kwargs.update(kwargs)
-
current_scope[key_op] = current_kwargs
-
else:
-
current_scope[key_op] = kwargs.copy()
-
_get_arg_stack().append(current_scope)
-
yield current_scope
-
finally:
-
_get_arg_stack().pop()
如注释中所说,这个函数的作用是给list_ops中的内容设置默认值。但是每个list_ops中的每个成员需要用@add_arg_scope修饰才行。所以使用slim.arg_scope()有两个步骤:
- 使用@slim.add_arg_scope修饰目标函数
- 用 slim.arg_scope()为目标函数设置默认参数.
例如如下代码;首先用@slim.add_arg_scope修饰目标函数fun1(),然后利用slim.arg_scope()为它设置默认参数。
-
import tensorflow as tf
-
slim =tf.contrib.slim
-
-
@slim.add_arg_scope
-
def fun1(a=0,b=0):
-
return (a+b)
-
-
with slim.arg_scope([fun1],a=10):
-
x=fun1(b=30)
-
print(x)
运行结果为:
40
平常所用到的slim.conv2d( ),slim.fully_connected( ),slim.max_pool2d( )等函数在他被定义的时候就已经添加了@add_arg_scope。以slim.conv2d( )为例;
-
@add_arg_scope
-
def convolution(inputs,
-
num_outputs,
-
kernel_size,
-
stride=1,
-
padding='SAME',
-
data_format=None,
-
rate=1,
-
activation_fn=nn.relu,
-
normalizer_fn=None,
-
normalizer_params=None,
-
weights_initializer=initializers.xavier_initializer(),
-
weights_regularizer=None,
-
biases_initializer=init_ops.zeros_initializer(),
-
biases_regularizer=None,
-
reuse=None,
-
variables_collections=None,
-
outputs_collections=None,
-
trainable=True,
-
scope=None):
所以,在使用过程中可以直接slim.conv2d( )等函数设置默认参数。例如在下面的代码中,不做单独声明的情况下,slim.conv2d, slim.max_pool2d, slim.avg_pool2d三个函数默认的步长都设为1,padding模式都是'VALID'的。但是也可以在调用时进行单独声明。这种参数设置方式在构建网络模型时,尤其是较深的网络时,可以节省时间。
-
with slim.arg_scope(
-
[slim.conv2d, slim.max_pool2d, slim.avg_pool2d],stride = 1, padding = 'VALID'):
-
net = slim.conv2d(inputs, 32, [3, 3], stride = 2, scope = 'Conv2d_1a_3x3')
-
net = slim.conv2d(net, 32, [3, 3], scope = 'Conv2d_2a_3x3')
-
net = slim.conv2d(net, 64, [3, 3], padding = 'SAME', scope = 'Conv2d_2b_3x3')
@修饰符
其实这种用法是python中常用到的。在python中@修饰符放在函数定义的上方,它将被修饰的函数作为参数,并返回修饰后的同名函数。形式如下;
-
@fun_a #等价于fun_a(fun_b)
-
def fun_b():
这在本质上讲跟直接调用被修饰的函数没什么区别,但是有时候也有用处,例如在调用被修饰函数前需要输出时间信息,我们可以在@后方的函数中添加输出时间信息的语句,这样每次我们只需要调用@后方的函数即可。
-
def funs(fun,factor=20):
-
x=fun()
-
print(factor*x)
-
-
-
@funs #等价funs(add(),fator=20)
-
def add(a=10,b=20):
-
return(a+b)
slim.arg_scope()的使用的更多相关文章
- slim.arg_scope中python技巧
slim.arg_scope函数说明如下: Stores the default arguments for the given set of list_ops. For usage, please ...
- tf.contrib.slim arg_scope
缘由 最近一直在看深度学习的代码,又一次看到了slim.arg_scope()的嵌套使用,具体代码如下: with slim.arg_scope( [slim.conv2d, slim.separab ...
- 使用多块GPU进行训练 1.slim.arg_scope(对于同等类型使用相同操作) 2.tf.name_scope(定义名字的范围) 3.tf.get_variable_scope().reuse_variable(参数的复用) 4.tf.py_func(构造函数)
1. slim.arg_scope(函数, 传参) # 对于同类的函数操作,都传入相同的参数 from tensorflow.contrib import slim as slim import te ...
- 【Tensorflow】slim.arg_scope()的使用
https://blog.csdn.net/u013921430/article/details/80915696
- TensorFlow和最近发布的slim
笔者将和大家分享一个结合了TensorFlow和最近发布的slim库的小应用,来实现图像分类.图像标注以及图像分割的任务,围绕着slim展开,包括其理论知识和应用场景. 之前自己尝试过许多其它的库,比 ...
- 用tensorlayer导入Slim模型迁移学习
上一篇博客[用tensorflow迁移学习猫狗分类]笔者讲到用tensorlayer的[VGG16模型]迁移学习图像分类,那麽问题来了,tensorlayer没提供的模型怎么办呢?别担心,tensor ...
- tf.contrib.slim add_arg_scope
上一篇文章中我们介绍了arg_scope函数,它在每一层嵌套中update当前字典中参数形成新的字典,并入栈.那么这些参数是怎么作用到代码块中的函数的呢?比如说如下情况: with slim.arg_ ...
- 第二十四节,TensorFlow下slim库函数的使用以及使用VGG网络进行预训练、迁移学习(附代码)
在介绍这一节之前,需要你对slim模型库有一些基本了解,具体可以参考第二十二节,TensorFlow中的图片分类模型库slim的使用.数据集处理,这一节我们会详细介绍slim模型库下面的一些函数的使用 ...
- 第二十二节,TensorFlow中的图片分类模型库slim的使用、数据集处理
Google在TensorFlow1.0,之后推出了一个叫slim的库,TF-slim是TensorFlow的一个新的轻量级的高级API接口.这个模块是在16年新推出的,其主要目的是来做所谓的“代码瘦 ...
随机推荐
- Blueprint的实现
Blueprint其实本身只是对view上的接口进行了注册,然后整体挂载在app上,Blueprint本身的目的就是组织多模块的平行共存,避免直接在app上注册view,其实更多的只是方便开发和代码的 ...
- 如何通过命令行编写调试第一个C++程序(UNIX)
1.文件保存以.cc,.cpp等结尾: 2.bash窗口调试命令:cc prog1.cc,编译器生成可执行问价,Unix系统中为a.out,windows中一般以filename.exe; 3.(1) ...
- mongodb C#连接报错 Invalid credentials for database 'admin'
这2天学习mongodb3.2.9,用户设置好了,结果用C#查询的时候报错了,看字面意思是用户验证没通过,但是我用shell是完全没有问题的,后来网上搜了下,发现原来是我用的是旧驱动,旧驱动用的是旧的 ...
- 【leetcode】1006. Clumsy Factorial
题目如下: Normally, the factorial of a positive integer n is the product of all positive integers less t ...
- mysql中int的长度与值的问题
我们在数据库中设置一个int类型,设置好长度,然后会发现并没有受到长度的限制,这是因为,int值的范围和这个长度根本没有关系. int的存储大小是4个字节(B), 计算机存储单位的换算: 1B=8b ...
- BZOJ 4059: [Cerc2012]Non-boring sequences(启发式分治)
传送门 解题思路 首先可以想到要预处理一个\(nxt_i\)和\(pre_i\),表示前后与当前位置权值相同的节点,那么这样可以迅速算出某个点在某段区间是否出现多次.然后这样的话就考虑分治,对于\([ ...
- BZOJ 4421: [Cerc2015] Digit Division(思路)
传送门 解题思路 差点写树套树...可以发现如果几个数都能被\(m\)整除,那么这几个数拼起来也能被\(m\)整除.同理,如果一个数不能被\(m\)整除,那么它无论如何拆,都无法拆成若干个可以被\(m ...
- PHP基础知识总结(三) 流程控制、函数、类对象和数据库
PHP基础语法 1.流程控制 条件语句:if elseif else / switch if($a == 1){ …… } elseif ($a == 2){ …… } else{ …… } 循环 ...
- react 中使用 JsBarcode 显示条形码
import React from 'react';import JsBarcode from 'jsbarcode'; export class RefundSheet extends React. ...
- (61)C# 可枚举类型和迭代器
一.可枚举类型 枚举器-Enumerator 是一个只读且只能在值序列向前移动的游标 枚举器需要实现下列接口之一 System.Collections.IEnumerator System.Coll ...