Add tpu_ordinal_selector_op.
PiperOrigin-RevId: 225307980
This commit is contained in:
parent
7b9f418c37
commit
c2cb414e54
@ -102,6 +102,7 @@ tf_gen_op_libs(
|
||||
"replication_ops",
|
||||
"tpu_configuration_ops",
|
||||
"tpu_embedding_ops",
|
||||
"tpu_ordinal_selector_op",
|
||||
],
|
||||
deps = [
|
||||
"//tensorflow/contrib/tpu/proto:tpu_embedding_configuration_proto_cc",
|
||||
@ -153,6 +154,13 @@ tf_gen_op_wrapper_py(
|
||||
],
|
||||
)
|
||||
|
||||
tf_gen_op_wrapper_py(
|
||||
name = "tpu_ordinal_selector_op",
|
||||
deps = [
|
||||
":tpu_ordinal_selector_op_op_lib",
|
||||
],
|
||||
)
|
||||
|
||||
py_library(
|
||||
name = "profiler",
|
||||
srcs = ["python/profiler/__init__.py"],
|
||||
|
||||
39
tensorflow/contrib/tpu/ops/tpu_ordinal_selector_op.cc
Normal file
39
tensorflow/contrib/tpu/ops/tpu_ordinal_selector_op.cc
Normal file
@ -0,0 +1,39 @@
|
||||
/* Copyright 2017 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.h"
|
||||
#include "tensorflow/core/framework/shape_inference.h"
|
||||
|
||||
namespace tensorflow {
|
||||
|
||||
REGISTER_OP("TPUOrdinalSelector")
|
||||
.Output("device_ordinals: int32")
|
||||
.SetIsStateful()
|
||||
.SetShapeFn([](::tensorflow::shape_inference::InferenceContext* c) {
|
||||
c->set_output(0,
|
||||
c->Vector(shape_inference::InferenceContext::kUnknownDim));
|
||||
return Status::OK();
|
||||
})
|
||||
.Doc(R"doc(
|
||||
A TPU core selector Op.
|
||||
|
||||
This Op produces a set of TPU cores (for warm-up) or a single TPU core
|
||||
(for regular inference) to execute the TPU program on. The output is
|
||||
consumed by TPUPartitionedCall.
|
||||
|
||||
device_ordinals: A vector 1 or more TPU cores.
|
||||
)doc");
|
||||
|
||||
} // namespace tensorflow
|
||||
Loading…
x
Reference in New Issue
Block a user