forked from SciSharp/TensorFlow.NET
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathFullType.cs
More file actions
450 lines (418 loc) · 17.5 KB
/
FullType.cs
File metadata and controls
450 lines (418 loc) · 17.5 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
// <auto-generated>
// Generated by the protocol buffer compiler. DO NOT EDIT!
// source: tensorflow/core/framework/full_type.proto
// </auto-generated>
#pragma warning disable 1591, 0612, 3021
#region Designer generated code
using pb = global::Google.Protobuf;
using pbc = global::Google.Protobuf.Collections;
using pbr = global::Google.Protobuf.Reflection;
using scg = global::System.Collections.Generic;
namespace Tensorflow {
/// <summary>Holder for reflection information generated from tensorflow/core/framework/full_type.proto</summary>
public static partial class FullTypeReflection {
#region Descriptor
/// <summary>File descriptor for tensorflow/core/framework/full_type.proto</summary>
public static pbr::FileDescriptor Descriptor {
get { return descriptor; }
}
private static pbr::FileDescriptor descriptor;
static FullTypeReflection() {
byte[] descriptorData = global::System.Convert.FromBase64String(
string.Concat(
"Cil0ZW5zb3JmbG93L2NvcmUvZnJhbWV3b3JrL2Z1bGxfdHlwZS5wcm90bxIK",
"dGVuc29yZmxvdyJyCgtGdWxsVHlwZURlZhInCgd0eXBlX2lkGAEgASgOMhYu",
"dGVuc29yZmxvdy5GdWxsVHlwZUlkEiUKBGFyZ3MYAiADKAsyFy50ZW5zb3Jm",
"bG93LkZ1bGxUeXBlRGVmEgsKAXMYAyABKAlIAEIGCgRhdHRyKqwDCgpGdWxs",
"VHlwZUlkEg0KCVRGVF9VTlNFVBAAEgsKB1RGVF9WQVIQARILCgdURlRfQU5Z",
"EAISDwoLVEZUX1BST0RVQ1QQAxIQCgxURlRfQ0FMTEFCTEUQZBIPCgpURlRf",
"VEVOU09SEOgHEg4KCVRGVF9BUlJBWRDpBxIRCgxURlRfT1BUSU9OQUwQ6gcS",
"EAoLVEZUX0RBVEFTRVQQ9k4SDQoIVEZUX0JPT0wQyAESDgoJVEZUX1VJTlQ4",
"EMkBEg8KClRGVF9VSU5UMTYQygESDwoKVEZUX1VJTlQzMhDLARIPCgpURlRf",
"VUlOVDY0EMwBEg0KCFRGVF9JTlQ4EM0BEg4KCVRGVF9JTlQxNhDOARIOCglU",
"RlRfSU5UMzIQzwESDgoJVEZUX0lOVDY0ENABEg0KCFRGVF9IQUxGENEBEg4K",
"CVRGVF9GTE9BVBDSARIPCgpURlRfRE9VQkxFENMBEhEKDFRGVF9CRkxPQVQx",
"NhDXARISCg1URlRfQ09NUExFWDY0ENQBEhMKDlRGVF9DT01QTEVYMTI4ENUB",
"Eg8KClRGVF9TVFJJTkcQ1gFCfQoYb3JnLnRlbnNvcmZsb3cuZnJhbWV3b3Jr",
"Qg5GdWxsVHlwZVByb3Rvc1ABWkxnaXRodWIuY29tL3RlbnNvcmZsb3cvdGVu",
"c29yZmxvdy90ZW5zb3JmbG93L2dvL2NvcmUvZnJhbWV3b3JrL3R5cGVzX2dv",
"X3Byb3Rv+AEBYgZwcm90bzM="));
descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData,
new pbr::FileDescriptor[] { },
new pbr::GeneratedClrTypeInfo(new[] {typeof(global::Tensorflow.FullTypeId), }, null, new pbr::GeneratedClrTypeInfo[] {
new pbr::GeneratedClrTypeInfo(typeof(global::Tensorflow.FullTypeDef), global::Tensorflow.FullTypeDef.Parser, new[]{ "TypeId", "Args", "S" }, new[]{ "Attr" }, null, null, null)
}));
}
#endregion
}
#region Enums
/// <summary>
/// Experimental. Represents the complete type information of a TensorFlow value.
/// </summary>
public enum FullTypeId {
/// <summary>
/// The default represents an uninitialized values.
/// </summary>
[pbr::OriginalName("TFT_UNSET")] TftUnset = 0,
/// <summary>
/// Type variables may serve as placeholder for any other type ID in type
/// templates.
///
/// Examples:
/// TFT_DATASET[TFT_VAR["T"]] is a Dataset returning a type indicated by "T".
/// TFT_TENSOR[TFT_VAR["T"]] is a Tensor of n element type indicated by "T".
/// TFT_TENSOR[TFT_VAR["T"]], TFT_TENSOR[TFT_VAR["T"]] are two tensors of
/// identical element types.
/// TFT_TENSOR[TFT_VAR["P"]], TFT_TENSOR[TFT_VAR["Q"]] are two tensors of
/// potentially different element types.
/// </summary>
[pbr::OriginalName("TFT_VAR")] TftVar = 1,
/// <summary>
/// Wildcard type. Describes a parameter of unknown type. In TensorFlow, that
/// can mean either a "Top" type (accepts any type), or a dynamically typed
/// object whose type is unknown in context.
/// Important: "unknown" does not necessarily mean undeterminable!
/// </summary>
[pbr::OriginalName("TFT_ANY")] TftAny = 2,
/// <summary>
/// The algebraic product type. This is an algebraic type that may be used just
/// for logical grouping. Not to confused with TFT_TUPLE which describes a
/// concrete object of several elements.
///
/// Example:
/// TFT_DATASET[TFT_PRODUCT[TFT_TENSOR[TFT_INT32], TFT_TENSOR[TFT_FLOAT64]]]
/// is a Dataset producing two tensors, an integer one and a float one.
/// </summary>
[pbr::OriginalName("TFT_PRODUCT")] TftProduct = 3,
/// <summary>
/// Callable types describe functions and ops.
///
/// Parametrization:
/// TFT_CALLABLE[<arg type>, <return type>]
/// * <arg_type> is the type of the arguments; TFT_PRODUCT represents
/// multiple
/// arguments.
/// * <return_type> is the return type; TFT_PRODUCT represents multiple
/// return values (that means that callables returning multiple things
/// don't necessarily return a single tuple).
///
/// Example:
/// TFT_CALLABLE[
/// TFT_ANY,
/// TFT_PRODUCT[TFT_TENSOR[TFT_INT32], TFT_TENSOR[TFT_FLOAT64]],
/// ]
/// is a callable with unspecified (for now) input arguments, and
/// two return values of type tensor.
/// </summary>
[pbr::OriginalName("TFT_CALLABLE")] TftCallable = 100,
/// <summary>
/// The usual Tensor. This is a parametric type.
///
/// Parametrization:
/// TFT_TENSOR[<element type>, <shape type>]
/// * <element_type> is currently limited to one of the element types
/// defined below.
/// * <shape_type> is not yet defined, and may only be TFT_UNKNOWN for now.
///
/// A TFT_SHAPE type will be defined in the future.
///
/// Example:
/// TFT_TENSOR[TFT_INT32, TFT_UNKNOWN]
/// is a Tensor of int32 element type and unknown shape.
///
/// TODO(mdan): Define TFT_SHAPE and add more examples.
/// </summary>
[pbr::OriginalName("TFT_TENSOR")] TftTensor = 1000,
/// <summary>
/// Array (or tensorflow::TensorList in the variant type registry).
/// Note: this is not to be confused with the deprecated `TensorArray*` ops
/// which are not supported by FullType.
/// This type represents a random-access list whose elements can be
/// described by a single type. Although immutable, Array is expected to
/// support efficient mutation semantics (i.e. element update) in the
/// user-facing API.
/// The element type may be generic or even TFT_ANY for a heterogenous list.
///
/// Parametrization:
/// TFT_ARRAY[<element type>]
/// * <element_type> may be any concrete type.
///
/// Examples:
/// TFT_ARRAY[TFT_TENSOR[TFT_INT32]] is a TensorArray holding int32 Tensors
/// of any shape.
/// TFT_ARRAY[TFT_TENSOR[TFT_UNKNOWN]] is a TensorArray holding Tensors of
/// mixed element types.
/// TFT_ARRAY[TFT_UNKNOWN] is a TensorArray holding any element type.
/// TFT_ARRAY[] is equivalent to TFT_ARRAY[TFT_UNKNOWN].
/// TFT_ARRAY[TFT_ARRAY[]] is an array or arrays (of unknown types).
/// </summary>
[pbr::OriginalName("TFT_ARRAY")] TftArray = 1001,
/// <summary>
/// Optional (or tensorflow::OptionalVariant in the variant type registry).
/// This type represents a value that may either hold an element of a single
/// specified type, or nothing at all.
///
/// Parametrization:
/// TFT_OPTIONAL[<element type>]
/// * <element_type> may be any concrete type.
///
/// Examples:
/// TFT_OPTIONAL[TFT_TENSOR[TFT_INT32]] is an Optional holding an int32
/// Tensor of any shape.
/// </summary>
[pbr::OriginalName("TFT_OPTIONAL")] TftOptional = 1002,
/// <summary>
/// Datasets created by tf.data ops and APIs. Datasets have generator/iterable
/// semantics, that is, one can construct an iterator from them. Like
/// Array, they are considered to return elements that can be described
/// by a single type. Unlike Array, they do not support random access or
/// mutation, and can potentially produce an infinite number of elements.
/// A datasets can produce logical structures (e.g. multiple elements). This
/// is expressed using TFT_PRODUCT.
///
/// Parametrization: TFT_ARRAY[<element type>].
/// <element_type> may be a concrete type or a type symbol. It represents the
/// data type of the elements produced by the dataset.
///
/// Examples:
/// TFT_DATSET[TFT_TENSOR[TFT_INT32]] is a Dataset producing single int32
/// Tensors of unknown shape.
/// TFT_DATSET[TFT_PRODUCT[TFT_TENSOR[TFT_INT32], TFT_TENSOR[TFT_FLOAT32]] is
/// a
/// Dataset producing pairs of Tensors, one integer and one float.
/// Note: The high ID number is to prepare for the eventuality that Datasets
/// will be supported by user types in the future.
/// </summary>
[pbr::OriginalName("TFT_DATASET")] TftDataset = 10102,
/// <summary>
/// The bool element type.
/// TODO(mdan): Quantized types, legacy representations (e.g. ref)
/// </summary>
[pbr::OriginalName("TFT_BOOL")] TftBool = 200,
/// <summary>
/// Integer element types.
/// </summary>
[pbr::OriginalName("TFT_UINT8")] TftUint8 = 201,
[pbr::OriginalName("TFT_UINT16")] TftUint16 = 202,
[pbr::OriginalName("TFT_UINT32")] TftUint32 = 203,
[pbr::OriginalName("TFT_UINT64")] TftUint64 = 204,
[pbr::OriginalName("TFT_INT8")] TftInt8 = 205,
[pbr::OriginalName("TFT_INT16")] TftInt16 = 206,
[pbr::OriginalName("TFT_INT32")] TftInt32 = 207,
[pbr::OriginalName("TFT_INT64")] TftInt64 = 208,
/// <summary>
/// Floating-point element types.
/// </summary>
[pbr::OriginalName("TFT_HALF")] TftHalf = 209,
[pbr::OriginalName("TFT_FLOAT")] TftFloat = 210,
[pbr::OriginalName("TFT_DOUBLE")] TftDouble = 211,
[pbr::OriginalName("TFT_BFLOAT16")] TftBfloat16 = 215,
/// <summary>
/// Complex element types.
/// TODO(mdan): Represent as TFT_COMPLEX[TFT_DOUBLE] instead?
/// </summary>
[pbr::OriginalName("TFT_COMPLEX64")] TftComplex64 = 212,
[pbr::OriginalName("TFT_COMPLEX128")] TftComplex128 = 213,
/// <summary>
/// The string element type.
/// </summary>
[pbr::OriginalName("TFT_STRING")] TftString = 214,
}
#endregion
#region Messages
/// <summary>
/// Highly experimental and very likely to change.
/// This encoding uses tags instead of dedicated messages for regularity. In
/// particular the encoding imposes no restrictions on what the parameters of any
/// type should be, which in particular needs to be true for type symbols.
/// </summary>
public sealed partial class FullTypeDef : pb::IMessage<FullTypeDef> {
private static readonly pb::MessageParser<FullTypeDef> _parser = new pb::MessageParser<FullTypeDef>(() => new FullTypeDef());
private pb::UnknownFieldSet _unknownFields;
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public static pb::MessageParser<FullTypeDef> Parser { get { return _parser; } }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public static pbr::MessageDescriptor Descriptor {
get { return global::Tensorflow.FullTypeReflection.Descriptor.MessageTypes[0]; }
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
pbr::MessageDescriptor pb::IMessage.Descriptor {
get { return Descriptor; }
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public FullTypeDef() {
OnConstruction();
}
partial void OnConstruction();
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public FullTypeDef(FullTypeDef other) : this() {
typeId_ = other.typeId_;
args_ = other.args_.Clone();
switch (other.AttrCase) {
case AttrOneofCase.S:
S = other.S;
break;
}
_unknownFields = pb::UnknownFieldSet.Clone(other._unknownFields);
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public FullTypeDef Clone() {
return new FullTypeDef(this);
}
/// <summary>Field number for the "type_id" field.</summary>
public const int TypeIdFieldNumber = 1;
private global::Tensorflow.FullTypeId typeId_ = global::Tensorflow.FullTypeId.TftUnset;
/// <summary>
/// The principal type represented by this object. This may be a concrete type
/// (Tensor, Dataset) a type variable (used for dependent types) a type
/// symbol (Any, Union). See FullTypeId for details.
/// </summary>
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public global::Tensorflow.FullTypeId TypeId {
get { return typeId_; }
set {
typeId_ = value;
}
}
/// <summary>Field number for the "args" field.</summary>
public const int ArgsFieldNumber = 2;
private static readonly pb::FieldCodec<global::Tensorflow.FullTypeDef> _repeated_args_codec
= pb::FieldCodec.ForMessage(18, global::Tensorflow.FullTypeDef.Parser);
private readonly pbc::RepeatedField<global::Tensorflow.FullTypeDef> args_ = new pbc::RepeatedField<global::Tensorflow.FullTypeDef>();
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public pbc::RepeatedField<global::Tensorflow.FullTypeDef> Args {
get { return args_; }
}
/// <summary>Field number for the "s" field.</summary>
public const int SFieldNumber = 3;
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public string S {
get { return attrCase_ == AttrOneofCase.S ? (string) attr_ : ""; }
set {
attr_ = pb::ProtoPreconditions.CheckNotNull(value, "value");
attrCase_ = AttrOneofCase.S;
}
}
private object attr_;
/// <summary>Enum of possible cases for the "attr" oneof.</summary>
public enum AttrOneofCase {
None = 0,
S = 3,
}
private AttrOneofCase attrCase_ = AttrOneofCase.None;
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public AttrOneofCase AttrCase {
get { return attrCase_; }
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public void ClearAttr() {
attrCase_ = AttrOneofCase.None;
attr_ = null;
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public override bool Equals(object other) {
return Equals(other as FullTypeDef);
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public bool Equals(FullTypeDef other) {
if (ReferenceEquals(other, null)) {
return false;
}
if (ReferenceEquals(other, this)) {
return true;
}
if (TypeId != other.TypeId) return false;
if(!args_.Equals(other.args_)) return false;
if (S != other.S) return false;
if (AttrCase != other.AttrCase) return false;
return Equals(_unknownFields, other._unknownFields);
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public override int GetHashCode() {
int hash = 1;
if (TypeId != global::Tensorflow.FullTypeId.TftUnset) hash ^= TypeId.GetHashCode();
hash ^= args_.GetHashCode();
if (attrCase_ == AttrOneofCase.S) hash ^= S.GetHashCode();
hash ^= (int) attrCase_;
if (_unknownFields != null) {
hash ^= _unknownFields.GetHashCode();
}
return hash;
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public override string ToString() {
return pb::JsonFormatter.ToDiagnosticString(this);
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public void WriteTo(pb::CodedOutputStream output) {
if (TypeId != global::Tensorflow.FullTypeId.TftUnset) {
output.WriteRawTag(8);
output.WriteEnum((int) TypeId);
}
args_.WriteTo(output, _repeated_args_codec);
if (attrCase_ == AttrOneofCase.S) {
output.WriteRawTag(26);
output.WriteString(S);
}
if (_unknownFields != null) {
_unknownFields.WriteTo(output);
}
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public int CalculateSize() {
int size = 0;
if (TypeId != global::Tensorflow.FullTypeId.TftUnset) {
size += 1 + pb::CodedOutputStream.ComputeEnumSize((int) TypeId);
}
size += args_.CalculateSize(_repeated_args_codec);
if (attrCase_ == AttrOneofCase.S) {
size += 1 + pb::CodedOutputStream.ComputeStringSize(S);
}
if (_unknownFields != null) {
size += _unknownFields.CalculateSize();
}
return size;
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public void MergeFrom(FullTypeDef other) {
if (other == null) {
return;
}
if (other.TypeId != global::Tensorflow.FullTypeId.TftUnset) {
TypeId = other.TypeId;
}
args_.Add(other.args_);
switch (other.AttrCase) {
case AttrOneofCase.S:
S = other.S;
break;
}
_unknownFields = pb::UnknownFieldSet.MergeFrom(_unknownFields, other._unknownFields);
}
[global::System.Diagnostics.DebuggerNonUserCodeAttribute]
public void MergeFrom(pb::CodedInputStream input) {
uint tag;
while ((tag = input.ReadTag()) != 0) {
switch(tag) {
default:
_unknownFields = pb::UnknownFieldSet.MergeFieldFrom(_unknownFields, input);
break;
case 8: {
TypeId = (global::Tensorflow.FullTypeId) input.ReadEnum();
break;
}
case 18: {
args_.AddEntriesFrom(input, _repeated_args_codec);
break;
}
case 26: {
S = input.ReadString();
break;
}
}
}
}
}
#endregion
}
#endregion Designer generated code