本文整理匯總了Python中tensorflow.contrib.slim方法的典型用法代碼示例。如果您正苦於以下問題:Python contrib.slim方法的具體用法?Python contrib.slim怎麽用?Python contrib.slim使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類tensorflow.contrib
的用法示例。
在下文中一共展示了contrib.slim方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _define_eval_metrics
# 需要導入模塊: from tensorflow import contrib [as 別名]
# 或者: from tensorflow.contrib import slim [as 別名]
def _define_eval_metrics(end_points, data_batched):
metric_map = super(ClassifierModel, ClassifierModel)._define_eval_metrics(end_points, data_batched)
# Define the metrics:
# streaming_auc requires inputs to be within [0,1]
targets = data_batched.get('target')
clipped_predictions = tf.clip_by_value(end_points['Predictions'], 0, 1)
metric_map['AUC'] = tf.metrics.auc(targets, clipped_predictions)
metric_map['mean_squared_error'] = slim.metrics.streaming_mean_squared_error(end_points['Predictions'], targets)
metric_map['precision_at_thresholds'] = tf.metrics.precision_at_thresholds(targets, clipped_predictions,
[i / 10.0 for i in range(0, 11)])
metric_map['recall_at_thresholds'] = tf.metrics.recall_at_thresholds(targets, clipped_predictions,
[i / 10.0 for i in range(0, 11)])
return metric_map
示例2: setup_metrics
# 需要導入模塊: from tensorflow import contrib [as 別名]
# 或者: from tensorflow.contrib import slim [as 別名]
def setup_metrics( inputs, model, cfg ):
# predictions = model[ 'model' ].
# Choose the metrics to compute:
# names_to_values, names_to_updates = slim.metrics.aggregate_metric_map( {} )
return {}, {}
示例3: summarize_data_utilization
# 需要導入模塊: from tensorflow import contrib [as 別名]
# 或者: from tensorflow.contrib import slim [as 別名]
def summarize_data_utilization(v, tf_global_step, batch_size, epsilon=0.001):
"""Summarizes the samples of non-zero weights during training.
Args:
v: a tensor [batch_size, 1] represents the sample weights.
0: loss, 1: loss difference to the moving average, 2: label and 3: epoch,
where epoch is an integer between 0 and 99 (the first and the last epoch).
tf_global_step: the tensor of the current global step.
batch_size: an integer batch_size
epsilon: the rounding error. If the weight is smaller than epsilon then set
it to zero.
Returns:
data_util: a tensor of data utilization.
"""
nonzero_v = tf.get_variable('data_util/nonzero_v', [],
initializer=tf.zeros_initializer(),
trainable=False,
dtype=tf.float32)
rounded_v = tf.maximum(v - epsilon, tf.to_float(0))
# Log data utilization
nonzero_v = tf.assign_add(nonzero_v, tf.count_nonzero(
rounded_v, dtype=tf.float32))
# slim runs extra sessions to log, causing
# the value lager than 1 (data are fed but the global step is not changed)
# so we use tf_global_step + 2
data_util = (nonzero_v) / tf.to_float(batch_size) / (
tf.to_float(tf_global_step) + 2)
data_util = tf.minimum(data_util, 1)
tf.stop_gradient(data_util)
slim.summaries.add_scalar_summary(data_util, 'data_util/data_util')
slim.summaries.add_scalar_summary(tf.reduce_sum(v), 'data_util/batch_sum_v')
return data_util
示例4: run_training
# 需要導入模塊: from tensorflow import contrib [as 別名]
# 或者: from tensorflow.contrib import slim [as 別名]
def run_training( cfg ):
# set up logging
tf.logging.set_verbosity( tf.logging.INFO )
with tf.Graph().as_default() as g:
# create ops and placeholders
inputs = utils.setup_input( cfg, is_training=False, use_filename_queue=True )
RuntimeDeterminedEnviromentVars.load_dynamic_variables( inputs, cfg )
RuntimeDeterminedEnviromentVars.populate_registered_variables()
# build model (and losses and train_op)
model = setup_model( inputs, cfg, is_training=False )
# set up metrics to evaluate
names_to_values, names_to_updates = setup_metrics( inputs, model, cfg )
# execute training
start_time = time.time()
utils.print_start_info( cfg, inputs[ 'max_steps' ], is_training=False )
training_runners = { 'sess': tf.Session(), 'coord': tf.train.Coordinator() }
data_prefetch_init_fn = utils.get_data_prefetch_threads_init_fn( inputs, cfg, is_training=False, use_filename_queue=True )
training_runners[ 'threads' ] = data_prefetch_init_fn( training_runners[ 'sess' ], training_runners[ 'coord' ] )
try:
# This just returns the imput as output. It is for testing data
# input only.
for step in xrange( inputs[ 'max_steps' ] ):
input_batch, target_batch, data_idx = training_runners['sess'].run( [
model['input_batch'], model['target_batch'], model[ 'data_idxs' ] ] )
if training_runners['coord'].should_stop():
break
finally:
utils.request_data_loading_end( training_runners )
utils.end_data_loading_and_sess( training_runners )
# else: # Use tf.slim
# train_log_dir = os.path.join( cfg['log_dir'], 'slim-train' )
# # When ready to use a model, use the code below
# train( model[ 'train_op' ],
# train_log_dir,
# get_data_prefetch_threads_init_fn( inputs, cfg ),
# global_step=model[ 'global_step' ],
# number_of_steps=inputs[ 'max_steps' ],
# init_fn=model[ 'init_fn' ],
# save_summaries_secs=300,
# save_interval_secs=600,
# saver=model[ 'saver_op' ] )
end_train_time = time.time() - start_time
print('time to train %d epochs: %.3f hrs' % (cfg['num_epochs'], end_train_time/(60*60)))
print('avg time per epoch: %.3f hrs' % ( (end_train_time/(60*60)) / cfg['num_epochs']) )