本文主要介绍如何搭建一个网络并训练

最近,我在写代码时经常碰到这样的情况,明明记得代码应该怎么写,在写出来的代码调试时,总是有些小错误。原因不是接口参数个数不对,就是位置不对。为了节约上网查找时间,现记录下常用操作,以备需要时快速查看。

根据网络结构不同功能,主要分这几大块:网络基本结构元组件,网络常用结构,Tensorboard调试接口,数据预处理常用操作,后处理常用操作。

1、搭建一个基础网络所需的元组件:

import tensorflow as tf
import glog as log class basenet(object):
'''
base model for other specific cnn
'''
def __init__(self):
pass def weight_variable(self,shape,sdtdev=0.1,name):
initial=tf.truncated_normal(shape=shape,mean=0.0,stddev=sdtdev)
if name is None:
return tf.Variable(initial)
else:
return tf.get_variable(name=name,initial=initialdef bias_variable(self,shape,name): initial=tf.constant(.01,shape=shape)
     if name is None:
return tf.Variable(initial,name=name)
else:
return tf.get_variable(name=name,initial=initial)
@staticmethod
def conv2d(self,x,w,s=1,name=None,padding='SAME'):
#with tf.variable_scope(name):
if s == 1:
x = tf.nn.conv2d(x,w,strides=[1,s,s,1],padding=padding)
else:
x = tf.nn.conv2d(x,w,strides=[1,s,s,1],padding=padding)
#log.info('basenet conv2d x:{:}'.format(x.get_shape().as_list()))
return x def conv2d_transpose(x,w,b,output_shape,stride=2):
if output_shape is None:
output_shape =x.get_shape().as_list()
output_shape[1]*=2
output_shape[2]*=2
output_shape[3]=w.get_shape().as_list()[2]
conv = tf.nn.conv2d_transpose(x,w,output_shape,strides=[1,stride,stride,1],padding='SAME')
return tf.nn.bias_add(conv,b)
def maxpool(self,x,k=2,s=2,padding='SAME'):
x= tf.nn.max_pool(x,ksize=[1,k,k,1],strides=[1,s,s,1],padding=padding)
return x def avgpool(self,x,k,s,padding='SAME'):
x= tf.nn.avg_pool(x,ksize=[1,k,k,1],strides=[1,s,s,1],padding=padding)

def local_response_norm(x):
return tf.nn.lrn(x,depth_radius=5,bias=2,alpha=1e-4,beta=0.75)
def relu(self,x,name):
x = tf.nn.relu(x)
return x def leaky_relu(x,alpha=0.0,name=""):
return tf.maximum(alpha*x,x,name) def relu6(self,x):
x= min(max(0,x), 6)
x = tf.nn.relu(x)
return x

def batch_norm(x,output,phrase,scope='bn',decay=0.9,eps=1e-5):
with tf.variable_scope(scope):
beta=tf.get_variable(name='beta',shape=[output],initializer=tf.constant_initializer(0.05))
gamma=tf.get_variable(name='gamma',shape=[output],initialzer=tf.random_normal_initializer(1.0,0.02)
batch_mean,batch_var=tf.nn.moment(x,[0,1,2],name='moment') def mean_var_2_update():
ema_apply_op = ema.apply([batch_mean,batch_var])
with tf.control_dependencies([ema_apply_op]):
return tf.identity(batch_mean),tf.identity(batch_var)
mean,var = tf.cond(phrase,mean_var_2_update,lambda:(ema.average(batch_mean),ema.average(batch_var))
normed = tf.nn.batch_normalization(x,mean,var,beta,gamma,eps)
return normed
def wx_b(self,x,w,b):
x = tf.matmul(x,w)+b
log.info('basenet wx_b x:{:}'.format(x.get_shape().as_list()))
return x def fc(self,x,w,b):
x = tf.add(tf.matmul(x,w),b)
return x

2、常用网络结构

网络结构1:

def bottleneck_unit(x,out_chan1,out_chan2,down_stride=False,up_stride=False,name=None):

3、数据预处理常用操作

def save_img(image,save_dir,name,mean=None):
if mean:
image=unprocess_image(image,mean)
misc.imsave(os.path.join(save_dir,name+'.png'),image) def process_image(image,mean_pixel):
return image-mean_pixel

4、Tensorboard常用接口

def add_regular_to_summary(var):
if var is not None:
tf.summary.histogram(var.op.name,var)
tf.add_to_collection('reg_loss',tf.nn.l2_loss(var)) def add_activation_to_summary(var):
if var is not None:
tf.summary.histogram(var.op.name+'/activation',var)
tf.summary.scalar(var.op.name+'/sparsity',tf.nn.zero_fraction(var)) def add_gradient_to_summary(grad,var):
if grad is not None:
tf.summary.histogram(var.op.name+'/gradient',grad)

TF版网络模型搭建常用代码备忘的更多相关文章

  1. metasploit 常用命令备忘

    metasploit 常用命令备忘    MSFconsole Commands-------------------------------------24show exploits 查看所有exp ...

  2. 代码备忘, TODO宏实现

    代码备忘, TODO宏实现 我们平时在开发过程中, 往往并非憋足气一股脑敲完所有代码.每一个模块, 每一个函数的实现总有个先后顺序. 又或者哪个部分须要做调整, 改动- 所以, 我们须要有一个东西, ...

  3. Linux基础之常用基本命令备忘

    Linux基础之常用基本命令备忘 PWD   查询当前所在Linux上的位置 /         根目录 CD(change directory)切换目录  语法 CD /(注意添加空格)   LS ...

  4. Webstorm常用快捷键备忘(Webstorm入门指南)

    WebStorm 是jetbrains公司旗下一款JavaScript 开发工具.被广大中国JS开发者誉为“Web前端开发神器”.“最强大的HTML5编辑器”.“最智能的JavaSscript IDE ...

  5. sublime 常用快捷键备忘

    转一篇sublime常用的快捷键备忘 sublime常用快捷键 选择类Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本.Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本 ...

  6. Webstorm常用快捷键备忘

    WebStorm 是jetbrains公司旗下一款JavaScript 开发工具.被广大中国JS开发者誉为“Web前端开发神器”.“最强大的HTML5编辑器”.“最智能的JavaSscript IDE ...

  7. Axure常用操作备忘

    目录 前言 技巧 边框重合 复制对象文本居中 复制粘贴样式 文本自适应 给图形添加连接点 导出图片无空白 前言 下面列出Axure画图过程中曾经遇到过的问题,备忘一下,避免别人也走弯路,法布施一下~ ...

  8. CentOS常用命令备忘

    1. 查看进程 ps -a 杀掉进程 kill PID 2. 添加计划任务crontab -e 例如:30 21 * * * service httpd restart 每天21:30重启apache ...

  9. 【荐1】Total Commander 7.57 个人使用设置 及 常用快捷键 备忘

    Total Commander 7.57a  下载地址:http://www.baidu.com/s?wd=total commander 7.57 破解版 软件整体预览图:(注意,下面的版本我用的是 ...

随机推荐

  1. centos安装tidy扩展

    wget http://pecl.php.net/get/tidy-1.2.tgztar -xvzf tidy-1.2.tgzcd tidy-1.2/usr/local/php/bin/phpize. ...

  2. Linux中nohup和&的用法和区别

    在Linux执行任务时,如果键入Ctrl+C退出进行其他任务或者关闭当前session 当前任务就会终止 要想不让进程停止或者让进程在后台运行,就需要一些命令,nohup和&就是一种非常好的方 ...

  3. Packages window(包窗口)

    使用Unity Package Manager(在Unity的顶层菜单中:Window > Package Manager)查看可以安装或已安装在Project中的软件包.此外,您可以使用此窗口 ...

  4. NMS(Non-Maximum Suppression) 非极大值抑制

    NMS  非极大值抑制:找到局部最大值,并删除邻域内其他的值. 简单说一下流程: 首先剔除背景(背景无需NMS),假设有6个边界框,根据分类置信度对这6个边界框做降序排列,假设顺序为A.B.C.D.E ...

  5. Vue.js 关于双向绑定的一些实现细节

    Vue.js 是采用 Object.defineProperty 的 getter 和 setter,并结合观察者模式来实现数据绑定的. 当把一个普通 Javascript 对象传给 Vue 实例来作 ...

  6. vscode自动生成文件头部注释和函数注释

    参考链接:https://blog.csdn.net/sueRimn/article/details/88048276

  7. C#进阶系列—WebApi

    参考学习优秀博客地址:http://www.cnblogs.com/landeanfen/p/5177176.html

  8. 使用tensorflow训练SSD(一):相关环境的配置

    在使用TensorFlow进行目标检测时,首先需要下载tensorflow object detection API模型,该模型的下载地址为https://github.com/tensorflow/ ...

  9. ZOJ Problem Set - 1010

    算法:已知多边形各顶点坐标,求多边形面积的公式 http://www.cnblogs.com/FleetingTime/p/3849957.html http://www.mathchina.net/ ...

  10. 《你必须知道的495个C语言问题》读书笔记之第15-20章:浮点数、风格、杂项

    一.可变参数列表 1. Q:为什么调用printf前必须要包含<stdio.h>? A:为了把printf的正确原型说明引入作用域.例如,如果可变参数的调用比固定参数的调用效率低,编译器就 ...