diff options
author | A. Unique TensorFlower <gardener@tensorflow.org> | 2017-01-17 14:03:09 -0800 |
---|---|---|
committer | TensorFlower Gardener <gardener@tensorflow.org> | 2017-01-17 14:28:12 -0800 |
commit | 66b5684133bda0a3050e1573f747d86c645dfd67 (patch) | |
tree | 1f3347a68c7f8b9f36b0a6ac0e37f3d77dd3e806 /tensorflow/core/kernels/record_input_op.cc | |
parent | bf67d0a1c52c303f9018c00cbc030dc35438ed2c (diff) |
Add a new lightweight queue-like object - RecordInput
Change: 144752664
Diffstat (limited to 'tensorflow/core/kernels/record_input_op.cc')
-rw-r--r-- | tensorflow/core/kernels/record_input_op.cc | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/tensorflow/core/kernels/record_input_op.cc b/tensorflow/core/kernels/record_input_op.cc new file mode 100644 index 0000000000..60c0a7d2d8 --- /dev/null +++ b/tensorflow/core/kernels/record_input_op.cc @@ -0,0 +1,67 @@ +/* Copyright 2016 The TensorFlow Authors. All Rights Reserved. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +==============================================================================*/ + +#include "tensorflow/core/framework/op_kernel.h" +#include "tensorflow/core/framework/resource_mgr.h" +#include "tensorflow/core/framework/tensor.h" +#include "tensorflow/core/framework/tensor_shape.h" +#include "tensorflow/core/kernels/record_yielder.h" +#include "tensorflow/core/lib/strings/strcat.h" +#include "tensorflow/core/platform/env.h" + +namespace tensorflow { + +class RecordInputOp : public OpKernel { + public: + explicit RecordInputOp(OpKernelConstruction* ctx) : OpKernel(ctx) { +#define GETATTR(TYPE, FIELD) \ + TYPE FIELD; \ + OP_REQUIRES_OK(ctx, ctx->GetAttr(#FIELD, &FIELD)); + + GETATTR(string, file_pattern); + GETATTR(int64, file_random_seed); + GETATTR(float, file_shuffle_shift_ratio); + GETATTR(int64, file_buffer_size); + GETATTR(int64, file_parallelism); + GETATTR(int64, batch_size); +#undef GETATTR + + RecordYielder::Options yopts; + yopts.file_pattern = file_pattern; + yopts.seed = file_random_seed; + yopts.bufsize = file_buffer_size; + yopts.file_shuffle_shift_ratio = file_shuffle_shift_ratio; + yopts.parallelism = file_parallelism; + yielder_ = std::unique_ptr<RecordYielder>(new RecordYielder(ctx, yopts)); + + batch_size_ = batch_size; + } + + void Compute(OpKernelContext* ctx) override { + Tensor out(DT_STRING, {batch_size_}); + auto t_out = out.flat<string>(); + for (int i = 0; i < batch_size_; ++i) { + OP_REQUIRES_OK(ctx, yielder_->Yield(&t_out(i))); + } + ctx->set_output(0, out); + } + + private: + int64 batch_size_; + std::unique_ptr<RecordYielder> yielder_; +}; + +REGISTER_KERNEL_BUILDER(Name("RecordInput").Device(DEVICE_CPU), RecordInputOp); +} // namespace tensorflow |